/* ============================================================
   NGS ADVISORY — Contact page
   Self-contained: own design tokens, no dependency on styles.css.
   Mirrors the For Physicians / Thanks palette. Site nav + footer
   come from header.php / footer.php (site-chrome.css).
   ============================================================ */
:root {
  --bg:#EEF1F4; --bg-2:#E4E8ED; --bg-3:#DCE1E7; --paper:#F7F8FA;
  --ink:#0B1220; --ink-2:#1B2536; --ink-3:#38445A;
  --muted:#6B7689; --muted-2:#8A94A6;
  --line:#C9D0DA; --line-2:#D9DEE6; --line-soft:rgba(11,18,32,0.08);
  --blue:#2B6CB0; --blue-deep:#1E4E7E; --blue-soft:#DCE7F2;
  --gold:#B8862F; --gold-soft:#EFE3C5; --gold-deep:#8C6620;
  --positive:#3F7D5F; --alert:#B25842;
  --serif:"Newsreader","Source Serif 4",Georgia,serif;
  --sans:"Inter",-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,monospace;
  --display:"Playfair Display","Newsreader",Georgia,serif;
  --maxw:1180px; --gutter:clamp(20px,4vw,56px);
  --radius:4px; --radius-lg:10px;
  --shadow-sm:0 1px 2px rgba(11,18,32,0.04),0 1px 1px rgba(11,18,32,0.03);
  --shadow-md:0 6px 24px -8px rgba(11,18,32,0.12),0 2px 6px rgba(11,18,32,0.05);
  --shadow-lg:0 24px 60px -20px rgba(11,18,32,0.22),0 8px 24px -8px rgba(11,18,32,0.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block}
.serif{font-family:var(--serif)} .mono{font-family:var(--mono)} .display{font-family:var(--display)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);font-weight:500}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-0.01em;color:var(--ink);margin:0}
h1{font-size:clamp(44px,5.4vw,72px);line-height:1.04;letter-spacing:-0.025em}
h2{font-size:clamp(26px,2.6vw,36px);line-height:1.15}
h3{font-size:clamp(18px,1.4vw,22px);line-height:1.25}
p{margin:0;color:var(--ink-2)}
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
::selection{background:var(--blue-soft);color:var(--ink)}

.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:500;letter-spacing:0.01em;border:1px solid transparent;transition:all .18s ease;white-space:nowrap}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--ink-2);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(255,255,255,0.4)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep);color:var(--paper)}
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;padding:4px 9px;border:1px solid var(--line);border-radius:3px;color:var(--ink-3);background:var(--paper)}

@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse-ring{0%{transform:scale(0.6);opacity:0.7}100%{transform:scale(1.45);opacity:0}}
.rise{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}
.delay-1{animation-delay:.08s}.delay-2{animation-delay:.16s}.delay-3{animation-delay:.24s}
.delay-4{animation-delay:.32s}.delay-5{animation-delay:.4s}.delay-6{animation-delay:.48s}

/* ---- Hero ---- */
.hero{padding:clamp(64px,8vw,112px) 0 clamp(40px,5vw,72px);position:relative}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px var(--gold-soft)}
.hero-eyebrow::after{content:"";flex:1;height:1px;background:var(--line);max-width:120px}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:72px;align-items:end}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:32px}}
.hero h1 em{font-style:italic;color:var(--blue-deep);font-family:var(--display)}
.hero .lede{font-family:var(--serif);font-size:clamp(17px,1.5vw,21px);line-height:1.5;color:var(--ink-2);max-width:540px;margin-top:28px}
.hero .meta{display:flex;flex-direction:column;gap:0;padding-bottom:8px}
.hero .meta-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid var(--line-soft);font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.hero .meta-row:first-child{border-top:1px solid var(--ink)}
.hero .meta-row .v{color:var(--ink)}
.hero .meta-row .v.gold{color:var(--gold-deep)}
.hero .meta-row .v.pos{color:var(--positive)}
.hero .meta-row:last-child{border-bottom:1px solid var(--line-soft)}

