/* ============================================================
   ADULT AUTISM CLARITY — adultautismclarity.com
   Design system v3 — "Editorial Dark"
   Near-black navy · champagne gold · teal · Newsreader + Hanken Grotesk
   Adapted from the approved PSYPACT dark concept.
   ============================================================ */

:root{
  --bg:        #0E1419;
  --bg-2:      #141D24;
  --panel:     #18222B;
  --panel-2:   #1E2B34;
  --ink:       #EEF2F3;
  --ink-soft:  #9AA9B2;
  --ink-dim:   #6E7C85;
  --line:      rgba(255,255,255,0.10);
  --line-2:    rgba(255,255,255,0.16);
  --gold:      #D8A93A;
  --gold-soft: #E7C879;
  --gold-deep: #C2922E;
  --gold-ghost: rgba(216,169,58,0.10);
  --teal:      #6FB0B8;
  --rose:      #C98B6B;
  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --max: 1160px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:#1A1407; }

/* film grain — kills the "flat web page" feel */
body::after{
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  opacity:.04; mix-blend-mode:overlay;
}

.wrap{ max-width:var(--max); margin:0 auto; padding:0 clamp(22px,4vw,40px); }
.serif{ font-family:var(--serif); }
.gold{ color:var(--gold); }

h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; color:var(--ink); line-height:1.08; letter-spacing:-.01em; }
p{ margin:0; }

/* ---------- reveal ---------- */
.rv{ opacity:0; transform:translateY(24px); transition:opacity .8s cubic-bezier(.22,.6,.2,1), transform .8s cubic-bezier(.22,.6,.2,1); }
.rv.in{ opacity:1; transform:none; }
.rv.d1{ transition-delay:.08s; } .rv.d2{ transition-delay:.16s; } .rv.d3{ transition-delay:.24s; } .rv.d4{ transition-delay:.32s; } .rv.d5{ transition-delay:.40s; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .rv{ opacity:1; transform:none; transition:none; }
  .scroll-cue, .dot{ animation:none !important; }
}

