/* ===================================================================
   SeniorNavigator Services — Design System
   Premium, senior-first, WCAG-AA. Teal + Gold + Ivory.
   =================================================================== */

/* ---------- Tokens ---------- */
:root{
  --teal-900:#08323D; --teal-800:#0C4A5A; --teal-700:#0F586C; --teal-600:#176A80;
  --teal-500:#1E7E96; --teal-400:#3E97AC; --teal-200:#A9CFD9; --teal-100:#DCEBEF; --teal-50:#EEF6F8;
  --gold-700:#9A6F2C; --gold-600:#B8893A; --gold-500:#C9A24B; --gold-400:#D9B569;
  --gold-300:#E4C77F; --gold-200:#EAD8A0; --gold-100:#F5ECD3;
  --ivory:#FBF8F2; --cream:#F4EEE1; --sand:#EFE7D6; --paper:#FFFFFF;
  --ink:#1F2E34; --ink-soft:#33454C; --muted:#5E7077; --faint:#8B989D;
  --line:#E8E1D2; --line-soft:#F0EADD;
  --ok:#2E7D5B; --ok-bg:#E7F3EC;

  --font-head:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Nunito Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  --wrap:1180px; --wrap-narrow:880px;
  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  --shadow-sm:0 2px 8px rgba(8,50,61,.06);
  --shadow:0 14px 40px rgba(8,50,61,.10);
  --shadow-lg:0 26px 70px rgba(8,50,61,.16);
  --ring:0 0 0 4px rgba(201,162,75,.45);
  --t:.28s cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  margin:0;background:var(--ivory);color:var(--ink-soft);
  font-family:var(--font-body);font-size:18px;line-height:1.72;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block;height:auto}
a{color:var(--teal-700);text-decoration-color:rgba(23,106,128,.35);text-underline-offset:3px}
a:hover{color:var(--teal-800)}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--teal-900);font-weight:600;line-height:1.12;margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5.2vw,3.7rem);font-weight:600}
h2{font-size:clamp(1.85rem,3.6vw,2.6rem)}
h3{font-size:1.4rem}
h4{font-size:1.13rem;font-family:var(--font-body);font-weight:800;color:var(--teal-800)}
p{margin:0 0 1.1em}
strong{font-weight:800;color:var(--ink)}
:focus-visible{outline:3px solid var(--gold-500);outline-offset:3px;border-radius:4px}
::selection{background:var(--gold-200);color:var(--teal-900)}
hr{border:0;border-top:1px solid var(--line);margin:2.5rem 0}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.narrow{max-width:var(--wrap-narrow)}
.section{padding-block:clamp(3.5rem,8vw,6rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,3.5rem)}
.bg-ivory{background:var(--ivory)} .bg-paper{background:var(--paper)} .bg-cream{background:var(--cream)}
.bg-teal{background:var(--teal-900);color:#E7EEF0}
.bg-teal h1,.bg-teal h2,.bg-teal h3{color:#fff}
.bg-teal a{color:var(--gold-300)}
.bg-gradient{background:linear-gradient(160deg,var(--teal-900) 0%,var(--teal-800) 48%,var(--teal-700) 100%);color:#E7EEF0}
.center{text-align:center} .mx-auto{margin-inline:auto}
.grid{display:grid;gap:clamp(1.1rem,2.4vw,1.7rem)}
.g-2{grid-template-columns:repeat(2,1fr)} .g-3{grid-template-columns:repeat(3,1fr)} .g-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* ---------- Eyebrow / kicker ---------- */
.kicker{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-body);font-weight:800;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-700)}
.kicker::before{content:"";width:26px;height:2px;background:var(--gold-500);border-radius:2px}
.bg-teal .kicker,.bg-gradient .kicker{color:var(--gold-300)}
.bg-teal .kicker::before,.bg-gradient .kicker::before{background:var(--gold-400)}
.lead{font-size:1.22rem;color:var(--muted);line-height:1.62}
.bg-teal .lead,.bg-gradient .lead{color:#BFD3D8}
.eyebrow-c{display:block;max-width:46rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-body);font-weight:800;font-size:1rem;line-height:1;
  padding:1.05em 1.7em;border-radius:var(--r-pill);border:2px solid transparent;cursor:pointer;
  text-decoration:none;transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);min-height:52px}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--gold-500);color:var(--teal-900);box-shadow:0 10px 24px rgba(201,162,75,.35)}
