/* ============================================================
   Thought Pattern AI - Contact page layout
   Page-specific only; shared chrome is in site.css.
   ============================================================ */

.contact {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(48px, 9vw, 112px) var(--tp-space-8) clamp(56px, 9vw, 120px);
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(var(--tp-space-8), 6vw, var(--tp-space-16));
  align-items: start;
}

/* -------- Left rail: pitch + alternate channels ---------- */
.contact-aside { max-width: 30rem; }
.contact-title {
  font-family: var(--tp-font-display);
  font-weight: var(--tp-fw-regular);
  letter-spacing: var(--tp-ls-display);
  font-size: clamp(2.5rem, 7vw, 4rem);
  line-height: 1;
  text-transform: uppercase;
  color: var(--tp-fg);
  margin: 0 0 var(--tp-space-5);
}
.contact-lede {
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-lg);
  line-height: var(--tp-lh-body);
  color: var(--tp-fg-body);
  margin: 0 0 var(--tp-space-8);
}
.contact-alt { margin: 0; }
.contact-alt dt {
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: var(--tp-ls-caps);
  text-transform: uppercase;
  color: var(--tp-fg-muted);
  margin: 0 0 var(--tp-space-2);
}
.contact-alt dd {
  margin: 0 0 var(--tp-space-6);
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-md);
  color: var(--tp-fg-body);
}
.contact-alt a { color: var(--tp-yellow); text-decoration: none; }
.contact-alt a:hover { color: var(--tp-yellow-hi); }

/* -------- Form card -------------------------------------- */
.contact-card {
  position: relative;
  background: var(--tp-bg-surface);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius-md);
  padding: clamp(var(--tp-space-6), 4vw, var(--tp-space-10));
}

.field { margin-bottom: var(--tp-space-5); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--tp-space-5); }

.field label {
  display: block;
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tp-fg-muted);
  margin: 0 0 var(--tp-space-2);
}
.field label .req { color: var(--tp-yellow); margin-left: 2px; }

.field input,
.field select,
.field textarea {
  width: 100%;
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-base);
  color: var(--tp-fg);
  background: var(--tp-bg-recessed);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius-sm);
  padding: 12px 14px;
  transition: border-color var(--tp-duration-fast) var(--tp-ease-out),
              box-shadow var(--tp-duration-fast) var(--tp-ease-out);
}
.field textarea { min-height: 140px; resize: vertical; line-height: var(--tp-lh-body); }
.field input::placeholder,
.field textarea::placeholder { color: var(--tp-fg-subtle); }

.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--tp-border-active);
  box-shadow: 0 0 0 3px var(--tp-warning-bg);
}
.field input[aria-invalid="true"],
.field textarea[aria-invalid="true"] {
  border-color: var(--tp-danger);
  box-shadow: 0 0 0 3px var(--tp-danger-bg);
}

.field-error {
  display: none;
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  color: var(--tp-danger);
  margin: var(--tp-space-2) 0 0;
}
.field-error.is-visible { display: block; }

/* honeypot - visually hidden, off-screen, not announced */
.hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-submit { margin-top: var(--tp-space-6); }
.contact-submit .btn { width: 100%; cursor: pointer; }
.contact-submit .btn[disabled] { opacity: 0.55; cursor: progress; }

.form-status {
  display: none;
  margin-top: var(--tp-space-5);
  padding: var(--tp-space-4) var(--tp-space-5);
  border-radius: var(--tp-radius-sm);
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-md);
  line-height: var(--tp-lh-body);
}
.form-status.is-visible { display: block; }
.form-status.is-success {
  background: var(--tp-success-bg);
  color: var(--tp-success);
  border: 1px solid rgba(74, 222, 128, 0.35);
}
.form-status.is-error {
  background: var(--tp-danger-bg);
  color: var(--tp-danger);
  border: 1px solid rgba(248, 113, 113, 0.35);
}

.form-fineprint {
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: 0.03em;
  color: var(--tp-fg-subtle);
  margin: var(--tp-space-5) 0 0;
}

/* -------- Responsive ------------------------------------- */
@media (max-width: 860px) {
  .contact { grid-template-columns: 1fr; }
  .contact-aside { max-width: none; }
}
@media (max-width: 560px) {
  .contact { padding-left: var(--tp-space-5); padding-right: var(--tp-space-5); }
  .field-row { grid-template-columns: 1fr; gap: 0; }
}