/* ---------- kicker / section heads ---------- */
.kick{
  display:inline-flex; align-items:center; gap:12px;
  font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:18px;
}
.kick::before{ content:""; width:26px; height:1px; background:var(--gold); }
.sec-head{ max-width:700px; margin:0 auto clamp(46px,6vw,64px); text-align:center; }
.sec-head .kick{ justify-content:center; }
.sec-head .kick::after{ content:""; width:26px; height:1px; background:var(--gold); }
.sec-head h2{ font-size:clamp(2rem,4vw,2.9rem); }
.sec-head p{ font-size:1.12rem; color:var(--ink-soft); margin-top:16px; }
.sec-head.left{ margin:0 0 clamp(40px,5vw,56px); text-align:left; }
.sec-head.left .kick{ justify-content:flex-start; }
.sec-head.left .kick::after{ display:none; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--sans); font-weight:600; font-size:.94rem; letter-spacing:.01em;
  border-radius:999px; padding:14px 26px; cursor:pointer;
  border:1px solid transparent; white-space:nowrap; transition:.2s ease;
}
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(4px); }
.btn-gold{ background:linear-gradient(135deg, var(--gold-soft), var(--gold)); color:#1A1407; box-shadow:0 8px 26px rgba(216,169,58,.28); }
.btn-gold:hover{ background:linear-gradient(135deg, #F0D391, var(--gold-soft)); transform:translateY(-2px); box-shadow:0 14px 34px rgba(216,169,58,.36); }
.btn-line{ background:transparent; border-color:var(--line-2); color:var(--ink); }
.btn-line:hover{ border-color:var(--gold); color:var(--gold); }
.btn-sm{ padding:11px 20px; font-size:.86rem; }

/* ============================================================
   HEADER
   ============================================================ */
.site-head{
  position:sticky; top:0; z-index:100;
  background:rgba(14,20,25,.55); backdrop-filter:blur(2px);
  border-bottom:1px solid transparent;
  transition:background .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.site-head.scrolled{ background:rgba(14,20,25,.9); backdrop-filter:blur(14px); border-bottom-color:var(--line); box-shadow:0 8px 30px rgba(0,0,0,.3); }
.nav{ display:flex; align-items:center; gap:24px; height:76px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand .mk{
  width:40px; height:40px; flex:none; position:relative;
}
.brand-name{ font-family:var(--serif); font-size:1.2rem; line-height:1.05; color:var(--ink); }
.brand-name em{ font-style:italic; color:var(--gold); }
.brand-sub{ display:block; font-family:var(--sans); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-dim); margin-top:3px; }
.nav nav{ display:flex; gap:26px; margin-left:auto; font-size:.92rem; color:var(--ink-soft); }
.nav nav a{ transition:color .2s ease; }
.nav nav a:hover{ color:var(--ink); }
.nav .head-phone{ font-size:.92rem; font-weight:600; color:var(--ink); }
.nav .head-phone:hover{ color:var(--gold); }

/* ============================================================
   HERO — full-bleed office photo, dark editorial overlay
   ============================================================ */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.hero-bg{ position:absolute; inset:0; background-size:cover; background-position:center 32%; filter:saturate(.7) contrast(1.03) brightness(.55); transform:scale(1.05); }
.hero::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(900px 520px at 78% -8%, rgba(111,176,184,.22), transparent 60%),
    radial-gradient(820px 560px at 8% 110%, rgba(216,169,58,.16), transparent 58%),
    linear-gradient(100deg, rgba(14,20,25,.96) 0%, rgba(14,20,25,.86) 40%, rgba(14,20,25,.6) 72%, rgba(14,20,25,.7) 100%);
}
.hero .wrap{ position:relative; z-index:2; padding:clamp(64px,11vh,118px) clamp(22px,4vw,40px) clamp(72px,11vh,118px); }
.availbar{
  display:inline-flex; align-items:center; gap:11px;
  border:1px solid var(--line-2); border-radius:999px; padding:8px 18px;
  font-size:.82rem; color:var(--ink-soft); margin-bottom:30px; background:rgba(255,255,255,.03);
}
.availbar .dot{ width:8px; height:8px; border-radius:50%; background:var(--teal); box-shadow:0 0 0 0 rgba(111,176,184,.5); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(111,176,184,.45);} 70%{ box-shadow:0 0 0 7px rgba(111,176,184,0);} 100%{ box-shadow:0 0 0 0 rgba(111,176,184,0);} }
.hero h1{ font-size:clamp(2.7rem,6vw,4.7rem); line-height:1.02; max-width:16ch; text-shadow:0 2px 40px rgba(0,0,0,.5); }
.hero h1 em{ font-style:italic; color:var(--gold-soft); }
.hero .sub{ font-size:clamp(1.08rem,1.7vw,1.3rem); color:rgba(238,242,243,.82); margin:28px 0 36px; max-width:48ch; }
.hero .sub strong{ color:var(--ink); font-weight:600; }
.hero-cta{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.hero-cta .meta{ font-size:.84rem; color:var(--ink-soft); }
.promise-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:50px; }
.promise{ border:1px solid var(--line); border-radius:14px; padding:22px 24px; background:linear-gradient(180deg, rgba(255,255,255,.04), transparent); backdrop-filter:blur(4px); }
.promise b{ font-family:var(--serif); font-size:1.9rem; color:var(--gold-soft); display:block; line-height:1; }
.promise span{ font-size:.85rem; color:var(--ink-soft); display:block; margin-top:9px; }

.scroll-cue{ position:absolute; left:50%; bottom:22px; transform:translateX(-50%); z-index:2; color:rgba(216,169,58,.7); animation:cue 2.6s ease-in-out infinite; }
@keyframes cue{ 0%,100%{ transform:translate(-50%,0); opacity:.8; } 50%{ transform:translate(-50%,8px); opacity:.35; } }

/* ============================================================
   AWARD BAR
   ============================================================ */
.awardbar{ background:var(--bg-2); border-bottom:1px solid var(--line); }
.awardbar .wrap{ display:flex; align-items:center; gap:28px; padding:22px clamp(22px,4vw,40px); flex-wrap:wrap; }
.awardbar img{ height:72px; width:auto; border-radius:8px; }
.awardbar .blk b{ font-family:var(--serif); font-size:1.32rem; display:block; }
.awardbar .blk span{ font-size:.88rem; color:var(--ink-soft); }
.awardbar .stars{ color:var(--gold); letter-spacing:2px; }
.awardbar .vline{ width:1px; height:54px; background:var(--line); }
.awardbar .right{ margin-left:auto; text-align:right; }

/* ============================================================
   SECTION BASE
   ============================================================ */
section.block{ padding:clamp(72px,9vw,110px) 0; }
section.tint{ background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }

/* ---------- recognition / why grid ---------- */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.why{ border:1px solid var(--line); border-radius:16px; padding:32px 30px; background:var(--panel); transition:transform .3s ease, border-color .3s ease; }
.why:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.why .ic{ width:50px; height:50px; border-radius:13px; border:1px solid var(--gold); color:var(--gold); display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.why h3{ font-size:1.3rem; font-weight:500; }
.why p{ font-size:.96rem; color:var(--ink-soft); margin-top:9px; }
.pattern-note{
  margin-top:30px; position:relative; max-width:880px;
  border:1px solid var(--line); border-radius:16px; padding:28px 34px 28px 80px;
  background:linear-gradient(180deg, rgba(216,169,58,.05), transparent);
  font-family:var(--serif); font-size:1.2rem; line-height:1.5; color:var(--ink);
}
.pattern-note::before{ content:"\201C"; position:absolute; left:26px; top:34px; font-family:var(--serif); font-size:4.4rem; line-height:0; color:var(--gold); }

/* ---------- "why missed" numbered ---------- */
.missed{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:m; }
.missed .col{ position:relative; padding-top:52px; }
.missed .col::before{ counter-increment:m; content:counter(m,decimal-leading-zero); position:absolute; top:-12px; left:-2px; font-family:var(--serif); font-size:4.4rem; line-height:1; color:transparent; -webkit-text-stroke:1px rgba(216,169,58,.5); }
.missed h3{ font-size:1.32rem; font-weight:500; margin-bottom:.4em; }
.missed p{ font-size:.96rem; color:var(--ink-soft); }

/* ---------- evaluation feature (photo + panel) ---------- */
.feature{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.feature .photo{ position:relative; border-radius:18px; overflow:hidden; aspect-ratio:4/3.2; border:1px solid var(--line-2); box-shadow:0 30px 70px rgba(0,0,0,.45); }
.feature .photo img{ width:100%; height:100%; object-fit:cover; filter:saturate(.82) brightness(.92); }
.feature .photo::after{ content:""; position:absolute; inset:12px; border-radius:10px; border:1px solid rgba(216,169,58,.4); pointer-events:none; mix-blend-mode:screen; }
.eval-list{ list-style:none; margin:24px 0 0; display:grid; gap:14px; }
.eval-list li{ display:flex; gap:13px; font-size:.97rem; color:var(--ink-soft); }
.eval-list li b{ color:var(--ink); font-weight:600; }
.eval-list svg{ flex:none; margin-top:4px; color:var(--gold); }

/* ---------- two-week timeline ---------- */
.tw-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,5vw,60px); align-items:center; }
.tw-list{ list-style:none; }
.tw-list li{ display:grid; grid-template-columns:auto 1fr; gap:22px; padding:22px 0; border-top:1px solid var(--line); }
.tw-list li:first-child{ border-top:none; }
.tw-list .day{ font-family:var(--serif); font-size:.95rem; color:var(--gold); white-space:nowrap; padding-top:2px; }
.tw-list h4{ font-size:1.08rem; font-weight:600; font-family:var(--sans); }
.tw-list p{ font-size:.92rem; color:var(--ink-soft); margin-top:3px; }
.tw-card{ border:1px solid var(--line-2); border-radius:22px; padding:44px 40px; background:linear-gradient(180deg, rgba(216,169,58,.06), transparent); text-align:center; }
.tw-card .big{ font-family:var(--serif); font-size:clamp(4rem,7vw,5.4rem); line-height:.9; color:var(--gold-soft); }
.tw-card .big small{ font-size:1.5rem; }
.tw-card .cap{ font-size:1.02rem; color:var(--ink-soft); margin-top:12px; }
.tw-card hr{ border:none; border-top:1px solid var(--line); margin:26px 0; }
.tw-card .fine{ font-size:.86rem; color:var(--ink-soft); }

/* ---------- states ---------- */
.map-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,60px); align-items:center; }
.states{ display:flex; flex-wrap:wrap; gap:7px; margin-top:22px; }
.states span{ font-size:.78rem; color:var(--ink-soft); border:1px solid var(--line); border-radius:7px; padding:5px 10px; }
.states span.hot{ color:var(--gold); border-color:var(--line-2); }
.map-photo{ position:relative; border-radius:18px; overflow:hidden; aspect-ratio:16/12; border:1px solid var(--line-2); box-shadow:0 30px 70px rgba(0,0,0,.45); }
.map-photo img{ width:100%; height:100%; object-fit:cover; filter:saturate(.8) brightness(.9); }
.map-photo .cap{ position:absolute; left:0; right:0; bottom:0; padding:24px; background:linear-gradient(to top, rgba(14,20,25,.92), transparent); font-size:.88rem; color:var(--ink-soft); }

