/* ============================================================
   Gender Affirmation Thailand, facilitator site
   Design system. Palette: deep petrol teal (trust) + lavender
   (a quiet nod to community dignity) + warm honey accent, on a
   warm paper ground. Signature: a continuous "journey line" that
   threads the coordinated steps together, the product is the
   coordination, so the line is the brand.
   ============================================================ */

/* ---- Fonts (self-hosted, no third-party calls) ---- */
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces.woff2") format("woff2");
  font-weight:300 900;font-display:swap;font-style:normal;}
@font-face{font-family:"Mulish";src:url("../fonts/mulish-400.woff2") format("woff2");font-weight:400;font-display:swap;}
@font-face{font-family:"Mulish";src:url("../fonts/mulish-500.woff2") format("woff2");font-weight:500;font-display:swap;}
@font-face{font-family:"Mulish";src:url("../fonts/mulish-600.woff2") format("woff2");font-weight:600;font-display:swap;}
@font-face{font-family:"Mulish";src:url("../fonts/mulish-700.woff2") format("woff2");font-weight:700;font-display:swap;}
@font-face{font-family:"Spline Mono";src:url("../fonts/spline-mono.woff2") format("woff2");font-weight:300 700;font-display:swap;}

:root{
  --ink:#16302B; --ink-soft:#46615A; --ink-mute:#6E847D;
  --teal:#0F5E54; --teal-700:#0C4C44; --teal-deep:#093B34;
  --lav:#7C6CAE; --lav-deep:#372C57;
  --gold:#C2873A; --gold-soft:#E7C98E;
  --paper:#FAF7F2; --paper-2:#F3EEE5; --card:#FFFFFF;
  --mist:#E6F0EC; --haze:#EFEBF6;
  --line:rgba(22,48,43,.13); --line-soft:rgba(22,48,43,.08);
  --ok:#1f7a3a; --wa:#1FA855;
  --shadow:0 1px 2px rgba(9,59,52,.05), 0 14px 40px -22px rgba(9,59,52,.35);
  --shadow-sm:0 1px 2px rgba(9,59,52,.05), 0 6px 18px -12px rgba(9,59,52,.3);
  --r:16px; --r-lg:26px; --r-sm:10px;
  --wrap:1140px; --gut:clamp(18px,4vw,40px);
  --font-d:"Fraunces",Georgia,serif;
  --font-b:"Mulish",system-ui,sans-serif;
  --font-m:"Spline Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-b);
  font-size:clamp(16px,1.05vw,17.5px);line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
h1,h2,h3,h4{font-family:var(--font-d);font-weight:560;line-height:1.08;
  letter-spacing:-.005em;color:var(--ink);margin:0 0 .5em;
  padding-inline-start:.06em}
/* small left slack so the display serif's first-letter overhang is never clipped by overflow:hidden ancestors */
h1,h2,h3{padding-inline-start:.07em;margin-inline-start:-.07em}
h1{font-size:clamp(2.2rem,5.2vw,4rem);font-weight:540}
h2{font-size:clamp(1.7rem,3.4vw,2.7rem)}
h3{font-size:clamp(1.2rem,1.9vw,1.5rem);font-weight:600}
h4{font-size:1.05rem;font-weight:650}
p{margin:0 0 1rem}
strong{font-weight:700;color:var(--ink)}
hr{border:0;border-top:1px solid var(--line);margin:2.4rem 0}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.wrap-tight{max-width:880px;margin-inline:auto;padding-inline:var(--gut)}
.section{padding:clamp(48px,7vw,92px) 0}
.section--tint{background:var(--mist)}
.section--haze{background:var(--haze)}
.section--paper2{background:var(--paper-2)}
.section--deep{background:var(--teal-deep);color:#EAF3F0}
.section--deep h1,.section--deep h2,.section--deep h3{color:#fff}
.center{text-align:center}
.lead{font-size:clamp(1.12rem,1.7vw,1.32rem);line-height:1.55;color:var(--ink-soft);font-weight:440}

/* ---- eyebrow / labels ---- */
.eyebrow{font-family:var(--font-m);font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--teal);font-weight:500;display:inline-flex;
  align-items:center;gap:.55em;margin-bottom:1rem}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--gold);display:inline-block}