.btn--primary:hover{background:var(--gold-400);color:var(--teal-900);box-shadow:0 14px 30px rgba(201,162,75,.45)}
.btn--teal{background:var(--teal-800);color:#fff}
.btn--teal:hover{background:var(--teal-700);color:#fff}
.btn--ghost{background:transparent;color:var(--teal-800);border-color:var(--teal-200)}
.btn--ghost:hover{background:var(--teal-50);color:var(--teal-900);border-color:var(--teal-400)}
.btn--light{background:#fff;color:var(--teal-900)}
.btn--light:hover{background:var(--gold-100);color:var(--teal-900)}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn--outline-light:hover{background:rgba(255,255,255,.1);color:#fff}
.btn--lg{font-size:1.08rem;padding:1.15em 2em;min-height:58px}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.btn-row--center{justify-content:center}

/* ---------- Header ---------- */
.topbar{background:var(--teal-900);color:#CFE0E4;font-size:.86rem;font-weight:600}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:44px;padding-block:6px}
.topbar a{color:#E7EEF0;text-decoration:none}
.topbar .tb-langs{color:var(--gold-300);letter-spacing:.02em}
.topbar .tb-item{display:inline-flex;align-items:center;gap:.45em}
@media (max-width:720px){.topbar .tb-hide{display:none}.topbar .wrap{justify-content:center}}

.site-header{position:sticky;top:0;z-index:60;background:rgba(251,248,242,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);transition:box-shadow var(--t),background var(--t)}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(251,248,242,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;min-height:78px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;flex:none}
.brand .mark{width:46px;height:46px}
.brand .bt-name{font-family:var(--font-head);font-weight:600;font-size:1.32rem;color:var(--teal-800);line-height:1}
.brand .bt-sub{font-weight:800;font-size:.58rem;letter-spacing:.34em;color:var(--gold-700);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.nav-links a{display:block;text-decoration:none;color:var(--ink-soft);font-weight:700;font-size:.97rem;
  padding:.6em .8em;border-radius:var(--r-sm);transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--teal-900);background:var(--teal-50)}
.nav-links a[aria-current="page"]{color:var(--teal-900)}
.nav-links a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--gold-500);border-radius:2px;margin-top:3px}
.nav-cta{display:flex;align-items:center;gap:.7rem;flex:none}
.nav-phone{display:inline-flex;align-items:center;gap:.5em;font-weight:800;color:var(--teal-800);text-decoration:none;white-space:nowrap}
.nav-phone:hover{color:var(--gold-700)}
.nav-toggle{display:none;background:var(--teal-800);border:0;color:#fff;width:50px;height:50px;border-radius:var(--r-sm);cursor:pointer;align-items:center;justify-content:center}
.nav-toggle svg{width:26px;height:26px}
@media (max-width:1040px){
  .nav-links,.nav-cta .btn,.nav-phone span{display:none}
  .nav-toggle{display:inline-flex}
  .nav-cta .nav-phone{display:inline-flex}
}
/* mobile drawer */
.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(360px,86vw);background:var(--paper);z-index:80;
  transform:translateX(100%);transition:transform var(--t);box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;padding:1.4rem;overflow-y:auto}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu .mm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.mobile-menu .mm-close{background:var(--teal-50);border:0;width:48px;height:48px;border-radius:var(--r-sm);cursor:pointer;color:var(--teal-800)}
.mobile-menu a{text-decoration:none;color:var(--ink);font-weight:700;font-size:1.1rem;padding:.85em .6em;border-bottom:1px solid var(--line-soft)}
.mobile-menu .mm-cta{margin-top:1.2rem;display:grid;gap:.7rem}
.scrim{position:fixed;inset:0;background:rgba(8,50,61,.5);z-index:70;opacity:0;visibility:hidden;transition:opacity var(--t)}
.scrim.show{opacity:1;visibility:visible}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(165deg,var(--teal-900) 0%,var(--teal-800) 52%,var(--teal-700) 100%);color:#E9F0F1}
.hero::after{content:"";position:absolute;right:-160px;top:-120px;width:620px;height:620px;
  background:radial-gradient(circle,rgba(201,162,75,.16),transparent 62%);pointer-events:none}
.hero-compass{position:absolute;right:-80px;bottom:-120px;width:460px;opacity:.10;pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,4vw,3.5rem);align-items:center;
  padding-block:clamp(3.2rem,7vw,5.5rem)}
.hero h1{color:#fff;margin-bottom:.35em}
.hero h1 .accent{color:var(--gold-300);font-style:italic}
.hero .lead{color:#C7D9DD;max-width:34rem}
.hero-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.chip{display:inline-flex;align-items:center;gap:.5em;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  color:#E9F0F1;font-weight:700;font-size:.86rem;padding:.5em .9em;border-radius:var(--r-pill)}
.chip svg{width:17px;height:17px;color:var(--gold-300)}
.hero-cta{margin-top:1.9rem}
@media (max-width:900px){.hero .wrap{grid-template-columns:1fr}.hero-card{order:-1;max-width:420px}}

/* hero side card (sample family update) */
.hero-card{background:rgba(255,255,255,.97);color:var(--ink-soft);border-radius:var(--r-xl);padding:1.5rem;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.5)}
.hero-card .hc-top{display:flex;align-items:center;gap:.7rem;border-bottom:1px solid var(--line);padding-bottom:.9rem;margin-bottom:.9rem}
.hero-card .hc-av{width:44px;height:44px;border-radius:50%;background:var(--teal-100);color:var(--teal-800);display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.hero-card .hc-title{font-weight:800;color:var(--teal-900);font-size:1rem}
.hero-card .hc-sub{font-size:.82rem;color:var(--muted)}
.hero-card ul{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.hero-card li{display:flex;gap:.7rem;font-size:.95rem;line-height:1.4}
.hero-card li svg{width:20px;height:20px;color:var(--ok);flex:none;margin-top:2px}
.hero-card .hc-foot{margin-top:1rem;font-size:.82rem;color:var(--faint);display:flex;align-items:center;gap:.4em}

/* ---------- Cards / features ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem;
  box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t);height:100%}
.card--hover:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-200)}
.card .ic{width:56px;height:56px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;
  background:var(--teal-50);color:var(--teal-700);margin-bottom:1.1rem;border:1px solid var(--teal-100)}
.card .ic svg{width:28px;height:28px}
.card h3{margin-bottom:.4em}
.card p:last-child{margin-bottom:0}
.card .stat-note{margin-top:1rem;font-size:.86rem;color:var(--gold-700);font-weight:800;display:flex;align-items:center;gap:.45em}
.card-link{display:inline-flex;align-items:center;gap:.4em;font-weight:800;text-decoration:none;color:var(--teal-700);margin-top:1rem}
.card-link:hover{gap:.65em;color:var(--teal-900)}
.card--feature .ic{background:var(--gold-100);color:var(--gold-700);border-color:var(--gold-200)}

/* numbered steps */
.steps{counter-reset:step;display:grid;gap:1.4rem}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start}
.step .num{counter-increment:step;width:56px;height:56px;border-radius:50%;flex:none;
  background:var(--teal-800);color:#fff;font-family:var(--font-head);font-weight:600;font-size:1.5rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(12,74,90,.25)}
.step .num::before{content:counter(step)}
.step h3{margin-bottom:.25em}

/* stats band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat .num{font-family:var(--font-head);font-weight:600;font-size:clamp(2.2rem,5vw,3rem);color:var(--gold-400);line-height:1}
.stat .lab{margin-top:.4rem;font-size:.95rem;color:#BFD3D8}

/* ---------- Price cards ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media (max-width:900px){.price-grid{grid-template-columns:1fr}}
.price{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.9rem;position:relative;height:100%;box-shadow:var(--shadow-sm)}
.price--featured{border:2px solid var(--gold-500);box-shadow:var(--shadow)}
.price .tag{position:absolute;top:-14px;left:1.9rem;background:var(--gold-500);color:var(--teal-900);font-weight:800;font-size:.78rem;letter-spacing:.04em;padding:.4em .9em;border-radius:var(--r-pill)}
.price h3{margin-bottom:.1em}
.price .amt{font-family:var(--font-head);font-weight:600;color:var(--teal-900);font-size:2.5rem;line-height:1;margin:.3em 0 .1em}
.price .amt span{font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--muted)}
.price .per{color:var(--muted);font-size:.95rem;margin-bottom:1.1rem}
.price ul{list-style:none;margin:0 0 1.5rem;padding:0;display:grid;gap:.7rem}
.price li{display:flex;gap:.6rem;font-size:.98rem}
.price li svg{width:20px;height:20px;color:var(--ok);flex:none;margin-top:3px}

/* ---------- Testimonials ---------- */
.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow-sm);height:100%;display:flex;flex-direction:column}
.quote .stars{color:var(--gold-500);letter-spacing:2px;margin-bottom:.8rem;font-size:1.05rem}
.quote blockquote{margin:0 0 1.2rem;font-size:1.06rem;line-height:1.6;color:var(--ink-soft)}
.quote .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--teal-100);color:var(--teal-800);display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.quote .who b{display:block;color:var(--teal-900)}
.quote .who span{font-size:.86rem;color:var(--muted)}

/* ---------- List with checks ---------- */
.checks{list-style:none;margin:0;padding:0;display:grid;gap:.85rem}
.checks li{display:flex;gap:.7rem;align-items:flex-start}
.checks li svg{width:24px;height:24px;color:var(--gold-600);flex:none;margin-top:2px}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split--reverse .split-media{order:2}
@media (max-width:880px){.split{grid-template-columns:1fr}.split--reverse .split-media{order:0}}
.media-panel{position:relative;border-radius:var(--r-xl);overflow:hidden;background:linear-gradient(150deg,var(--teal-700),var(--teal-900));min-height:340px;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.08)}
.media-panel .ph-note{position:absolute;bottom:14px;left:14px;font-size:.72rem;color:rgba(255,255,255,.6);background:rgba(0,0,0,.25);padding:.3em .7em;border-radius:6px}
.media-panel svg.illus{width:72%;opacity:.95}

/* ---------- Banner / CTA ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);background:linear-gradient(150deg,var(--teal-900),var(--teal-700));color:#fff;padding:clamp(2.4rem,5vw,3.6rem);text-align:center;box-shadow:var(--shadow)}
.cta-band::after{content:"";position:absolute;left:-90px;bottom:-90px;width:320px;height:320px;background:radial-gradient(circle,rgba(201,162,75,.2),transparent 65%)}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:#C7D9DD;position:relative;max-width:40rem;margin-inline:auto}
.cta-band .btn-row{position:relative}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-900);color:#B7CCD1;font-size:.95rem;padding-block:3.5rem 2rem}
.site-footer a{color:#CFE0E4;text-decoration:none}
.site-footer a:hover{color:var(--gold-300)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .mark{width:50px;height:50px;margin-bottom:.9rem}
.foot-brand .fb-name{font-family:var(--font-head);font-size:1.3rem;color:#fff;font-weight:600}
.foot-brand p{color:#9FB6BC;font-size:.92rem;max-width:24rem}
.foot-col h4{color:#fff;font-family:var(--font-body);font-weight:800;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.foot-contact li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.7rem;color:#B7CCD1}
.foot-contact svg{width:19px;height:19px;color:var(--gold-400);flex:none;margin-top:3px}
.foot-social{display:flex;gap:.6rem;margin-top:1rem}
.foot-social a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.foot-social a:hover{background:var(--gold-500)}
.foot-social svg{width:20px;height:20px;color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.5rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-size:.84rem;color:#8AA3AA}
.foot-bottom a{color:#8AA3AA}.foot-bottom .fb-links{display:flex;gap:1.2rem;flex-wrap:wrap}
.foot-disclaimer{font-size:.82rem;color:#7C969D;margin-top:.8rem;max-width:60rem}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:600px){.form .row{grid-template-columns:1fr}}
.field{display:grid;gap:.4rem}
.field label{font-weight:800;color:var(--teal-900);font-size:.95rem}
.field .req{color:var(--gold-700)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--paper);color:var(--ink);width:100%;transition:border-color var(--t),box-shadow var(--t);min-height:52px}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-500);box-shadow:var(--ring)}
.field .hint{font-size:.84rem;color:var(--muted)}
.form-note{font-size:.86rem;color:var(--muted)}

/* contact info cards */
.info-card{display:flex;gap:1rem;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem;box-shadow:var(--shadow-sm)}
.info-card .ic{width:48px;height:48px;border-radius:var(--r-sm);background:var(--teal-50);color:var(--teal-700);display:flex;align-items:center;justify-content:center;flex:none;border:1px solid var(--teal-100)}
.info-card .ic svg{width:24px;height:24px}
.info-card b{display:block;color:var(--teal-900);font-size:1.02rem}
.info-card a{text-decoration:none;font-weight:700}

/* ---------- Accordion (FAQ) ---------- */
.accordion{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);box-shadow:var(--shadow-sm)}
.acc-item+.acc-item{border-top:1px solid var(--line)}
.acc-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:1.25em 1.4em;font-family:var(--font-body);
  font-weight:800;font-size:1.08rem;color:var(--teal-900);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.acc-q:hover{background:var(--teal-50)}
.acc-q .ico{flex:none;width:28px;height:28px;border-radius:50%;background:var(--teal-50);color:var(--teal-700);display:flex;align-items:center;justify-content:center;transition:transform var(--t),background var(--t)}
.acc-q[aria-expanded="true"] .ico{transform:rotate(45deg);background:var(--gold-500);color:var(--teal-900)}
.acc-a{padding:0 1.4em;max-height:0;overflow:hidden;transition:max-height var(--t),padding var(--t)}
.acc-a.open{padding:0 1.4em 1.3em}
.acc-a p{margin:0;color:var(--ink-soft)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(160deg,var(--teal-900),var(--teal-800));color:#E7EEF0;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-120px;top:-120px;width:440px;height:440px;background:radial-gradient(circle,rgba(201,162,75,.14),transparent 64%)}
.page-hero .wrap{position:relative;z-index:2;padding-block:clamp(2.6rem,6vw,4.2rem);max-width:var(--wrap)}
.page-hero h1{color:#fff;margin-bottom:.3em}
.page-hero p{color:#C7D9DD;max-width:42rem;font-size:1.15rem;margin:0}
.crumbs{display:flex;gap:.5em;align-items:center;font-size:.85rem;color:#9FB6BC;margin-bottom:1.1rem;flex-wrap:wrap}
.crumbs a{color:#C7D9DD;text-decoration:none}.crumbs a:hover{color:var(--gold-300)}
.crumbs svg{width:14px;height:14px;opacity:.6}

/* ---------- Misc ---------- */
.badge{display:inline-flex;align-items:center;gap:.45em;background:var(--gold-100);color:var(--gold-700);font-weight:800;font-size:.82rem;padding:.4em .9em;border-radius:var(--r-pill);border:1px solid var(--gold-200)}
.badge svg{width:16px;height:16px}
.pill-ok{display:inline-flex;align-items:center;gap:.45em;background:var(--ok-bg);color:var(--ok);font-weight:800;font-size:.84rem;padding:.4em .9em;border-radius:var(--r-pill)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold-500);color:var(--teal-900);padding:.8em 1.2em;font-weight:800;z-index:200;border-radius:0 0 var(--r-sm) 0}
.skip-link:focus{left:0}
.langnote{display:inline-flex;align-items:center;gap:.5em;color:var(--gold-700);font-weight:800;font-size:.95rem}
.langnote svg{width:20px;height:20px}
.prose p{max-width:42rem}
.prose h2{margin-top:2rem}.prose h3{margin-top:1.5rem}
.prose ul{padding-left:1.2rem}.prose li{margin-bottom:.5rem}
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r)}
table.tbl{width:100%;border-collapse:collapse;background:var(--paper);min-width:560px}
table.tbl th,table.tbl td{text-align:left;padding:.9em 1.1em;border-bottom:1px solid var(--line);font-size:.96rem}
table.tbl th{background:var(--teal-50);color:var(--teal-900);font-weight:800;font-family:var(--font-body)}
/* Reveal-on-scroll is a pure enhancement: content is ALWAYS visible without JS. */
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important}}

/* icon sizing safety nets (CSS wins over the width/height attributes on bare icons) */
.btn svg{width:1.15em;height:1.15em;flex:none}
.topbar svg{width:16px;height:16px;flex:none}
.nav-phone svg{width:19px;height:19px;flex:none}
.hero-card .hc-foot svg{width:19px;height:19px;flex:none}
.stat-note svg,.card-link svg{width:18px;height:18px;flex:none}
.crumbs svg{flex:none}
.langnote svg{flex:none}