/* ---------- pricing ---------- */
.price-wrap{ max-width:580px; margin:0 auto; }
.price-card{ position:relative; overflow:hidden; border:1px solid var(--gold); border-radius:24px; padding:46px 44px; background:linear-gradient(180deg, rgba(216,169,58,.07), transparent); text-align:center; }
.price-card::before{ content:""; position:absolute; top:-60%; left:-30%; width:80%; height:220%; background:linear-gradient(100deg,transparent 30%,rgba(216,169,58,.08) 50%,transparent 70%); transform:rotate(8deg); pointer-events:none; }
.price-card .tag{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-weight:700; }
.price-card h3{ font-size:1.85rem; font-weight:500; margin:10px 0 8px; }
.price-card .amt{ font-family:var(--serif); font-size:clamp(2.4rem,4vw,3rem); color:var(--ink); }
.price-card .amt small{ display:block; font-family:var(--sans); font-size:.82rem; color:var(--ink-soft); margin-top:8px; letter-spacing:.01em; }
.price-card ul{ list-style:none; text-align:left; max-width:400px; margin:28px auto 0; display:grid; gap:13px; }
.price-card li{ display:flex; gap:12px; font-size:.96rem; }
.price-card li .ck{ color:var(--gold); flex:none; }
.price-card .btn-gold{ margin-top:32px; width:100%; }
.price-note{ text-align:center; font-size:.84rem; color:var(--ink-soft); margin-top:18px; }