/* ---- Channel grid ---- */
.channels{padding:clamp(40px,5vw,64px) 0;border-top:1px solid var(--line-soft)}
.channel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--paper);box-shadow:var(--shadow-sm)}
@media(max-width:880px){.channel-grid{grid-template-columns:1fr}}
.channel{padding:32px 28px;border-right:1px solid var(--line-soft);display:flex;flex-direction:column;gap:14px;position:relative;transition:background .18s;min-width:0}
.channel:last-child{border-right:none}
@media(max-width:880px){.channel{border-right:none;border-bottom:1px solid var(--line-soft)}.channel:last-child{border-bottom:none}}
.channel:hover{background:var(--bg-2)}
.channel .num{font-family:var(--mono);font-size:10.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--blue)}
.channel .ic{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:6px}
.channel .ic svg{width:18px;height:18px}
.channel h3{font-family:var(--serif);letter-spacing:-0.01em}
.channel .v{font-family:var(--mono);font-size:14px;color:var(--ink);letter-spacing:0.01em;font-weight:500;word-break:break-word}
.channel .v.email{color:var(--blue-deep)}
.channel .desc{font-size:13.5px;color:var(--ink-3);line-height:1.55}
.channel .foot{margin-top:auto;padding-top:14px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);border-top:1px dashed var(--line-2)}
.channel .foot .ok{color:var(--positive);display:inline-flex;align-items:center;gap:6px}
.channel .foot .ok::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--positive);box-shadow:0 0 0 3px rgba(63,125,95,0.18)}

/* ---- Body grid: form + side ---- */
.body-section{padding:clamp(48px,6vw,80px) 0;border-top:1px solid var(--line-soft)}
.body-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:56px;align-items:start}
@media(max-width:980px){.body-grid{grid-template-columns:1fr;gap:40px}}

/* ---- Form ---- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;min-width:0}
.form-head{padding:22px 32px;border-bottom:1px solid var(--line-2);background:var(--bg-2);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.form-head .left{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3)}
.form-head .left .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
.form-head .right{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:0.1em}

.form-body{padding:32px;display:grid;gap:22px}

/* Honeypot — kept off-screen, never visible to humans. */
.form-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

/* Role toggle — fixed: min-width:0 prevents overflow at narrow widths */
.role-toggle{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg)}
.role-toggle label{padding:16px 18px;display:flex;flex-direction:column;gap:4px;cursor:pointer;border-right:1px solid var(--line);transition:all .15s;position:relative;min-width:0}
.role-toggle label:last-child{border-right:none}
.role-toggle input{position:absolute;opacity:0;pointer-events:none}
.role-toggle .role-k{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);transition:color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.role-toggle .role-v{font-family:var(--serif);font-size:17px;color:var(--ink-2);letter-spacing:-0.01em;transition:color .15s;line-height:1.25}
.role-toggle .role-d{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.45}
.role-toggle label:hover{background:var(--bg-2)}
.role-toggle label:has(input:checked){background:var(--paper);box-shadow:inset 0 -2px 0 var(--ink)}
.role-toggle label:has(input:checked) .role-k{color:var(--gold-deep)}
.role-toggle label:has(input:checked) .role-v{color:var(--ink);font-weight:500}

.field{display:flex;flex-direction:column;gap:8px;min-width:0}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.field-row{grid-template-columns:1fr}}
.field-label{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:8px}
.field-label .req{color:var(--alert)}
.field-label .opt{color:var(--muted-2);font-size:9.5px}
.input,.textarea,.select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;font-family:var(--sans);font-size:14.5px;color:var(--ink);transition:all .15s;font-feature-settings:"ss01","cv11"}
.textarea{font-family:var(--sans);min-height:140px;resize:vertical;line-height:1.5}
.select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%2338445A' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.input::placeholder,.textarea::placeholder{color:var(--muted-2)}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--ink);background:var(--paper);box-shadow:0 0 0 3px rgba(11,18,32,0.06)}

/* Field-level error highlight (added by submit handler when API returns
   {error: validation_failed, errors: {<field>: msg, ...}}). The :focus
   variant has to be spelled out — without it, the .input:focus rule above
   wins specificity-wise and resets the box-shadow when the user clicks
   into an errored field. */