.section--deep .eyebrow{color:var(--gold-soft)}
.section--deep .eyebrow::before{background:var(--gold-soft)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-b);
  font-weight:700;font-size:.98rem;border-radius:999px;padding:.82em 1.5em;
  border:1.5px solid transparent;cursor:pointer;transition:.18s ease;text-decoration:none;line-height:1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-700);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-light{background:#fff;color:var(--teal);}
.btn-light:hover{box-shadow:var(--shadow-sm)}
.section--deep .btn-ghost,.phero .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.section--deep .btn-ghost:hover,.phero .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{filter:brightness(.95)}
/* ghost buttons on dark sections must stay legible */
.section--deep .btn-ghost,.phero .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.section--deep .btn-ghost:hover,.phero .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.btn svg{width:1.05em;height:1.05em;fill:currentColor}
.btn-row{display:flex;gap:.75rem;flex-wrap:wrap}

/* ---- header ---- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(250,247,242,.86);
  backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line-soft)}
.head-in{display:flex;align-items:center;gap:1.2rem;height:68px;
  max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-d);
  font-weight:600;font-size:1.06rem;color:var(--ink);letter-spacing:-.01em;flex-shrink:0}
.brand:hover{text-decoration:none}
.brand .mark{flex-shrink:0}
.brand b{font-weight:600}
.brand span{color:var(--teal)}
.nav{display:flex;align-items:center;gap:.2rem;margin-left:auto}
.nav a{font-family:var(--font-b);font-weight:600;font-size:.92rem;color:var(--ink-soft);
  padding:.5em .7em;border-radius:8px}
.nav a:hover{color:var(--teal);background:var(--mist);text-decoration:none}
.nav a[aria-current="page"]{color:var(--teal)}
.nav a.head-cta{color:#fff}
.nav a.head-cta:hover{color:#fff;background:var(--teal-700)}
.head-cta{margin-left:.4rem}
.nav-toggle{display:none;margin-left:auto;background:none;border:1.5px solid var(--line);
  border-radius:9px;width:42px;height:42px;align-items:center;justify-content:center;cursor:pointer}
.nav-toggle svg{width:20px;height:20px;stroke:var(--ink)}

@media(max-width:920px){
  .nav{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);padding:.6rem var(--gut) 1.2rem;
    gap:.1rem;margin-left:0;transform:translateY(-130%);transition:transform .28s ease;
    box-shadow:var(--shadow)}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.85em .4em;font-size:1.05rem;border-bottom:1px solid var(--line-soft)}
  .nav .head-cta{margin:.8rem 0 0}
  .nav .btn{justify-content:center}
  .nav-toggle{display:flex}
}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;background:var(--teal-deep)}
.hero-img{position:absolute;inset:0}
.hero-img img{width:100%;height:100%;object-fit:cover;opacity:.5}
.hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,var(--teal-deep) 18%,rgba(9,59,52,.82) 46%,rgba(55,44,87,.45) 100%)}
.hero-in{position:relative;max-width:var(--wrap);margin-inline:auto;padding:clamp(60px,9vw,120px) var(--gut) clamp(54px,7vw,96px)}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--gold-soft);font-weight:440}
.hero .lead{color:#D7E7E2;max-width:54ch;margin-top:1.2rem}
.hero .btn-row{margin-top:2rem}
.hero-eyebrow{color:var(--gold-soft)}
.hero-eyebrow::before{background:var(--gold-soft)}

/* trust bar */
.trustbar{position:relative;z-index:2;background:var(--ink);color:#CFE0DB}
.trustbar .row{display:flex;flex-wrap:wrap;gap:1rem 2.2rem;align-items:center;
  max-width:var(--wrap);margin-inline:auto;padding:.95rem var(--gut)}
.trustbar .ti{display:flex;align-items:center;gap:.5rem;font-size:.84rem;font-weight:600;letter-spacing:.01em}
.trustbar .ti svg{width:17px;height:17px;fill:none;stroke:var(--gold-soft);stroke-width:2;flex-shrink:0}
.trustbar b{color:#fff}

/* ---- generic grid ---- */
.grid{display:grid;gap:clamp(18px,2.4vw,28px)}
.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:880px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* split (text + media) */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(26px,4vw,60px);align-items:center}
.split.rev .split-media{order:-1}
.split-media img{border-radius:var(--r-lg);box-shadow:var(--shadow);display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
@media(max-width:820px){.split{grid-template-columns:1fr}.split.rev .split-media{order:0}}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:1.5rem 1.5rem 1.6rem;box-shadow:var(--shadow-sm)}
.card h3{margin-bottom:.4rem}
.card .ic{width:42px;height:42px;border-radius:11px;background:var(--mist);
  display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.card .ic svg{width:22px;height:22px;fill:none;stroke:var(--teal);stroke-width:1.7}
.card p{margin-bottom:0;color:var(--ink-soft);font-size:.97rem}

/* hospital card */
.hcard{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:.2s ease}
.hcard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.hcard .ph{aspect-ratio:4/3;overflow:hidden}
.hcard .ph img{width:100%;height:100%;object-fit:cover}
.hcard .bd{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.hcard h3{margin-bottom:.2rem}
.hcard .loc{font-family:var(--font-m);font-size:.74rem;letter-spacing:.04em;color:var(--ink-mute);
  text-transform:uppercase;margin-bottom:.7rem}
.hcard p{font-size:.95rem;color:var(--ink-soft)}
.hcard .tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:.4rem 0 1.1rem}
.hcard .more{margin-top:auto;font-weight:700;color:var(--teal);font-size:.95rem;
  display:inline-flex;align-items:center;gap:.4em}
.hcard .more::after{content:"→";transition:.2s}
.hcard:hover .more::after{transform:translateX(3px)}

.pill{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.02em;
  padding:.3em .7em;border-radius:999px;background:var(--mist);color:var(--teal-700);
  border:1px solid rgba(15,94,84,.16)}
.pill.lav{background:var(--haze);color:var(--lav-deep);border-color:rgba(124,108,174,.22)}
.pill.gold{background:#F8EFDD;color:#7a531a;border-color:rgba(194,135,58,.28)}

/* ---- journey line (signature) ---- */
.journey{list-style:none;margin:0;padding:0;position:relative}
.journey::before{content:"";position:absolute;left:21px;top:14px;bottom:14px;width:2px;
  background:linear-gradient(var(--teal),var(--lav));opacity:.4}
.journey li{position:relative;padding:0 0 1.6rem 60px;min-height:44px}
.journey li:last-child{padding-bottom:0}
.journey .dot{position:absolute;left:10px;top:0;width:24px;height:24px;border-radius:50%;
  background:var(--paper);border:2px solid var(--teal);display:flex;align-items:center;
  justify-content:center;font-family:var(--font-m);font-size:.72rem;font-weight:600;color:var(--teal);z-index:1}
.journey li.done .dot{background:var(--teal);color:#fff;border-color:var(--teal)}
.journey h4{margin:.1rem 0 .25rem}
.journey p{margin:0;color:var(--ink-soft);font-size:.96rem}
.section--deep .journey::before{background:linear-gradient(var(--gold-soft),var(--lav));opacity:.5}
.section--deep .journey .dot{background:var(--teal-deep);border-color:var(--gold-soft);color:var(--gold-soft)}
.section--deep .journey h4{color:#fff}
.section--deep .journey p{color:#BFD6D0}

/* horizontal numbered process (compact) */
.steps{counter-reset:s;display:grid;gap:1.4rem}
@media(min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.steps .st{position:relative;padding-top:1.1rem;border-top:2px solid var(--line)}
.steps .st::before{counter-increment:s;content:counter(s,decimal-leading-zero);
  font-family:var(--font-m);font-size:.8rem;color:var(--teal);font-weight:600;
  position:absolute;top:-.9rem;background:var(--paper);padding-right:.6rem}
.section--tint .steps .st::before{background:var(--mist)}

/* ---- feature list with ticks ---- */
.ticks{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.ticks li{position:relative;padding-left:1.9rem;color:var(--ink-soft)}
.ticks li::before{content:"";position:absolute;left:0;top:.34em;width:1.05rem;height:1.05rem;
  background:var(--mist);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F5E54' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-size:.72rem;background-repeat:no-repeat;background-position:center}
.ticks li strong{color:var(--ink)}

/* ---- pricing table ---- */
.ptable{width:100%;border-collapse:collapse;background:var(--card);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm);font-size:.95rem}
.ptable caption{caption-side:top;text-align:left;font-family:var(--font-m);font-size:.74rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);padding:0 0 .7rem}
.ptable th,.ptable td{padding:.78rem 1rem;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top}
.ptable thead th{background:var(--teal-deep);color:#fff;font-weight:650;font-size:.84rem;
  letter-spacing:.02em;border-bottom:none}
.ptable tbody tr:last-child td{border-bottom:none}
.ptable tbody tr:nth-child(even){background:#FBFAF7}
.ptable .eur{font-family:var(--font-m);font-weight:600;color:var(--ink);white-space:nowrap}
.ptable .thb{font-family:var(--font-m);font-size:.82rem;color:var(--ink-mute);white-space:nowrap}
.ptable .proc{font-weight:600;color:var(--ink)}
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tscroll .ptable{min-width:560px}

/* compare grid */
.compare{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--card);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.compare th,.compare td{padding:.8rem 1rem;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top}
.compare thead th{background:var(--ink);color:#fff;font-size:.85rem}
.compare tbody th{font-weight:600;color:var(--ink-soft);background:#FBFAF7;font-size:.86rem;white-space:nowrap}
.compare thead th.hname{font-family:var(--font-d);font-size:1.05rem;color:#fff;font-weight:600}

/* ---- FAQ ---- */
.faq details{border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:.7rem;
  background:var(--card);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.05rem 1.2rem;font-weight:650;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-m);font-size:1.3rem;color:var(--teal);
  transition:.2s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open] summary{border-bottom:1px solid var(--line-soft)}
.faq .ans{padding:1rem 1.2rem 1.2rem;color:var(--ink-soft)}
.faq .ans p:last-child{margin-bottom:0}

/* ---- callouts ---- */
.callout{background:var(--haze);border:1px solid rgba(124,108,174,.2);border-radius:var(--r);
  padding:1.2rem 1.4rem;display:flex;gap:.9rem;align-items:flex-start}
.callout svg{width:22px;height:22px;flex-shrink:0;stroke:var(--lav-deep);fill:none;stroke-width:1.8;margin-top:.15rem}
.callout p{margin:0;font-size:.95rem;color:var(--lav-deep)}
.callout.teal{background:var(--mist);border-color:rgba(15,94,84,.18)}
.callout.teal svg{stroke:var(--teal-700)}
.callout.teal p{color:var(--teal-deep)}

.note{font-size:.86rem;color:var(--ink-mute);font-style:italic}

/* reviewer / credential row */
.cred{display:flex;align-items:center;gap:1rem;background:var(--card);border:1px solid var(--line-soft);
  border-radius:var(--r);padding:1rem 1.2rem;box-shadow:var(--shadow-sm)}
.cred img{width:72px;height:72px;border-radius:14px;object-fit:cover;flex-shrink:0}
.cred-mono{width:72px;height:72px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;font-family:var(--font-d);font-weight:560;font-size:1.4rem;letter-spacing:.02em;
  color:var(--teal);background:linear-gradient(150deg,var(--mist),#D9E8E2);border:1px solid var(--line-soft)}
.cred .nm{font-family:var(--font-d);font-size:1.1rem;color:var(--ink);margin:0}
.cred .ro{font-size:.86rem;color:var(--ink-mute);margin:.1rem 0 0}

/* ---- CTA band ---- */
.cta-band{background:var(--teal-deep);color:#EAF3F0;border-radius:var(--r-lg);
  padding:clamp(30px,5vw,56px);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(120% 130% at 85% 0%,rgba(124,108,174,.5),transparent 55%)}
.cta-band>*{position:relative}
.cta-band h2{color:#fff;margin-bottom:.5rem}
.cta-band p{color:#C9DED8;max-width:52ch;margin:0 auto 1.6rem}
.cta-band .btn-row{justify-content:center}

/* ---- enquiry form ---- */
.form-card{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:clamp(22px,3.4vw,38px);box-shadow:var(--shadow)}
.fgrid{display:grid;gap:1rem}
@media(min-width:620px){.fgrid .two{display:grid;grid-template-columns:1fr 1fr;gap:1rem}}
.field label{display:block;font-weight:650;font-size:.9rem;margin-bottom:.35rem;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;font-family:var(--font-b);font-size:1rem;
  padding:.72em .85em;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(15,94,84,.14)}
.field textarea{resize:vertical;min-height:120px}
.field .req{color:var(--gold)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;color:var(--ink-soft)}
.consent input{width:1.1rem;height:1.1rem;margin-top:.25rem;flex-shrink:0;accent-color:var(--teal)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---- footer ---- */
.foot{background:var(--ink);color:#B9CFC9;font-size:.92rem}
.foot a{color:#D6E6E1}
.foot a:hover{color:#fff}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2rem;
  max-width:var(--wrap);margin-inline:auto;padding:clamp(40px,6vw,68px) var(--gut) 2.4rem}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}
.foot h4{color:#fff;font-family:var(--font-b);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:1rem}
.foot ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.foot .fbrand{font-family:var(--font-d);font-size:1.2rem;color:#fff;display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}
.foot .langs{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem}
.foot .langs span{font-size:.74rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.18em .6em;color:#CFE0DB}
.foot-bot{border-top:1px solid rgba(255,255,255,.12)}
.foot-bot .row{max-width:var(--wrap);margin-inline:auto;padding:1.2rem var(--gut);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:#8FAAA3}
.disclaimer{background:#112723;color:#86A39B;font-size:.8rem;line-height:1.55}
.disclaimer .wrap{padding-block:1.1rem}

/* ---- sticky mobile CTA ---- */
.mcta{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;gap:.5rem;
  padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));background:rgba(250,247,242,.95);
  backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.mcta .btn{flex:1;justify-content:center;padding:.78em 1em}
@media(max-width:760px){.mcta{display:flex}body{padding-bottom:72px}}

/* breadcrumb */
.crumb{font-size:.82rem;color:var(--ink-mute);padding:1rem 0 0;font-family:var(--font-b)}
.crumb a{color:var(--ink-mute)}.crumb a:hover{color:var(--teal)}
.crumb span{color:var(--ink)}

/* page hero (interior) */
.phero{background:var(--teal-deep);color:#fff;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(110% 120% at 92% 0%,rgba(124,108,174,.45),transparent 55%)}
.phero-in{position:relative;max-width:var(--wrap);margin-inline:auto;
  padding:clamp(40px,6vw,76px) var(--gut) clamp(34px,4vw,52px)}
.phero h1{color:#fff;max-width:20ch}
.phero .lead{color:#CFE3DE;max-width:60ch}
.phero .eyebrow{color:var(--gold-soft)}.phero .eyebrow::before{background:var(--gold-soft)}
.phero .crumb{color:#9CC0B8}.phero .crumb a{color:#9CC0B8}.phero .crumb span{color:#fff}

/* misc spacing utility */
.mt-1{margin-top:.6rem}.mt-2{margin-top:1.2rem}.mt-3{margin-top:2rem}.mt-4{margin-top:3rem}
.mb-0{margin-bottom:0}
.maxw{max-width:62ch}
.figure-cap{font-size:.8rem;color:var(--ink-mute);margin-top:.5rem;font-style:italic}
.kicker-num{font-family:var(--font-d);font-size:clamp(2.2rem,4vw,3.2rem);color:var(--teal);line-height:1;font-weight:560}
.statline{display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem}
.statline .s b{display:block;font-family:var(--font-d);font-size:1.9rem;color:var(--ink);line-height:1}
.statline .s span{font-size:.85rem;color:var(--ink-mute)}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:3px solid var(--lav);outline-offset:2px;border-radius:4px}
.skip{position:absolute;left:-9999px;top:0;background:var(--teal);color:#fff;padding:.6em 1em;z-index:100;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* reveal on scroll - gated on .js so content is ALWAYS visible if the script is slow or fails to load */
.js .reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.js .reveal.in{opacity:1;transform:none}
html.reveal-all .reveal,html.reveal-all .reveal.in{opacity:1!important;transform:none!important}
@media (prefers-reduced-motion: reduce){.js .reveal{opacity:1;transform:none;transition:none}}