/* ---------- testimonials ---------- */
.t-feature{ max-width:900px; margin:0 auto clamp(40px,5vw,54px); text-align:center; position:relative; }
.t-feature::before{ content:"\201C"; display:block; height:.36em; font-family:var(--serif); font-size:clamp(6rem,12vw,9rem); line-height:.9; color:rgba(216,169,58,.22); }
.t-feature .stars{ color:var(--gold); letter-spacing:7px; font-size:1.1rem; }
.t-feature blockquote{ font-family:var(--serif); font-size:clamp(1.4rem,2.6vw,2rem); font-style:italic; line-height:1.45; margin:14px 0 20px; color:var(--ink); }
.t-feature blockquote b{ color:var(--gold-soft); font-weight:500; font-style:normal; }
.t-feature .who{ font-size:.78rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim); }
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rev{ border:1px solid var(--line); border-radius:16px; padding:30px; background:var(--panel); }
.rev .stars{ color:var(--gold); letter-spacing:2px; }
.rev p{ font-family:var(--serif); font-size:1.12rem; line-height:1.45; margin:14px 0 18px; color:var(--ink); }
.rev .who{ font-size:.86rem; color:var(--ink-soft); display:flex; align-items:center; gap:9px; }
.rev .who .g{ width:22px; height:22px; border-radius:50%; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; font-size:.7rem; color:var(--gold); flex:none; }
.note-fine{ text-align:center; font-size:.74rem; color:var(--ink-dim); margin-top:26px; font-family:ui-monospace,Menlo,monospace; letter-spacing:.04em; }

/* ---------- credibility ---------- */
.cred{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,6vw,80px); align-items:center; }
.arch{ position:relative; border-radius:280px 280px 20px 20px; overflow:hidden; aspect-ratio:4/5; max-width:400px; background:linear-gradient(165deg, var(--panel-2), var(--bg)); border:1px solid var(--line-2); box-shadow:0 30px 70px rgba(0,0,0,.5); display:grid; place-items:center; }
.arch::after{ content:""; position:absolute; inset:13px; border-radius:268px 268px 11px 11px; border:1px solid rgba(216,169,58,.4); pointer-events:none; }
.arch img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.arch .ph{ text-align:center; padding:28px; z-index:1; }
.arch .ph .mono{ width:108px; height:108px; border-radius:50%; margin:0 auto 16px; border:1px solid rgba(216,169,58,.5); background:rgba(216,169,58,.08); color:var(--gold-soft); font-family:var(--serif); font-size:2.3rem; display:grid; place-items:center; }
.arch .ph b{ display:block; font-family:var(--serif); font-size:1.1rem; color:var(--ink); }
.arch .ph small{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); }
.cred-list{ list-style:none; margin:26px 0 0; display:grid; gap:16px; }
.cred-list li{ display:flex; gap:15px; align-items:flex-start; font-size:.98rem; }
.cred-list .tick{ flex:none; width:30px; height:30px; margin-top:2px; border-radius:50%; background:var(--gold-ghost); border:1px solid rgba(216,169,58,.3); color:var(--gold); display:grid; place-items:center; }
.cred-list b{ color:var(--ink); }
.award-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.award-chips span{ font-size:.76rem; font-weight:600; background:var(--panel); border:1px solid var(--line-2); border-radius:999px; padding:9px 17px; color:var(--ink-soft); }
.award-chips b{ color:var(--gold); }

