/* psyflo.com — Contact page + shared legal-page styles. */

/* ── Contact hero ──────────────────────────────────────────────── */
.contactpage .contact-hero { padding-top: clamp(44px, 6vw, 76px); padding-bottom: clamp(8px, 1.4vw, 16px); }
.contactpage .contact-hero__eyebrow-row { display: flex; align-items: center; gap: 14px; margin-bottom: clamp(22px, 3vw, 32px); }
.contactpage .contact-hero__eyebrow-row .hero__rule { width: 38px; height: 1px; background: var(--cream-500, #B8A580); flex: 0 0 38px; }
.contactpage .contact-hero__title { font-size: clamp(38px, 5.6vw, 68px); line-height: 1.02; margin: 0; }
.contactpage .contact-hero__lede { margin-top: clamp(20px, 2.6vw, 28px); max-width: 760px; }
.contactpage .contact-hero__offer { margin-top: 20px; font-size: 15px; color: var(--ink-600, #525252); }

/* shared inline link with focus state */
.home .contact-link { color: var(--navy-700, #303F87); font-weight: 500; text-decoration: none; display: inline-flex; align-items: center; gap: 5px; }
.home .contact-link:hover { color: var(--navy-900, #1E2A6B); text-decoration: underline; text-underline-offset: 2px; }
.home .contact-link:focus-visible { outline: 2px solid var(--navy-700, #303F87); outline-offset: 2px; border-radius: 4px; }

/* ── Body grid ─────────────────────────────────────────────────── */
.contactpage .contact-body { padding-block: clamp(32px, 4.5vw, 56px); }
.contactpage .contact-body__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(36px, 5vw, 72px); align-items: start; }

/* Reach list */
.contactpage .reach__list { margin: clamp(24px, 3vw, 32px) 0 0; padding: 0; list-style: none; display: grid; gap: 22px; }
.contactpage .reach__item { padding-bottom: 22px; border-bottom: 1px solid var(--cream-200, #ECE4D2); }
.contactpage .reach__item:last-child { border-bottom: none; padding-bottom: 0; }
.contactpage .reach__k { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-500, #737373); font-weight: 600; }
.contactpage .reach__v { font-size: 17px; color: #0A0A0A; font-weight: 500; margin-top: 7px; }
a.reach__v { width: fit-content; }
.contactpage .reach__d { font-size: 14px; color: var(--ink-600, #525252); margin-top: 5px; line-height: 1.5; }
.contactpage .reach__note { margin-top: clamp(24px, 3vw, 32px); font-size: 14px; color: var(--ink-600, #525252); line-height: 1.6; }

/* Form card */
.contactpage .contact-formcard { background: #fff; border: 1px solid var(--cream-300, #DFD3B7); border-radius: 18px; padding: clamp(28px, 3.6vw, 44px); box-shadow: 0 1px 2px rgba(20,28,74,.04), 0 18px 44px -26px rgba(20,28,74,.18); }
.contactpage .cform { margin-top: 22px; display: grid; gap: 16px; }
.contactpage .cform__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contactpage .cform__field { display: grid; gap: 7px; }
.contactpage .cform__label { font-size: 13px; font-weight: 600; color: var(--ink-700, #404040); }
.contactpage .cform__input { font-family: var(--body-font); font-size: 15px; color: #0A0A0A; background: var(--cream-50, #FBF8F2); border: 1px solid var(--cream-300, #DFD3B7); border-radius: 10px; padding: 11px 13px; width: 100%; transition: border-color 140ms ease, box-shadow 140ms ease; }
.contactpage .cform__input:hover { border-color: var(--cream-500, #B8A580); }
.contactpage .cform__input:focus { outline: none; border-color: var(--navy-500, #5870A8); box-shadow: 0 0 0 3px rgba(88,112,168,.18); }
.contactpage select.cform__input { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5 6 7.5 9 4.5' stroke='%23737373' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 13px center; padding-right: 34px; cursor: pointer; }
.contactpage .cform__textarea { resize: vertical; min-height: 96px; line-height: 1.5; }
.contactpage .cform__disclaimer { font-size: 13px; line-height: 1.55; color: var(--ink-700, #404040); margin: 2px 0 0; padding: 11px 14px; border-left: 2px solid var(--accent, #B8956A); background: color-mix(in srgb, var(--accent, #B8956A) 7%, transparent); border-radius: 0 6px 6px 0; }
.contactpage .cform__submit { margin-top: 4px; width: fit-content; }
.contactpage .cform__fine { font-size: 12.5px; color: var(--ink-500, #737373); line-height: 1.55; margin: 2px 0 0; }
.contactpage .cform__done { display: flex; flex-direction: column; align-items: flex-start; padding: clamp(8px, 2vw, 16px) 0; }
.contactpage .cform__done[hidden] { display: none; }
.contactpage .cform__doneico { width: 44px; height: 44px; border-radius: 50%; background: var(--accent-50, #FAF3E6); border: 1px solid var(--accent-200, #ECD9B0); color: var(--accent-700, #7A5F36); display: grid; place-items: center; margin-bottom: 16px; }
.contactpage .cform__donetitle { font-family: var(--headline-font); font-weight: var(--headline-weight); font-size: 24px; color: #0A0A0A; margin: 0; }
.contactpage .cform__donecopy { font-size: 15px; color: var(--ink-600, #525252); margin: 8px 0 0; line-height: 1.55; }

/* ── 988 note ──────────────────────────────────────────────────── */
.contactpage .contact-crisis { padding-block: 0 clamp(48px, 6vw, 80px); }
.contactpage .contact-crisis__card { display: flex; gap: 16px; align-items: flex-start; max-width: 820px; background: var(--cream-100, #F6F1E8); border: 1px solid var(--cream-300, #DFD3B7); border-radius: 16px; padding: clamp(22px, 3vw, 30px); }
.contactpage .contact-crisis__ico { flex: 0 0 auto; color: var(--gold-700, #7A5F36); margin-top: 2px; }
.contactpage .contact-crisis__title { font-family: var(--headline-font); font-weight: var(--headline-weight); font-size: clamp(19px, 2.1vw, 23px); color: #0A0A0A; margin: 0; letter-spacing: -0.01em; }
.contactpage .contact-crisis__text { font-size: 15px; color: var(--ink-700, #404040); line-height: 1.6; margin: 8px 0 0; }

.home .foot__contactlink { color: rgba(255,255,255,.66); text-decoration: none; }
.home .foot__contactlink:hover { color: #fff; text-decoration: underline; text-underline-offset: 2px; }

/* ── Legal pages (Privacy / Terms) ─────────────────────────────── */
.legalpage .legal-hero { padding-top: clamp(52px, 7vw, 92px); padding-bottom: clamp(8px, 2vw, 20px); }
.legalpage .legal-hero__eyebrow-row { display: flex; align-items: center; gap: 14px; margin-bottom: clamp(20px, 2.6vw, 28px); }
.legalpage .legal-hero__eyebrow-row .hero__rule { width: 38px; height: 1px; background: var(--cream-500, #B8A580); flex: 0 0 38px; }
.legalpage .legal-hero__title { font-family: var(--headline-font); font-weight: var(--headline-weight); letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(34px, 4.6vw, 54px); color: #0A0A0A; margin: 0; }
.legalpage .legal-hero__meta { font-size: 14px; color: var(--ink-500, #737373); margin-top: 16px; }
.legalpage .legal-body { padding-top: clamp(24px, 4vw, 44px); }
.legalpage .legal-grid { display: grid; grid-template-columns: 230px 1fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
.legalpage .legal-toc { position: sticky; top: 96px; }
.legalpage .legal-toc__title { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-500, #737373); font-weight: 600; margin-bottom: 14px; }
.legalpage .legal-toc ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 9px; }
.legalpage .legal-toc a { font-size: 14px; color: var(--ink-600, #525252); text-decoration: none; line-height: 1.4; display: inline-block; }
.legalpage .legal-toc a:hover { color: #0A0A0A; }
.legalpage .legal-toc a:focus-visible { outline: 2px solid var(--navy-700, #303F87); outline-offset: 2px; border-radius: 4px; }
.legalpage .legal-prose { max-width: 720px; }
.legalpage .legal-section { padding-bottom: clamp(28px, 4vw, 40px); margin-bottom: clamp(28px, 4vw, 40px); border-bottom: 1px solid var(--cream-200, #ECE4D2); scroll-margin-top: 92px; }
.legalpage .legal-section:last-child { border-bottom: none; }
.legalpage .legal-section h2 { font-family: var(--headline-font); font-weight: var(--headline-weight); letter-spacing: -0.015em; font-size: clamp(22px, 2.4vw, 28px); color: #0A0A0A; margin: 0 0 14px; }
.legalpage .legal-section p { font-size: 16px; line-height: 1.65; color: var(--ink-700, #404040); margin: 0 0 14px; }
.legalpage .legal-section p:last-child { margin-bottom: 0; }
.legalpage .legal-section ul { margin: 0 0 14px; padding-left: 20px; display: grid; gap: 8px; }
.legalpage .legal-section li { font-size: 16px; line-height: 1.6; color: var(--ink-700, #404040); }
.legalpage .legal-subhead { font-family: var(--headline-font); font-weight: var(--headline-weight); letter-spacing: -0.01em; font-size: clamp(17px, 1.9vw, 20px); color: #0A0A0A; margin: 26px 0 10px; }
.legalpage .legal-note { background: var(--accent-50, #FAF3E6); border: 1px solid var(--accent-200, #ECD9B0); border-radius: 12px; padding: 16px 18px; margin: 6px 0 16px; }
.legalpage .legal-note__title { font-size: 12px; letter-spacing: .06em; text-transform: uppercase; font-weight: 700; color: var(--accent-700, #7A5F36); margin: 0 0 6px; }
.legalpage .legal-note p { margin: 0; font-size: 15px; line-height: 1.6; color: var(--ink-700, #404040); }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .contactpage .contact-body__grid { grid-template-columns: 1fr; gap: 44px; }
  .legalpage .legal-grid { grid-template-columns: 1fr; gap: 28px; }
  .legalpage .legal-toc { position: static; }
}
@media (max-width: 560px) {
  .contactpage .cform__row { grid-template-columns: 1fr; }
}