.field.is-error .input,
.field.is-error .textarea,
.field.is-error .select,
.field.is-error .input:focus,
.field.is-error .textarea:focus,
.field.is-error .select:focus{border-color:var(--alert);background:#fff;box-shadow:0 0 0 3px rgba(178,88,66,0.18)}
.field.is-error .field-label{color:var(--alert)}
.consent.is-error{border-color:var(--alert);background:rgba(178,88,66,0.06);color:var(--alert)}
.consent.is-error a{color:var(--alert);border-color:var(--alert)}

/* Conditional patient-only block — animated grow/shrink.
   max-height (with a generous ceiling) instead of grid-template-rows: 0fr→1fr,
   which only animates in Chromium 117+ / Firefox 109+. max-height works in
   every evergreen browser; the ceiling has to comfortably exceed the block's
   real height (currently ~452px). */
.patient-wrap{max-height:0;overflow:hidden;transition:max-height .55s cubic-bezier(.2,.7,.2,1)}
.patient-wrap.is-active{max-height:800px}
.patient-only{padding:18px;background:var(--blue-soft);border:1px dashed var(--blue);border-radius:var(--radius);display:flex;gap:18px;flex-direction:column;opacity:0;transform:translateY(-8px) scale(.985);transform-origin:top center;transition:opacity .35s ease .08s,transform .5s cubic-bezier(.2,.7,.2,1) .05s}
.patient-wrap.is-active .patient-only{opacity:1;transform:translateY(0) scale(1)}
.patient-only .pn{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue-deep);display:flex;align-items:center;gap:10px}
.patient-only .pn::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--blue-deep)}
.patient-only .input,.patient-only .select{background:var(--paper)}

/* Form body settles smoothly when block toggles */
.form-body{transition:gap .35s ease}
@media(prefers-reduced-motion:reduce){
  .patient-wrap,.patient-only{transition:none !important}
}

.consent{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;background:var(--bg);border:1px solid var(--line-2);border-radius:var(--radius);font-size:13px;color:var(--ink-3);line-height:1.5}
.consent input{margin-top:3px;accent-color:var(--ink)}
.consent a{color:var(--blue-deep);border-bottom:1px solid var(--line);padding-bottom:1px}
.consent a:hover{color:var(--ink);border-color:var(--ink)}

.form-foot{padding:20px 32px;background:var(--bg-2);border-top:1px solid var(--line-2);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.form-foot .note{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.form-foot .note .lock{display:inline-flex;align-items:center;gap:6px}
.form-foot .note .lock::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--positive);box-shadow:0 0 0 3px rgba(63,125,95,0.18)}
.form-foot .form-status{font-family:var(--mono);font-size:11px;letter-spacing:0.04em;color:var(--muted);min-height:1em}
.form-foot .form-status.is-error{color:var(--alert);text-transform:none;letter-spacing:0}

/* ---- Side column ---- */
.side{display:flex;flex-direction:column;gap:24px}
.side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg)}
.side-card.gold{border-left:3px solid var(--gold)}
.side-card.blue{border-left:3px solid var(--blue)}
.side-card.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.side-card-pad{padding:24px 26px}
.side-card .title{font-family:var(--serif);font-size:20px;letter-spacing:-0.01em;color:var(--ink)}
.side-card.dark .title{color:var(--paper)}
.side-card .eyebrow{margin-bottom:8px}
.side-card.gold .eyebrow{color:var(--gold-deep)}
.side-card.blue .eyebrow{color:var(--blue-deep)}
.side-card.dark .eyebrow{color:rgba(247,248,250,0.6)}
.side-card p{font-size:13.5px;color:var(--ink-3);line-height:1.55;margin-top:8px}
.side-card.dark p{color:rgba(247,248,250,0.7)}
.side-card .row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:11px 0;border-top:1px dashed var(--line-2);font-size:13.5px}
.side-card.dark .row{border-color:rgba(255,255,255,0.12)}
.side-card .row:first-of-type{border-top:none}
.side-card .row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.side-card.dark .row .k{color:rgba(247,248,250,0.5)}
.side-card .row .v{color:var(--ink);font-weight:500;text-align:right}
.side-card.dark .row .v{color:var(--paper)}

/* Hours table */
.hours{display:grid;gap:0;margin-top:6px}
.hours .hrow{display:grid;grid-template-columns:1fr auto;gap:14px;padding:10px 0;border-top:1px dashed var(--line-2);font-size:13.5px;align-items:center}
.hours .hrow:first-child{border-top:none}
.hours .hrow .d{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.hours .hrow .t{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:500}
.hours .hrow.is-now{background:var(--bg-2);margin:0 -26px;padding:10px 26px;border-color:var(--line-2)}
.hours .hrow.is-now .d::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--positive);box-shadow:0 0 0 3px rgba(63,125,95,0.18);margin-right:8px;vertical-align:middle}