/* ---------- outcomes ---------- */
.outcome-cols{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.outcome{ border:1px solid var(--line); border-radius:16px; padding:34px 32px; background:var(--panel); }
.outcome.alt{ background:linear-gradient(180deg, rgba(216,169,58,.06), transparent); border-color:rgba(216,169,58,.4); }
.outcome h3{ font-size:1.3rem; font-weight:500; display:flex; align-items:center; gap:12px; }
.outcome h3::before{ content:""; width:30px; height:1px; background:var(--gold); }
.outcome ul{ list-style:none; margin:18px 0 0; display:grid; gap:12px; }
.outcome li{ display:flex; gap:12px; font-size:.95rem; color:var(--ink-soft); }
.outcome li svg{ flex:none; margin-top:5px; color:var(--gold); }

/* ---------- FAQ ---------- */
.faq{ max-width:780px; margin:0 auto; }
.faq details{ border-top:1px solid var(--line); padding:24px 0; }
.faq details:last-child{ border-bottom:1px solid var(--line); }
.faq summary{ font-family:var(--serif); font-size:1.3rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:22px; align-items:center; color:var(--ink); transition:color .2s ease; }
.faq summary:hover{ color:var(--gold); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--gold); font-size:1.7rem; line-height:1; flex:none; transition:transform .25s ease; }
.faq details[open] summary::after{ content:"\2013"; }
.faq p{ font-size:.98rem; color:var(--ink-soft); margin-top:14px; max-width:66ch; }

/* ---------- closing ---------- */
.closing{ position:relative; overflow:hidden; text-align:center; border-top:1px solid var(--line); }
.closing-bg{ position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(.65) brightness(.4); transform:scale(1.05); }
.closing::before{ content:""; position:absolute; inset:0; background:radial-gradient(700px 420px at 50% 120%, rgba(216,169,58,.2), transparent 60%), linear-gradient(rgba(14,20,25,.92),rgba(14,20,25,.92)); }
.closing .wrap{ position:relative; z-index:2; padding:clamp(86px,12vw,128px) clamp(22px,4vw,40px); }
.closing h2{ font-size:clamp(2.2rem,5vw,3.6rem); line-height:1.04; max-width:18ch; margin:0 auto 16px; }
.closing h2 em{ font-style:italic; color:var(--gold-soft); }
.closing p{ font-size:1.15rem; color:var(--ink-soft); max-width:40ch; margin:0 auto 34px; }
.closing .row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--line); padding:50px 0 38px; background:var(--bg); }
.foot{ display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:28px; padding-bottom:30px; border-bottom:1px solid var(--line); }
.foot .fbrand{ font-family:var(--serif); font-size:1.15rem; }
.foot .fbrand em{ font-style:italic; color:var(--gold); }
.foot p{ font-size:.88rem; color:var(--ink-soft); max-width:34em; margin-top:12px; }
.foot .flinks{ display:flex; gap:28px; font-size:.9rem; color:var(--ink-soft); flex-wrap:wrap; }
.foot .flinks a:hover{ color:var(--gold); }
.disc{ padding-top:22px; font-size:.78rem; color:var(--ink-dim); line-height:1.7; }
.disc a{ color:var(--ink-soft); }

/* ---------- responsive ---------- */
@media (max-width: 980px){
  .promise-row{ grid-template-columns:1fr 1fr; }
  .why-grid, .missed, .rev-grid{ grid-template-columns:1fr; }
  .feature, .tw-grid, .map-grid, .cred, .outcome-cols{ grid-template-columns:1fr; }
  .arch{ margin:0 auto; }
  .nav nav{ display:none; }
  .awardbar .right{ margin-left:0; text-align:left; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .promise-row{ grid-template-columns:1fr; }
  .nav .head-phone{ display:none; }
  .hero-cta .btn{ width:100%; }
  .awardbar img{ height:56px; }
}
