/* ============================================================
   CONTACT page — form, response promise, FAQ
   Pairs with kit.css + page.css. Editorial, calm, two-column.
   ============================================================ */

/* ----- Hero (slimmer than landing hero) ----------------- */
.contact-hero { padding-block: clamp(4rem, 9vw, 7rem) clamp(2.5rem, 5vw, 4rem); }
.contact-hero .hero-headline { max-inline-size: 18ch; }
.contact-hero .hero-sub { max-inline-size: 38rem; }

/* ============================================================
   CONTACT BODY — form + sidebar columns
   ============================================================ */
.contact-body {
  padding-block: clamp(2rem, 4vw, 3.5rem) clamp(4rem, 8vw, 7rem);
  border-block-start: 1px solid var(--border-light);
}
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}
@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
}

/* ============================================================
   FORM
   ============================================================ */
.contact-form-wrap { display: flex; flex-direction: column; gap: 1.5rem; }

.form-eyebrow { margin-block-end: 0.5rem; }
.form-lede {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.375rem, 1.6vw, 1.625rem);
  line-height: 1.3; letter-spacing: -0.01em;
  color: var(--ink); margin: 0;
  max-inline-size: 36ch;
}

.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem 1rem;
  margin-block-start: 0.5rem;
}
.field { display: flex; flex-direction: column; gap: 0.4375rem; min-inline-size: 0; }
.field--full { grid-column: 1 / -1; }

.field-label {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 0.4rem;
}
.field-label .req { color: var(--accent-deep); font-style: normal; }
.field-label .opt {
  font-family: var(--font-body);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
  font-size: var(--t-body-s);
  color: var(--muted-light);
}

.input, .select, .textarea {
  inline-size: 100%;
  font-family: var(--font-body);
  font-size: var(--t-body);
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--border-light);
  border-radius: var(--r-md);
  padding: 0.75rem 0.875rem;
  line-height: 1.4;
  transition: border-color var(--t-fast) var(--ease),
              box-shadow var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--muted-light); }
.input:hover, .select:hover, .textarea:hover { border-color: var(--border); }
.input:focus, .select:focus, .textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--accent) 18%, transparent);
}
.textarea { resize: vertical; min-block-size: 8.5rem; }

/* Custom select chevron */
.select {
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-soft) 50%),
                    linear-gradient(135deg, var(--ink-soft) 50%, transparent 50%);
  background-position: calc(100% - 1.125rem) 1.125rem,
                       calc(100% - 0.75rem) 1.125rem;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-inline-end: 2.25rem;
  cursor: pointer;
}
.select:invalid { color: var(--muted-light); }
.select option { color: var(--ink); }

.form-status {
  grid-column: 1 / -1;
  font-size: var(--t-body-s);
  padding: 0.875rem 1rem;
  border-radius: var(--r-md);
  border: 1px solid var(--border-light);
  background: var(--surface-soft);
  color: var(--ink);
}
.form-status.is-success {
  border-color: var(--positive-fg);
  background: var(--positive-bg);
  color: var(--positive-fg);
}
.form-status.is-error {
  border-color: var(--negative-fg);
  background: var(--negative-bg);
  color: var(--negative-fg);
}

.contact-form-actions {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 1.25rem;
  flex-wrap: wrap;
  margin-block-start: 0.25rem;
}
.privacy-note {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  letter-spacing: 0.04em;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.privacy-note::before {
  content: ""; inline-size: 0.5rem; block-size: 0.5rem;
  border-radius: 50%;
  background: oklch(72% 0.13 145);
  box-shadow: 0 0 0 3px oklch(72% 0.13 145 / 0.18);
}

@media (max-width: 600px) {
  .contact-form { grid-template-columns: 1fr; }
}

/* ============================================================
   SIDEBAR — promise card, other ways, locations
   ============================================================ */
.contact-side { display: flex; flex-direction: column; gap: 1.75rem; position: sticky; top: 6rem; }

.contact-side-eyebrow {
  display: block;
  margin-block-end: 1.25rem;
}

.promise-card {
  background: var(--surface);
  border: 1px solid var(--border-light);
  border-radius: var(--r-xl);
  padding: clamp(1.5rem, 2.5vw, 1.875rem);
  position: relative;
  overflow: hidden;
}
.promise-card::before {
  content: ""; position: absolute; inset-block-start: 0; inset-inline: clamp(1.5rem, 2.5vw, 1.875rem);
  block-size: 2px; background: var(--accent); border-radius: 2px;
}
.promise-eyebrow { margin-block-end: 1rem; }
.promise-headline {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.5rem, 2vw, 1.875rem);
  line-height: 1.15; letter-spacing: -0.015em;
  color: var(--ink); margin: 0;
  max-inline-size: 18ch;
}
.promise-headline em { font-style: italic; color: var(--accent-deep); }
.promise-body {
  margin-block-start: 0.875rem;
  font-size: var(--t-body); line-height: 1.55; color: var(--ink-soft);
  max-inline-size: 32ch;
}