/* SLA pills */
.sla-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.sla{padding:14px 12px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius);text-align:center}
.sla .n{font-family:var(--serif);font-size:22px;color:var(--paper);letter-spacing:-0.01em}
.sla .l{font-family:var(--mono);font-size:9.5px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(247,248,250,0.55);margin-top:4px}
.sla.gold{background:rgba(184,134,47,0.14);border-color:rgba(184,134,47,0.4)}
.sla.gold .n{color:var(--gold-soft)}
.sla.gold .l{color:rgba(239,227,197,0.85)}

/* ---- FAQ + Press ---- */
.bottom-section{padding:clamp(48px,6vw,80px) 0;border-top:1px solid var(--line-soft)}
.bottom-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:56px;align-items:start}
@media(max-width:980px){.bottom-grid{grid-template-columns:1fr;gap:40px}}

.faq-list{display:grid;gap:0;margin-top:24px;border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--line-soft);overflow:hidden;transition:background .25s ease}
.faq-item:hover{background:rgba(255,255,255,0.4)}
.faq-item.is-open{background:var(--paper)}

.faq-q{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:22px 4px;cursor:pointer;user-select:none;list-style:none;position:relative;transition:padding .3s cubic-bezier(.2,.7,.2,1)}
.faq-q::-webkit-details-marker{display:none}
.faq-q .num{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--muted);transition:color .25s}
.faq-q .qtxt{font-family:var(--serif);font-size:19px;color:var(--ink);letter-spacing:-0.01em;line-height:1.3;transition:transform .35s cubic-bezier(.2,.7,.2,1),color .25s}
.faq-q .toggle{width:28px;height:28px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-2);flex-shrink:0;transition:transform .4s cubic-bezier(.65,0,.35,1),background .25s,border-color .25s,color .25s;background:var(--paper)}
.faq-q .toggle svg{transition:transform .4s cubic-bezier(.65,0,.35,1)}

.faq-item.is-open .faq-q{padding-left:14px;padding-right:14px}
.faq-item.is-open .faq-q .num{color:var(--gold-deep)}
.faq-item.is-open .faq-q .qtxt{color:var(--ink)}
.faq-item.is-open .faq-q .toggle{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:rotate(135deg)}

/* Animated content reveal */
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s cubic-bezier(.2,.7,.2,1)}
.faq-body > .faq-body-inner{overflow:hidden;min-height:0}
.faq-item.is-open .faq-body{grid-template-rows:1fr}
.faq-a{font-size:14.5px;color:var(--ink-3);line-height:1.65;max-width:680px;padding:0 14px 26px 56px;opacity:0;transform:translateY(-6px);transition:opacity .35s ease .12s,transform .45s cubic-bezier(.2,.7,.2,1) .08s}
.faq-item.is-open .faq-a{opacity:1;transform:translateY(0)}
.faq-a a{color:var(--blue-deep);border-bottom:1px solid var(--line);padding-bottom:1px}
.faq-a a:hover{color:var(--ink);border-color:var(--ink)}

/* Subtle accent bar that grows on open */
.faq-item{position:relative}
.faq-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.faq-item.is-open::before{transform:scaleY(1)}

@media(prefers-reduced-motion:reduce){
  .faq-body,.faq-q,.faq-q .toggle,.faq-q .qtxt,.faq-a,.faq-item::before{transition:none !important}
}

.press-card{background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);padding:32px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.press-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue) 0%,var(--blue) 60%,var(--gold) 60%,var(--gold) 100%)}
.press-card .eyebrow{color:var(--gold)}
.press-card h3{color:var(--paper);font-family:var(--serif);font-size:24px;line-height:1.25;letter-spacing:-0.01em}
.press-card h3 em{font-style:italic;color:var(--gold)}
.press-card p{color:rgba(247,248,250,0.65);font-size:13.5px;line-height:1.55}
.press-card .lines{display:grid;gap:0;margin-top:6px}
.press-card .row{padding:11px 0;border-top:1px solid rgba(255,255,255,0.1);display:flex;justify-content:space-between;font-size:13.5px;gap:14px}
.press-card .row:first-of-type{border-top:1px solid rgba(255,255,255,0.18)}
.press-card .row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(247,248,250,0.5)}
.press-card .row .v{color:var(--paper);font-weight:500}
.press-card .row .v a{color:var(--paper)}
.press-card .row .v a:hover{color:var(--gold)}