.contact-side-block {
  padding-block: 1.5rem;
  border-block-start: 1px solid var(--border-light);
}
.contact-side-block:first-of-type { border-block-start: 0; padding-block-start: 0; }
.contact-side-block h3 {
  font-family: var(--font-mono);
  font-size: var(--t-meta);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 0.875rem;
}
.contact-side-block p,
.contact-side-block .stack {
  margin: 0; color: var(--ink-soft); font-size: var(--t-body);
  line-height: 1.55;
}
.contact-side-block .stack { display: flex; flex-direction: column; gap: 0.25rem; }
.contact-side-block .stack strong {
  color: var(--ink); font-weight: 500;
  font-family: var(--font-display); font-size: 1.0625rem;
  letter-spacing: -0.005em;
}
.contact-side-block .stack a {
  color: var(--ink-soft);
  border-block-end: 1px solid var(--border);
  padding-block-end: 1px;
  align-self: flex-start;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.contact-side-block .stack a:hover { color: var(--accent-deep); border-block-end-color: var(--accent); }

/* Mini FAQ — condensed, in sidebar */
.faq-mini { display: flex; flex-direction: column; }
.faq-mini-item {
  border-block-start: 1px solid var(--border-light);
  padding-block: 0.875rem;
}
.faq-mini-item:first-child { border-block-start: 0; padding-block-start: 0; }
.faq-mini-item:last-child { padding-block-end: 0; }
.faq-mini-item > summary {
  list-style: none;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.0625rem;
  letter-spacing: -0.005em;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  transition: color var(--t-fast) var(--ease);
}
.faq-mini-item > summary::-webkit-details-marker { display: none; }
.faq-mini-item > summary::after {
  content: "+";
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 1.125rem;
  color: var(--ink-soft);
  transition: transform var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.faq-mini-item[open] > summary { color: var(--accent-deep); }
.faq-mini-item[open] > summary::after { content: "−"; color: var(--accent-deep); }
.faq-mini-item > summary:hover { color: var(--accent-deep); }
.faq-mini-item > p {
  margin: 0.625rem 0 0;
  color: var(--ink-soft);
  font-size: var(--t-body);
  line-height: 1.55;
}

@media (max-width: 880px) {
  .contact-side { position: static; }
}

/* ============================================================
   FAQ
   ============================================================ */
.faq {
  padding-block: clamp(4rem, 8vw, 6.5rem);
  background: var(--bg-paper);
  border-block: 1px solid var(--border-light);
}
.faq-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.4fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: start;
}
.faq-aside { position: sticky; top: 6rem; display: flex; flex-direction: column; gap: 1rem; }
.faq-title {
  font-family: var(--font-display); font-weight: 400;
  font-size: var(--t-display-m); line-height: 1.05; letter-spacing: -0.02em;
  color: var(--ink); margin: 0;
  max-inline-size: 14ch;
}
.faq-title em { font-style: italic; color: var(--accent-deep); }
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-block-start: 1px solid var(--border-light);
  padding-block: clamp(1.25rem, 2.5vw, 1.75rem);
}
.faq-item:last-child { border-block-end: 1px solid var(--border-light); }
.faq-q {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.25rem, 1.6vw, 1.5rem);
  letter-spacing: -0.01em; line-height: 1.2;
  color: var(--ink); margin: 0 0 0.625rem;
  text-wrap: balance;
}
.faq-a {
  font-size: var(--t-body-l); line-height: 1.55; color: var(--ink-soft);
  margin: 0; max-inline-size: 56ch; text-wrap: pretty;
}
@media (max-width: 880px) {
  .faq-grid { grid-template-columns: 1fr; }
  .faq-aside { position: static; }
}
