/* ============================================================
   GC INTEGRATIVE — SITE STYLESHEET
   Depends on tokens.css. Bespoke (no framework).
   Sections: base · layout · type · header · rail · buttons ·
   panels · hero · cards · circle · forms · faq · footer ·
   page-hero · motion · responsive · reduced-motion
   ============================================================ */

/* ---------- BASE / RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-sans);background:var(--pearl);color:var(--text);
  font-size:var(--fs-body);line-height:var(--lh-body);font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;
}
img,video,svg,canvas{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--dur-fast) var(--ease)}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
ul,ol{margin:0;padding:0;list-style:none}
figure{margin:0}
p{margin:0 0 1em}
hr{border:0;height:1px;background:var(--line)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
::selection{background:rgba(201,162,75,.30);color:var(--text)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;left:50%;top:-60px;transform:translateX(-50%);z-index:200;background:var(--ink-900);color:var(--on-dark);padding:.7rem 1.2rem;border-radius:var(--r-pill);transition:top .25s}
.skip-link:focus{top:12px}
[id]{scroll-margin-top:96px}

/* ---------- LAYOUT ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:var(--maxw-wide)}
.wrap-narrow{max-width:var(--maxw-narrow)}
.section{padding-block:var(--sec-y);position:relative;scroll-margin-top:86px}
.section-sm{padding-block:var(--sec-y-sm)}
.grid{display:grid;gap:clamp(1.25rem,2.5vw,2rem)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.stack-sm>*+*{margin-top:.75rem}
.stack>*+*{margin-top:1.25rem}
.center{text-align:center}
.measure{max-width:var(--maxw-text)}
.mx-auto{margin-inline:auto}

/* ---------- PANELS (color contexts) ---------- */
.panel-pearl{background:var(--pearl)}
.panel-paper{background:var(--paper)}
.panel-clay{background:linear-gradient(180deg,var(--pearl) 0%,var(--clay) 100%)}
.panel-mist{background:var(--mist)}
.panel-dark{background:var(--ink-900);color:var(--on-dark)}
.panel-dark.glow{background:var(--grad-hero)}
.panel-wood{background:var(--grad-wood);color:var(--on-dark)}
.panel-dark h1,.panel-dark h2,.panel-dark h3,.panel-dark h4,.panel-wood h1,.panel-wood h2,.panel-wood h3{color:var(--on-dark)}
.panel-dark p,.panel-wood p{color:var(--on-dark-soft)}
.panel-dark .lead,.panel-wood .lead{color:var(--on-dark-soft)}
.panel-dark .eyebrow,.panel-wood .eyebrow{color:var(--gold-1)}
.hairline{height:1px;background:var(--line);border:0;margin:0}
.panel-dark .hairline,.panel-wood .hairline{background:var(--line-dark)}

/* ---------- TYPE ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:var(--lh-snug);letter-spacing:var(--tr-tight);color:var(--text);margin:0 0 .5em}
.display{font-size:var(--fs-display);line-height:var(--lh-tight);letter-spacing:var(--tr-display);font-weight:480}
h1,.h1{font-size:var(--fs-h1)}
h2,.h2{font-size:var(--fs-h2)}
h3,.h3{font-size:var(--fs-h3)}
h4,.h4{font-size:var(--fs-h4);font-family:var(--font-sans);font-weight:600;letter-spacing:0}
.lead{font-size:var(--fs-lead);line-height:1.55;color:var(--text-soft);font-weight:400}
.small{font-size:var(--fs-sm)}.xs{font-size:var(--fs-xs)}
.muted{color:var(--text-mut)}
.soft{color:var(--text-soft)}
strong,b{font-weight:600}
.serif{font-family:var(--font-display)}
.italic{font-style:italic}
.metal{background:var(--grad-metal);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.gold-text{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}

.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-sans);font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--gold-2)}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--grad-gold)}
.eyebrow.center{justify-content:center}
.eyebrow.no-tick::before{display:none}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:44px;font-family:var(--font-sans);font-weight:600;font-size:.97rem;letter-spacing:.005em;padding:.95rem 1.6rem;border-radius:var(--r-pill);border:1px solid transparent;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease),background var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast);will-change:transform;line-height:1}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn .ar{transition:transform var(--dur-fast) var(--ease-out)}
.btn:hover .ar{transform:translate(3px,-3px)}
.btn--gold{background:var(--grad-gold);color:#2A1E05;box-shadow:var(--sh-1)}
.btn--gold:hover{box-shadow:var(--sh-gold)}
.btn--dark{background:var(--ink-900);color:var(--on-dark)}
.btn--dark:hover{background:var(--ink-700);box-shadow:var(--sh-2)}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-2)}
.panel-dark .btn--ghost,.panel-wood .btn--ghost,.hero .btn--ghost{border-color:var(--line-dark);color:var(--on-dark)}
.panel-dark .btn--ghost:hover,.hero .btn--ghost:hover{border-color:var(--gold-1);color:var(--gold-1)}
.btn--lg{padding:1.1rem 2rem;font-size:1.02rem}
.btn--sm{padding:.65rem 1.1rem;font-size:.86rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.textlink{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--gold-2);border-bottom:1px solid transparent;transition:border-color var(--dur-fast),gap var(--dur-fast)}
.textlink:hover{border-color:var(--gold);gap:.6rem}
.panel-dark .textlink{color:var(--gold-1)}

/* ---------- HEADER / NAV ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:var(--z-header);transition:background var(--dur),backdrop-filter var(--dur),box-shadow var(--dur),padding var(--dur)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px;transition:height var(--dur)}
.site-header.scrolled{background:color-mix(in srgb,var(--ink-900) 82%,transparent);backdrop-filter:blur(16px) saturate(1.15);-webkit-backdrop-filter:blur(16px) saturate(1.15);box-shadow:0 1px 0 var(--line-dark-soft),0 14px 40px -28px rgba(0,0,0,.9)}
.site-header.scrolled .bar{height:62px}
.brand{display:inline-flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand img{height:38px;width:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-family:var(--font-display);font-weight:600;font-size:1.04rem;color:var(--on-dark);letter-spacing:.01em}
.brand .bt span{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-mut);margin-top:3px}
.nav{display:flex;align-items:center;gap:.2rem}
.nav a{font-size:.92rem;font-weight:500;color:var(--on-dark-soft);padding:.55rem .7rem;border-radius:8px;position:relative;white-space:nowrap}
.nav a:hover,.nav a.active{color:var(--on-dark)}
.nav a::after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.32rem;height:1.5px;background:var(--grad-gold);transform:scaleX(0);transform-origin:left;transition:transform var(--dur-fast) var(--ease-out)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav .has-sub{position:relative}
.nav .submenu{position:absolute;top:calc(100% + 8px);left:0;min-width:264px;background:color-mix(in srgb,var(--ink-800) 96%,transparent);backdrop-filter:blur(18px);border:1px solid var(--line-dark);border-radius:var(--r);padding:.5rem;box-shadow:var(--sh-dark);opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--dur-fast) var(--ease-out)}
.nav .has-sub:hover .submenu,.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .submenu a{display:block;padding:.6rem .8rem;border-radius:8px;color:var(--on-dark-soft);font-size:.9rem}
.nav .submenu a::after{display:none}
.nav .submenu a:hover{background:var(--line-dark-soft);color:var(--on-dark)}
.nav .submenu a small{display:block;color:var(--on-dark-mut);font-weight:400;font-size:.76rem;margin-top:2px}
.header-cta{display:flex;align-items:center;gap:.6rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:10px;border:1px solid var(--line-dark);align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:20px;height:1.6px;background:var(--on-dark);transition:transform .3s var(--ease-out),opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:var(--z-drawer);background:var(--grad-hero);transform:none;clip-path:inset(0 0 0 100%);visibility:hidden;transition:clip-path .42s var(--ease-out),visibility 0s linear .42s;display:flex;flex-direction:column;padding:6rem var(--gutter) 2rem;overflow-y:auto}
.drawer.open{clip-path:inset(0);visibility:visible;transition:clip-path .42s var(--ease-out),visibility 0s}
.drawer a{font-family:var(--font-display);font-size:1.5rem;color:var(--on-dark);padding:.55rem 0;border-bottom:1px solid var(--line-dark-soft)}
.drawer a:hover{color:var(--gold-1)}
.drawer .dr-cta{margin-top:auto;display:grid;gap:.7rem;padding-top:1.5rem}
.drawer .dr-sub a{font-family:var(--font-sans);font-size:1.02rem;color:var(--on-dark-soft);padding-left:1rem;border:0}

/* ---------- STICKY CTA RAIL ---------- */
.cta-rail{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:var(--z-rail);display:flex;flex-direction:column;gap:.6rem}
.cta-rail a{writing-mode:vertical-rl;transform:rotate(180deg);padding:1.1rem .65rem;border-radius:var(--r-pill);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;box-shadow:var(--sh-2);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast)}
.cta-rail a:hover{transform:rotate(180deg) translateY(4px)}
.cta-rail .r-book{background:var(--grad-gold);color:#2A1E05}
.cta-rail .r-refer{background:var(--ink-900);color:var(--on-dark);border:1px solid var(--line-dark)}
.mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:var(--z-rail);grid-template-columns:repeat(3,1fr);background:color-mix(in srgb,var(--ink-900) 92%,transparent);backdrop-filter:blur(14px);border-top:1px solid var(--line-dark)}
.mobile-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;padding:.7rem 0;color:var(--on-dark-soft);font-size:.72rem;font-weight:600;letter-spacing:.02em}
.mobile-bar a svg{width:20px;height:20px}
.mobile-bar a.primary{color:var(--gold-1)}
.mobile-bar a+a{border-left:1px solid var(--line-dark-soft)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:var(--on-dark);overflow:hidden;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-scrim{position:absolute;inset:0;z-index:-1;background:
  linear-gradient(95deg,rgba(8,9,12,.90) 0%,rgba(8,9,12,.58) 36%,rgba(8,9,12,.20) 64%,rgba(8,9,12,.05) 100%),
  linear-gradient(180deg,rgba(8,9,12,.50) 0%,rgba(8,9,12,.08) 34%,rgba(8,9,12,.30) 68%,rgba(8,9,12,.82) 100%),
  radial-gradient(120% 80% at 82% 22%,rgba(201,162,75,.16),transparent 55%)}
.hero canvas.fx{position:absolute;inset:0;z-index:-1;opacity:.55;mix-blend-mode:screen;pointer-events:none}
.hero-inner{padding-block:9rem 6rem;max-width:920px}
.hero .display{margin-bottom:1.1rem}
.hero .lead{color:var(--on-dark-soft);max-width:640px;margin-bottom:2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--on-dark-mut);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase}
.scroll-cue .line{width:1px;height:42px;background:linear-gradient(var(--gold-1),transparent);animation:cue 2.2s var(--ease-in-out) infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ---------- EYEBROW HEAD BLOCK ---------- */
.head{max-width:var(--maxw-narrow)}
.head.center{margin-inline:auto;text-align:center}
.head .eyebrow{margin-bottom:1rem}
.head h2{margin-bottom:.6rem}

/* ---------- CARDS ---------- */
.card{position:relative;display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.5rem,2.4vw,2.1rem);box-shadow:var(--sh-1);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast),border-color var(--dur-fast);overflow:hidden}
.card::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--grad-metal);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease-out)}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-3);border-color:var(--sand)}
.card:hover::before{transform:scaleX(1)}
.card .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(145deg,#fff,var(--clay));border:1px solid var(--line);margin-bottom:1.1rem;color:var(--gold-2)}
.card .ic svg{width:26px;height:26px}
.card h3{font-size:1.3rem;margin-bottom:.5rem}
.card p{color:var(--text-soft);margin-bottom:.9rem;font-size:.99rem}
.panel-dark .card{background:rgba(255,255,255,.035);border-color:var(--line-dark);box-shadow:none}
.panel-dark .card:hover{background:rgba(255,255,255,.06);border-color:rgba(201,162,75,.4)}
.panel-dark .card p{color:var(--on-dark-soft)}
.panel-dark .card .ic{background:rgba(255,255,255,.05);border-color:var(--line-dark);color:var(--gold-1)}

/* service card with image */
.svc{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast)}
.svc:hover{transform:translateY(-5px);box-shadow:var(--sh-3)}
.svc .ph{aspect-ratio:16/10;overflow:hidden}
.svc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.svc:hover .ph img{transform:scale(1.05)}
.svc .bd{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.svc .bd h3{font-size:1.22rem;margin-bottom:.4rem}
.svc .bd p{color:var(--text-soft);font-size:.95rem;flex:1;margin-bottom:1rem}

/* pathway cards (4 large) */
.pathway{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;border-radius:var(--r-lg);overflow:hidden;color:var(--on-dark);isolation:isolate;border:1px solid var(--line-dark)}
.pathway .frame{position:absolute!important;inset:0;display:block;margin:0;border-radius:inherit}
.pathway img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.pathway::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,9,12,.15) 0%,rgba(8,9,12,.55) 55%,rgba(8,9,12,.92) 100%)}
.pathway:hover img{transform:scale(1.06)}
.pathway .pc{position:relative;z-index:2;padding:1.5rem}
.pathway .rep-tag{z-index:2}
.pathway .eyebrow{color:var(--gold-1);margin-bottom:.5rem}
.pathway h3{color:#fff;font-size:1.32rem;margin-bottom:.4rem}
.pathway p{color:rgba(255,255,255,.78);font-size:.92rem;margin-bottom:1rem}
.pathway .textlink{color:var(--gold-1)}

/* who-we-help chip */
.who{display:flex;gap:.85rem;align-items:flex-start;padding:1.1rem 1.2rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);transition:border-color var(--dur-fast),transform var(--dur-fast) var(--ease-out)}
.who:hover{border-color:var(--sand);transform:translateY(-3px)}
.who .dot{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:linear-gradient(145deg,var(--clay),#fff);display:grid;place-items:center;color:var(--gold-2)}
.who .dot svg{width:20px;height:20px}
.who b{display:block;font-size:1rem;margin-bottom:1px}
.who span{font-size:.88rem;color:var(--text-mut)}

/* credential / trust list */
.trust-list{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.trust-list li{background:var(--paper);padding:1.05rem 1.3rem;display:flex;gap:.85rem;align-items:flex-start}
.trust-list .tk{flex-shrink:0;color:var(--gold-2);margin-top:2px}
.trust-list b{font-weight:600}
.trust-list span{color:var(--text-soft);font-size:.95rem}
.panel-dark .trust-list{background:var(--line-dark);border-color:var(--line-dark)}
.panel-dark .trust-list li{background:rgba(255,255,255,.03)}
.panel-dark .trust-list span{color:var(--on-dark-soft)}
.panel-dark .trust-list .tk{color:var(--gold-1)}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem}
.stat .n{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.1rem);line-height:1;color:var(--text)}
.panel-dark .stat .n{color:var(--on-dark)}
.stat .n .metal{display:inline}
.stat .l{font-size:.9rem;color:var(--text-mut);margin-top:.5rem;max-width:220px}

/* image frame */
.frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-3)}
.frame img{width:100%;height:100%;object-fit:cover}
.frame.tall{aspect-ratio:4/5}
.frame.wide{aspect-ratio:16/10}
.frame-badge{position:absolute;left:18px;bottom:18px;display:flex;align-items:center;gap:.6rem;background:color-mix(in srgb,var(--ink-900) 78%,transparent);backdrop-filter:blur(10px);border:1px solid var(--line-dark);border-radius:var(--r-pill);padding:.55rem 1rem;color:var(--on-dark);font-size:.82rem;font-weight:600}
.frame-badge img{height:18px;width:auto}

/* quote / philosophy */
.philo{display:grid;gap:.4rem}
.philo .ln{font-family:var(--font-display);font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.12;letter-spacing:var(--tr-display);font-weight:480}
.bigquote{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.35;font-style:italic;font-weight:440}
.bigquote cite{display:block;font-style:normal;font-family:var(--font-sans);font-size:.9rem;letter-spacing:.04em;color:var(--text-mut);margin-top:1.2rem}
.panel-dark .bigquote cite{color:var(--on-dark-mut)}

/* video player block */
.video-block{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-3);background:#000;aspect-ratio:16/9}
.video-block video{width:100%;height:100%;object-fit:cover}
.video-block .vposter{position:absolute;inset:0;cursor:pointer}
.video-block .vposter img{width:100%;height:100%;object-fit:cover}
.video-block .vposter::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,12,.15),rgba(8,9,12,.55))}
.playbtn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:84px;height:84px;border-radius:50%;background:color-mix(in srgb,var(--ink-900) 55%,transparent);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;color:#fff;transition:transform var(--dur-fast) var(--ease-out),background var(--dur-fast)}
.video-block .vposter:hover .playbtn{transform:translate(-50%,-50%) scale(1.08);background:var(--grad-gold);color:#2A1E05;border-color:transparent}
.playbtn svg{width:30px;height:30px;margin-left:4px}

/* ---------- SIX-STAGE CIRCLE ---------- */
.circle-wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.circle-stage{position:relative;aspect-ratio:1;max-width:520px;margin-inline:auto;width:100%}
.circle-stage canvas{width:100%;height:100%}
.circle-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center;pointer-events:none;padding:22%}
.circle-center .cs-no{font-family:var(--font-sans);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-1)}
.circle-center .cs-name{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);color:var(--on-dark);margin:.2rem 0 .4rem}
.circle-center .cs-copy{font-size:.92rem;color:var(--on-dark-soft);line-height:1.5}
.stage-list{display:grid;gap:.3rem}
.stage-item{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;padding:1rem 1.15rem;border-radius:var(--r);border:1px solid transparent;cursor:pointer;transition:background var(--dur-fast),border-color var(--dur-fast)}
.stage-item .si-no{font-family:var(--font-display);font-size:1.1rem;color:var(--on-dark-mut);width:1.6rem}
.stage-item .si-name{font-family:var(--font-display);font-size:1.18rem;color:var(--on-dark);transition:color var(--dur-fast)}
.stage-item .si-copy{font-size:.9rem;color:var(--on-dark-mut);margin-top:.25rem;max-width:46ch;display:none}
.stage-item.active{background:rgba(201,162,75,.08);border-color:rgba(201,162,75,.35)}
.stage-item.active .si-no{color:var(--gold-1)}
.stage-item.active .si-name{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stage-item.active .si-copy{display:block;color:var(--on-dark-soft)}

/* ---------- FORMS ---------- */
.form{display:grid;gap:1.15rem}
.field{display:grid;gap:.45rem}
.field label{font-size:.88rem;font-weight:600;color:var(--text)}
.field label .req{color:var(--gold-2)}
.field input,.field select,.field textarea{font:inherit;font-size:1rem;padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--paper);color:var(--text);transition:border-color var(--dur-fast),box-shadow var(--dur-fast);width:100%}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--glow-gold-soft)}
.field .help{font-size:.8rem;color:var(--text-mut)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem}
.file{display:flex;align-items:center;gap:.8rem;padding:.85rem 1rem;border:1px dashed var(--line);border-radius:var(--r-sm);background:var(--pearl-2);color:var(--text-soft);font-size:.92rem;cursor:pointer}
.file input{display:none}
.field-check{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:var(--text-soft)}
.field-check input{width:18px;height:18px;margin-top:2px;accent-color:var(--gold)}
fieldset{border:0;padding:0;margin:0}
fieldset legend{font-family:var(--font-display);font-size:1.15rem;margin-bottom:.9rem;padding-top:.5rem}
.form-note{font-size:.82rem;color:var(--text-mut);line-height:1.5}
.form-success{display:none;padding:1.25rem 1.5rem;border:1px solid rgba(201,162,75,.55);background:#f6efdc;border-radius:var(--r);color:#16181d;font-size:1rem;line-height:1.55}
.form-success b{color:#16181d}
.form-success a{color:#7a5f12;text-decoration:underline}
.form-success.show{display:block}
.panel-dark .field label{color:var(--on-dark)}
.panel-dark .field input,.panel-dark .field select,.panel-dark .field textarea{background:rgba(255,255,255,.05);border-color:var(--line-dark);color:var(--on-dark)}
.panel-dark .file{background:rgba(255,255,255,.03);border-color:var(--line-dark);color:var(--on-dark-soft)}

/* contact cards */
.contact-line{display:flex;gap:.9rem;align-items:flex-start}
.contact-line .ic{flex-shrink:0;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(145deg,#fff,var(--clay));border:1px solid var(--line);color:var(--gold-2)}
.panel-dark .contact-line .ic{background:rgba(255,255,255,.05);border-color:var(--line-dark);color:var(--gold-1)}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 0;font-family:var(--font-display);font-size:1.15rem;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{position:relative;width:20px;height:20px;flex-shrink:0}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--gold-2);transition:transform var(--dur-fast)}
.faq summary .pm::before{top:9px;left:0;width:20px;height:2px}
.faq summary .pm::after{top:0;left:9px;width:2px;height:20px}
.faq details[open] summary .pm::after{transform:scaleY(0)}
.faq details > div{padding:0 0 1.4rem;color:var(--text-soft);max-width:70ch}
.panel-dark .faq{border-color:var(--line-dark)}
.panel-dark .faq details{border-color:var(--line-dark)}
.panel-dark .faq details>div{color:var(--on-dark-soft)}

/* ---------- PAGE HERO (interior) ---------- */
.page-hero{position:relative;padding-block:11rem 3.5rem;color:var(--on-dark);overflow:hidden;isolation:isolate}
.page-hero.media::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(8,9,12,.78),rgba(8,9,12,.62))}
.page-hero .ph-bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover}
.page-hero.plain{background:var(--grad-hero)}
.hero h1,.hero .display,.page-hero h1,.page-hero h2{color:var(--on-dark)}
.page-hero h1{font-size:var(--fs-h1);max-width:18ch}
.page-hero .lead{max-width:60ch;color:var(--on-dark-soft)}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.82rem;color:var(--on-dark-mut);margin-bottom:1.5rem}
.breadcrumb a:hover{color:var(--gold-1)}
.breadcrumb .sep{opacity:.5}

/* alert / disclaimer band */
.band{padding:1.1rem 1.3rem;border-radius:var(--r);border:1px solid;font-size:.95rem;display:flex;gap:.85rem;align-items:flex-start}
.band .bi{flex-shrink:0;margin-top:1px}
.band-warn{background:#FBE7E4;border-color:#E8B9AE;color:#7A2E1C}
.band-info{background:rgba(201,162,75,.08);border-color:rgba(201,162,75,.32);color:var(--wood-2)}
.panel-dark .band-info{color:var(--on-dark-soft)}

/* pill tags */
.tags{display:flex;flex-wrap:wrap;gap:.5rem}
.tag{font-size:.8rem;font-weight:600;padding:.4rem .85rem;border-radius:var(--r-pill);background:var(--clay);color:var(--wood-2);border:1px solid var(--line)}
.panel-dark .tag{background:rgba(255,255,255,.06);color:var(--on-dark-soft);border-color:var(--line-dark)}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--ink-900);color:var(--on-dark);padding-block:clamp(3.5rem,6vw,5.5rem) 2rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:2.5rem}
.footer-brand img{height:46px;margin-bottom:1.1rem}
.footer-brand p{color:var(--on-dark-mut);font-size:.92rem;max-width:34ch}
.foot-col h4{font-family:var(--font-sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-1);margin-bottom:1.1rem}
.foot-col a{display:block;color:var(--on-dark-soft);font-size:.94rem;padding:.34rem 0}
.foot-col a:hover{color:var(--on-dark)}
.news input{width:100%;padding:.8rem 1rem;border-radius:var(--r-pill);border:1px solid var(--line-dark);background:rgba(255,255,255,.05);color:var(--on-dark);margin:.7rem 0}
.news input:focus{outline:none;border-color:var(--gold)}
/* Kajabi newsletter embed (form 2149606162) — brand-match to the dark footer */
.news-kjb .kajabi-form__title,
.news-kjb .kajabi-form__subtitle{display:none}
.news-kjb #kajabi-form,.news-kjb .kajabi-form__content,.news-kjb fieldset{margin:0;padding:0;border:0;text-align:left}
.news-kjb input[type=email]{width:100%;padding:.8rem 1rem;border-radius:var(--r-pill);border:1px solid var(--line-dark);background:rgba(255,255,255,.05);color:var(--on-dark);margin:.2rem 0 .7rem;font-size:.95rem}
.news-kjb input[type=email]::placeholder{color:var(--on-dark-mut)}
.news-kjb input[type=email]:focus{outline:none;border-color:var(--gold)}
.news-kjb .kajabi-form__btn{width:100%;padding:.8rem 1rem;border:0!important;border-radius:var(--r-pill);background:var(--gold)!important;color:#1b1300!important;font-weight:700;font-size:.95rem;cursor:pointer;transition:filter .15s ease}
.news-kjb .kajabi-form__btn:hover{filter:brightness(1.06)}
.footer-area-btn{display:flex!important;align-items:center;gap:.75rem;margin-top:1rem;padding:.82rem .95rem!important;border:1px solid rgba(234,206,130,.38);border-radius:var(--r);background:rgba(234,206,130,.08);color:var(--on-dark)!important;box-shadow:0 12px 32px -24px rgba(234,206,130,.55);transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast),background var(--dur-fast)}
.footer-area-btn:hover{transform:translateY(-2px);border-color:var(--gold-1);background:rgba(234,206,130,.14)}
.footer-area-btn .fab-ic{flex-shrink:0;width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--grad-gold);color:#2A1E05}
.footer-area-btn .fab-ic svg{width:20px;height:20px}
.footer-area-btn b{display:block;font-size:.93rem;line-height:1.15}
.footer-area-btn small{display:block;margin-top:2px;color:var(--on-dark-mut);font-size:.75rem;line-height:1.25}
.footer-area-btn .fab-ar{margin-left:auto;color:var(--gold-1);font-weight:700}
.footer-bot{margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;align-items:center}
.footer-bot p{color:var(--on-dark-mut);font-size:.82rem;margin:0}
.footer-legal{display:flex;gap:1.2rem;flex-wrap:wrap}
.footer-legal a{color:var(--on-dark-mut);font-size:.82rem}
.footer-legal a:hover{color:var(--gold-1)}
.socials{display:flex;gap:.6rem}
.socials a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-dark);display:grid;place-items:center;color:var(--on-dark-soft)}
.socials a:hover{border-color:var(--gold);color:var(--gold-1)}
.disclaimer-foot{margin-top:1.5rem;color:var(--on-dark-mut);font-size:.76rem;line-height:1.6;max-width:90ch}

/* ---------- MOTION (reveal) ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal="fade"]{transform:none}
[data-reveal="left"]{transform:translateX(-30px)}
[data-reveal="right"]{transform:translateX(30px)}
[data-reveal].in{transform:none}
[data-stagger]>*{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
[data-stagger].in>*{opacity:1;transform:none}
.parallax{will-change:transform}

/* ---------- UTILITIES ---------- */
.mt-0{margin-top:0}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}
.mb-0{margin-bottom:0}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}
.gap-sm{gap:.6rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.wrap-flex{flex-wrap:wrap}
.hide{display:none}
.rule-gold{height:2px;width:64px;background:var(--grad-gold);border:0;border-radius:2px}
.full{width:100%}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1100px){
  .cta-rail{display:none}
  .mobile-bar{display:grid}
  body{padding-bottom:60px}
  .nav,.header-cta .btn{display:none}
  .nav-toggle{display:flex}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:900px){
  .split,.circle-wrap{grid-template-columns:1fr;gap:2.5rem}
  .split.rev{direction:ltr}
  .cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}
  .circle-stage{max-width:400px}
  .form-row,.form-row-3{grid-template-columns:1fr}
}
@media (max-width:600px){
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bot{flex-direction:column;align-items:flex-start}
  .hero-inner{padding-block:7rem 5rem}
  .btn{width:100%}
  .btn-row .btn{width:auto}
  .hero-cta .btn{width:100%}
  [data-reveal="left"],[data-reveal="right"]{transform:translateY(26px)}
}

/* ---------- no-crop image frame (faces never cut) ---------- */
.frame.free{aspect-ratio:auto;line-height:0}
.frame.free img{width:100%;height:auto;display:block;object-fit:contain}

/* ---------- founder film (enlarged) ---------- */
.film-stage{max-width:1000px;margin-inline:auto}
button.video-block{border:0;padding:0;width:100%;font:inherit;color:inherit;display:block;cursor:pointer}
.film-stage .video-block{aspect-ratio:16/9;box-shadow:var(--sh-dark)}
.film-stage .playbtn{width:104px;height:104px}
.film-stage .playbtn svg{width:38px;height:38px}

/* ---------- video lightbox ---------- */
.vmodal{position:fixed;inset:0;z-index:var(--z-modal);display:none;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);background:rgba(6,7,9,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.vmodal.open{display:flex}
.vmodal .vbox{position:relative;width:min(92vw,1400px);aspect-ratio:16/9;max-height:86vh;border-radius:var(--r-lg);overflow:hidden;background:#000;box-shadow:0 40px 120px -30px rgba(0,0,0,.9)}
.vmodal video{width:100%;height:100%;object-fit:contain;background:#000;display:block}
.vmodal .vclose{position:absolute;top:-16px;right:-16px;width:46px;height:46px;border-radius:50%;background:var(--ink-900);color:var(--on-dark);border:1px solid var(--line-dark);display:grid;place-items:center;line-height:1;font-size:1.5rem;cursor:pointer;z-index:2}
.vmodal .vclose:hover{background:var(--grad-gold);color:#2A1E05;border-color:transparent}
@media(max-width:680px){.vmodal .vclose{top:8px;right:8px}}

/* ---------- intro interstitial (brand opening clip) ---------- */
.intro-clip{position:fixed;inset:0;z-index:var(--z-modal);display:none;align-items:center;justify-content:center;background:#0C0D10}
.intro-clip.open{display:flex}
.intro-clip video{width:100%;height:100%;object-fit:cover}
.intro-clip .skip{position:absolute;bottom:26px;right:26px;z-index:2;padding:.7rem 1.35rem;border-radius:var(--r-pill);background:color-mix(in srgb,var(--ink-900) 55%,transparent);backdrop-filter:blur(6px);border:1px solid var(--line-dark);color:var(--on-dark);font-weight:600;font-size:.88rem;letter-spacing:.04em;cursor:pointer}
.intro-clip .skip:hover{background:var(--grad-gold);color:#2A1E05;border-color:transparent}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal],[data-stagger]>*{opacity:1!important;transform:none!important}
  .scroll-cue .line{animation:none}
  .hero canvas.fx{display:none}
}

/* ============================================================
   ABOUT / FOUNDER — Authority layer (authority & social-proof cues)
   ============================================================ */

/* Authority credential ribbon — sits directly under the hero */
.cred-strip{background:var(--ink-900);border-bottom:1px solid var(--line-dark-soft)}
.cred-strip .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.45rem 1.4rem;padding-block:1.45rem}
.cred-strip .ci{display:inline-flex;align-items:center;color:var(--on-dark-soft);font-size:.95rem;font-weight:500;letter-spacing:.005em}
.cred-strip .ci b{color:var(--on-dark);font-weight:600}
.cred-strip .ci:not(:last-child)::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.6;margin-left:1.4rem}
@media(max-width:760px){.cred-strip .ci:not(:last-child)::after{display:none}.cred-strip .wrap{gap:.7rem 1.1rem;padding-block:1.1rem}.cred-strip .ci{font-size:.875rem}}

/* Champions — power feature */
.champ-hero{margin-top:clamp(2rem,4vw,3.25rem)}
.champ-hero .frame{aspect-ratio:3/2}
.champ-grid{margin-top:clamp(1rem,2.4vw,1.6rem)}
.champ-grid .gframe{position:relative;border-radius:var(--r-lg);overflow:hidden;background:#0a0b0e;border:1px solid var(--line-dark-soft);aspect-ratio:4/5}
.champ-grid .gframe img{width:100%;height:100%;object-fit:cover;display:block}
.champ-grid .cap{position:absolute;left:0;right:0;bottom:0;padding:1.5rem 1.1rem .9rem;font-size:.84rem;font-weight:600;color:var(--on-dark);letter-spacing:.01em;background:linear-gradient(180deg,transparent,rgba(8,9,12,.82))}

/* Youth-chamber presidency — honour feature */
.honor-feat .frame{aspect-ratio:1/1}
.honor-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.45rem 1rem;border-radius:var(--r-pill);background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.34);color:var(--gold-2);font-size:.76rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}

/* ============================================================
   EVENTS · COMMUNITY APPRECIATION · PRACTITIONER PROGRAM
   ============================================================ */

/* CJK-safe stack for Traditional Chinese disclaimers */
.zh{font-family:"PingFang TC","Hiragino Sans GB","Microsoft JhengHei","Noto Sans TC",var(--font-sans);line-height:1.8}

/* Compliance / privacy note box */
.note-box{border:1px solid rgba(201,162,75,.34);background:rgba(201,162,75,.08);border-radius:var(--r);padding:1.3rem 1.55rem;color:var(--wood-2)}
.note-box .nb-h{display:flex;align-items:center;gap:.6rem;font-weight:600;color:var(--gold-2);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.7rem}
.note-box p{color:var(--wood-2);font-size:.92rem}
.note-box p+p{margin-top:.7rem}
.panel-dark .note-box{color:var(--on-dark-soft)}.panel-dark .note-box p{color:var(--on-dark-soft)}

/* Events list */
.ev-item{display:grid;grid-template-columns:auto 1fr auto;gap:1.6rem;align-items:center;padding:1.5rem 1.65rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast)}
.ev-item:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}
.ev-item+.ev-item{margin-top:1rem}
.ev-date{text-align:center;min-width:72px}
.ev-date .d{font-family:var(--font-display);font-size:1.95rem;line-height:1;color:var(--text)}
.ev-date .m{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);margin-top:.3rem}
.ev-body h3{font-size:1.16rem;margin-bottom:.25rem}
.ev-body p{color:var(--text-soft);font-size:.93rem}
.ev-body .meta{font-size:.82rem;color:var(--text-mut);margin-top:.45rem;display:flex;flex-wrap:wrap;gap:.3rem 1.1rem}
@media(max-width:680px){.ev-item{grid-template-columns:auto 1fr;gap:1.1rem}.ev-item .btn{grid-column:1/-1;width:100%;justify-content:center}}
.ev-empty{text-align:center;max-width:62ch;margin-inline:auto;padding:clamp(2.5rem,5vw,4rem) clamp(1.5rem,4vw,3rem);background:var(--grad-hero);border:1px solid var(--line-dark);border-radius:var(--r-lg);color:var(--on-dark)}
.ev-empty h3{color:var(--on-dark)}.ev-empty p{color:var(--on-dark-soft)}

/* Appreciation letters + kind words */
.letter{background:var(--pearl-2);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.8rem;box-shadow:var(--sh-card);height:100%}
.letter .q{font-family:var(--font-display);font-style:italic;font-size:1.14rem;line-height:1.5;color:var(--text)}
.letter .by{margin-top:1.05rem;font-size:.82rem;color:var(--text-mut);letter-spacing:.02em}

/* Representative-image gallery tag */
.gal-fig{position:relative}
.rep-tag{position:absolute;top:10px;right:10px;left:auto;bottom:auto;font-size:.5rem;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.9);background:rgba(8,9,12,.5);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-pill);padding:.16rem .48rem;pointer-events:none;z-index:4}

/* East-West visual storytelling */
.benefit-badges{display:flex;flex-wrap:wrap;gap:.55rem}
.benefit-badges span{display:inline-flex;align-items:center;min-height:34px;border:1px solid rgba(201,162,75,.30);border-radius:var(--r-pill);padding:.42rem .86rem;background:rgba(201,162,75,.08);color:var(--gold-2);font-size:.8rem;font-weight:700;letter-spacing:.04em}
.panel-dark .benefit-badges span,.panel-wood .benefit-badges span{border-color:rgba(234,206,130,.36);background:rgba(234,206,130,.10);color:var(--gold-1)}
.bilingual-frame img{object-position:center 38%}
.bilingual-cue{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;color:var(--gold-2);font-size:.86rem;font-weight:700;letter-spacing:.04em}
.panel-dark .bilingual-cue{color:var(--gold-1)}
#two-worlds{padding-block:clamp(2.1rem,3.8vw,4.2rem)}
#two-worlds .wrap{max-width:min(1510px,100%)}
#two-worlds .head{max-width:1510px}
#two-worlds .head h2{font-size:clamp(2rem,2.8vw,2.95rem);line-height:1.05}
.translation-showcase.mt-12{margin-top:clamp(1.15rem,1.8vw,1.75rem)}
.translation-showcase{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(.7rem,1.25vw,1.15rem);align-items:stretch}
.world-card,.gc-translation-card{position:relative;overflow:hidden;display:grid;grid-template-rows:auto 50% 1fr;height:clamp(535px,29vw,560px);min-height:0;border-radius:18px;border:1px solid rgba(20,20,28,.12);background:var(--ink-900);box-shadow:0 1px 0 rgba(255,255,255,.42) inset,0 18px 48px -30px rgba(28,22,12,.42)}
.world-card__strip{display:flex;align-items:center;justify-content:center;min-height:34px;padding:.48rem .8rem;font-family:var(--font-sans);font-size:.75rem;line-height:1.1;font-weight:800;letter-spacing:.14em;text-transform:uppercase;text-align:center;color:var(--on-dark);background:linear-gradient(180deg,#141820 0%,#0b0d12 100%);border-bottom:1px solid rgba(255,255,255,.08)}
.world-card:not(.west) .world-card__strip{background:linear-gradient(180deg,#2a170f 0%,#120d0b 100%)}
.gc-translation-card{border-color:rgba(201,162,75,.46);box-shadow:0 1px 0 rgba(255,255,255,.38) inset,0 20px 56px -30px rgba(138,101,38,.7)}
.gc-translation-card .world-card__strip{color:#fff7db;background:linear-gradient(180deg,#9c782f 0%,#6e501d 100%);border-bottom-color:rgba(255,255,255,.18)}
.world-card figure,.merge-visual{position:relative;height:100%;min-height:0;margin:0;overflow:hidden;border:0;border-radius:0;background:rgba(255,255,255,.04)}
.world-card figure img,.merge-visual img{width:100%;height:100%;object-fit:cover;filter:saturate(.98) contrast(1.02)}
.world-card.west figure img{object-position:center 48%}
.world-card:not(.west) figure img{object-position:center 52%}
.gc-translation-card .merge-visual img{object-position:center 48%}
#two-worlds .rep-tag{top:10px;right:10px;left:auto;bottom:auto;font-size:.5rem;padding:.16rem .48rem;background:rgba(8,9,12,.5)}
.world-card .wc-body,.gc-translation-card .wc-body{display:grid;grid-template-columns:auto minmax(0,1fr);gap:clamp(.78rem,1vw,1rem);align-items:flex-start;padding:clamp(.9rem,1.1vw,1.05rem);color:var(--on-dark);background:
  radial-gradient(circle at 4% 18%,rgba(194,199,207,.13),transparent 30%),
  linear-gradient(145deg,#171b23 0%,#0d0f14 100%);border-top:1px solid rgba(255,255,255,.08)}
.world-card:not(.west) .wc-body{background:
  radial-gradient(circle at 8% 12%,rgba(201,162,75,.13),transparent 32%),
  linear-gradient(145deg,#331e15 0%,#15100e 100%)}
.gc-translation-card .wc-body{background:
  radial-gradient(circle at 0% 20%,rgba(234,206,130,.24),transparent 34%),
  linear-gradient(140deg,#826222 0%,#6c4a18 52%,#3a2610 100%);border-top-color:rgba(234,206,130,.28)}
.world-icon{width:58px;height:58px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(234,206,130,.74);color:var(--gold-1);background:rgba(8,9,12,.24);box-shadow:0 0 0 6px rgba(234,206,130,.055)}
.world-card.west .world-icon{color:var(--silver-1);border-color:rgba(232,235,239,.72);box-shadow:0 0 0 6px rgba(232,235,239,.045)}
.world-icon svg{width:29px;height:29px}
.world-icon--bridge{color:#fff1bd;border-color:rgba(255,241,189,.78);background:rgba(8,9,12,.18)}
.wc-copy{min-width:0}
.world-card h3{font-size:clamp(1.08rem,1.35vw,1.34rem);line-height:1.16;margin:0 0 .55rem;color:var(--on-dark)}
.world-card p{font-size:clamp(.86rem,.9vw,.96rem);line-height:1.58;color:var(--on-dark-soft);margin:0}
.gc-translation-card .wc-copy>p{font-family:var(--font-display);font-size:clamp(1.08rem,1.45vw,1.32rem);line-height:1.2;color:#fff5df;margin:0;text-shadow:0 1px 10px rgba(0,0,0,.25)}
.cycle-mini{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}
.cycle-mini span{border:1px solid rgba(255,241,189,.34);border-radius:var(--r-pill);padding:.28rem .58rem;color:#fff1bd;background:rgba(8,9,12,.14);font-size:.68rem;line-height:1;font-weight:800;letter-spacing:.035em}
#seen-online{overflow:hidden;isolation:isolate}
#seen-online::before{content:"";position:absolute;inset:0;z-index:0;background:var(--grad-hero)}
#seen-online .wrap{position:relative;z-index:1;max-width:min(1680px,100%);overflow:clip}
#seen-online .seen-hook-layout{grid-template-columns:minmax(640px,1.25fr) minmax(410px,.75fr);gap:clamp(2rem,4vw,4.25rem);align-items:center}
.seen-montage{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;align-items:stretch;overflow:clip;contain:paint}
.seen-montage figure{position:relative;overflow:hidden;margin:0;aspect-ratio:16/10;min-height:clamp(220px,13vw,300px);border-radius:var(--r);border:1px solid var(--line-dark);background:rgba(255,255,255,.04);box-shadow:0 28px 90px -58px rgba(0,0,0,.95)}
.seen-montage figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,12,0) 42%,rgba(8,9,12,.78) 100%);pointer-events:none}
.seen-montage figure img{width:100%;height:100%;object-fit:cover;filter:saturate(.96) contrast(1.02)}
.seen-montage .method-label{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;padding:.72rem .78rem .68rem;border:1px solid rgba(234,206,130,.22);border-radius:calc(var(--r) - 4px);background:linear-gradient(180deg,rgba(8,9,12,.34),rgba(8,9,12,.82));backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.seen-montage .method-label b{display:block;color:var(--on-dark);font-size:.8rem;line-height:1.14;letter-spacing:.08em;text-transform:uppercase}
.seen-montage .method-label span{display:block;margin-top:.26rem;color:var(--gold-1);font-size:.77rem;line-height:1.2;font-weight:700;letter-spacing:.03em}
.seen-montage .rep-tag{top:12px;bottom:auto;left:12px;z-index:3;font-size:.58rem;padding:.26rem .58rem}
.model-video-feature{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr);gap:clamp(1.2rem,3vw,2rem);align-items:center;margin-top:clamp(2rem,4vw,3rem);padding:clamp(1rem,2vw,1.35rem);border:1px solid var(--line-dark);border-radius:var(--r-lg);background:rgba(255,255,255,.04);box-shadow:var(--sh-dark)}
.model-video-feature figure{position:relative;margin:0;border-radius:calc(var(--r-lg) - 6px);overflow:hidden;background:#08090c;border:1px solid rgba(234,206,130,.22)}
.model-video-feature video{width:100%;height:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.model-video-feature h3{font-size:clamp(1.35rem,2.6vw,2rem);margin-bottom:.35rem;color:var(--on-dark)}
.model-video-feature p{color:var(--on-dark-soft)}
.human-broll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.human-broll-card{position:relative;overflow:hidden;border-radius:var(--r-lg);background:var(--ink-900);box-shadow:var(--sh-1)}
.human-broll-card figure{position:relative;margin:0;aspect-ratio:4/5}
.human-broll-card img{width:100%;height:100%;object-fit:cover}
.human-broll-card .hb-copy{position:absolute;left:0;right:0;bottom:0;padding:2.5rem 1rem .95rem;color:var(--on-dark);background:linear-gradient(180deg,transparent,rgba(8,9,12,.86))}
.human-broll-card b{display:block;font-size:.92rem;line-height:1.25}
.human-broll-card span{display:block;margin-top:.18rem;color:var(--on-dark-mut);font-size:.78rem}
.human-broll-card .rep-tag{top:12px;bottom:auto;left:12px;font-size:.58rem;padding:.26rem .58rem}
@media(max-width:1180px){#seen-online .seen-hook-layout{grid-template-columns:1fr;gap:2.5rem}#seen-online .seen-montage{max-width:960px;margin-inline:auto}.translation-showcase{grid-template-columns:1fr;max-width:780px;margin-inline:auto}.world-card,.gc-translation-card{height:auto;min-height:auto;grid-template-rows:auto minmax(250px,auto) auto}.world-card figure,.merge-visual{min-height:250px}}
@media(max-width:1050px){.model-video-feature{grid-template-columns:1fr}.human-broll-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.seen-montage figure{min-height:164px}}
@media(max-width:680px){.seen-montage{grid-template-columns:1fr}.seen-montage figure{min-height:218px}.human-broll-grid{grid-template-columns:1fr}.world-card figure,.merge-visual{min-height:220px}.world-card .wc-body,.gc-translation-card .wc-body{grid-template-columns:1fr}.world-icon{width:50px;height:50px}.world-icon svg{width:25px;height:25px}.world-card__strip{font-size:.66rem;letter-spacing:.11em;min-height:32px;padding:.44rem .7rem}}
@media(min-width:1500px){#seen-online::after{content:"";position:absolute;top:0;right:0;bottom:0;z-index:2;width:clamp(100px,7vw,150px);pointer-events:none;background:linear-gradient(90deg,rgba(12,13,16,0),#0c0d10 42%,#0c0d10)}}

/* Program vision band */
.prog-vision{display:grid;gap:.5rem;max-width:22ch}
.prog-vision .ln{font-family:var(--font-display);font-size:clamp(1.6rem,3.6vw,2.6rem);line-height:1.14;letter-spacing:var(--tr-display);font-weight:480}

/* ============================================================
   PREMIUM NAV CONDENSE + SERVICES MEGA-MENU
   ============================================================ */
.site-header .bar{position:relative}
.site-header .nav{gap:clamp(.15rem,.55vw,.7rem);flex:1 1 auto;min-width:0;justify-content:flex-end}
.site-header .nav>a,.site-header .nav .has-sub>a{font-size:.8rem;white-space:nowrap;letter-spacing:-.005em}
.site-header .nav .has-sub>a svg{margin-left:1px!important}
.site-header .header-cta .btn{padding:.55rem .9rem;font-size:.82rem}
/* tight desktop band: monogram-only brand + rely on floating Book rail, so all 10 items fit */
@media (max-width:1440px){.site-header .brand .bt{display:none}}
@media (max-width:1320px){.site-header .header-cta .btn{display:none}}
.nav .has-mega{position:static}
.nav .has-mega::after{content:"";position:absolute;left:0;right:0;top:100%;height:14px}
.nav .megamenu{position:absolute;left:0;right:0;top:calc(100% + 8px);background:color-mix(in srgb,var(--ink-900) 97%,transparent);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border:1px solid rgba(201,162,75,.26);border-radius:var(--r-lg);box-shadow:var(--sh-dark);padding:1.7rem 1.9rem;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),visibility var(--dur-fast);z-index:var(--z-drawer)}
.nav .megamenu::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--grad-gold);border-radius:var(--r-lg) var(--r-lg) 0 0}
.nav .has-mega:hover .megamenu,.nav .has-mega:focus-within .megamenu{opacity:1;visibility:visible;transform:translateY(0)}
.mm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.mm-col{min-width:0}
.mm-h{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-1);font-weight:700;padding-bottom:.55rem;margin-bottom:.45rem;border-bottom:1px solid var(--line-dark-soft)}
.nav .megamenu a{display:block;padding:.5rem .55rem;border-radius:10px;color:var(--on-dark);font-size:.9rem;font-weight:500;line-height:1.25}
.nav .megamenu a::after{display:none}
.nav .megamenu a small{display:block;color:var(--on-dark-mut);font-weight:400;font-size:.74rem;margin-top:2px;line-height:1.35}
.nav .megamenu a:hover{background:rgba(201,162,75,.1);color:var(--gold-1)}
.mm-foot{display:flex;align-items:center;gap:1.1rem;margin-top:1.5rem;padding-top:1.15rem;border-top:1px solid var(--line-dark-soft);flex-wrap:wrap}
.mm-foot span{color:var(--on-dark-soft);font-size:.9rem}
.mm-foot .textlink{color:var(--gold-1);margin-left:auto}
@media(max-width:1240px){.mm-grid{grid-template-columns:repeat(2,1fr);gap:1.2rem 2rem}}

/* drawer group headings (mega flattened to accordion-style groups) */
.drawer .dr-h{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-1);font-weight:700;margin:.9rem 0 .15rem;padding-left:1rem}

/* ===== Services page — pathway cards + funding/service detail ===== */
.pathway.lg{min-height:340px}
.svc .price,.fund-card .price{font-family:var(--font-display);color:var(--wood-2);font-size:1.1rem;margin:.25rem 0 .55rem}
.svc .price small,.fund-card .price small{font-family:var(--font-sans);color:var(--text-mut);font-size:.8rem;font-weight:400}
.fund-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem 1.6rem;box-shadow:var(--sh-1);height:100%}
.fund-card h3{font-size:1.14rem;margin-bottom:.3rem}
.fund-card p{color:var(--text-soft);font-size:.92rem}
.fund-card .tagline{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:600;margin-bottom:.5rem}

/* ============================================================
   CARE PATHWAY SYSTEM — Find My Pathway · VIP · Method
   ============================================================ */
/* keep 10-item nav + 2 header CTAs fitting: hide secondary CTA on tighter desktop */
@media (max-width:1500px){.site-header .header-cta .hide-tight{display:none}}

/* pathway cards (services overview) */
.pcard{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem 1.7rem 1.8rem;box-shadow:var(--sh-1);height:100%;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
.pcard .tagline{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.pcard h3{font-size:1.28rem;margin:.35rem 0 .2rem}
.pcard .sub{color:var(--text-mut);font-size:.9rem;margin-bottom:.7rem}
.pcard p{color:var(--text-soft);font-size:.93rem}
.pcard ul{list-style:none;margin:.8rem 0 1.1rem;display:grid;gap:.35rem}
.pcard ul li{font-size:.88rem;color:var(--text-soft);padding-left:1.3rem;position:relative}
.pcard ul li::before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.pcard .cta-row{margin-top:auto;display:flex;flex-wrap:wrap;gap:.6rem}
.pcard.vip{background:var(--grad-hero);border-color:rgba(201,162,75,.3);color:var(--on-dark)}
.pcard.vip h3,.pcard.vip .tagline{color:var(--gold-1)}
.pcard.vip p,.pcard.vip ul li{color:var(--on-dark-soft)}
.pcard.vip ul li::before{background:var(--gold-1)}

/* suburb chips */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}
.chip{padding:.5rem 1rem;border-radius:var(--r-pill);background:rgba(201,162,75,.1);border:1px solid rgba(201,162,75,.3);color:var(--wood-2);font-size:.9rem;font-weight:500}

/* Find My Pathway stepper */
.fmp{max-width:780px;margin-inline:auto}
.fmp .steps{display:flex;gap:.4rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.fmp .steps .s{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--text-mut)}
.fmp .steps .s .n{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);font-weight:700;background:var(--paper)}
.fmp .steps .s.active .n{background:var(--grad-gold);color:#2A1E05;border-color:transparent}
.fmp .steps .s.done .n{background:var(--gold-2);color:#fff;border-color:transparent}
.fmp-step{display:none}
.fmp-step.active{display:block;animation:fmpIn .45s var(--ease-out)}
@keyframes fmpIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.fmp-step h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:1.2rem}
.opt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:.7rem}
.opt{display:flex;align-items:center;gap:.7rem;padding:.95rem 1.1rem;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast);font-size:.95rem}
.opt:hover{border-color:var(--gold)}
.opt:has(input:checked){border-color:var(--gold);background:rgba(201,162,75,.09);box-shadow:0 0 0 1px var(--gold)}
.opt input{accent-color:var(--gold-2);width:18px;height:18px;flex-shrink:0}
.fmp-nav{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;gap:1rem}
.route-hint{margin-top:1.5rem;padding:1.3rem 1.5rem;border-radius:var(--r);background:rgba(201,162,75,.09);border:1px solid rgba(201,162,75,.32);color:var(--wood-2);display:none}
.route-hint.show{display:block}
.route-hint b{color:var(--gold-2)}

/* ============================================================
   SERVICE AREA — map, postcode zones and footer service cue
   ============================================================ */
.service-area-hero::after{background:
  linear-gradient(95deg,rgba(8,9,12,.90) 0%,rgba(8,9,12,.68) 44%,rgba(8,9,12,.28) 100%),
  radial-gradient(80% 90% at 82% 18%,rgba(201,162,75,.24),transparent 60%)}
.service-strip{background:var(--ink-900);border-top:1px solid var(--line-dark-soft);border-bottom:1px solid var(--line-dark-soft);color:var(--on-dark)}
.service-strip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-dark-soft)}
.service-strip-grid span{display:block;background:var(--ink-900);padding:1.05rem 1.2rem;color:var(--on-dark-soft);font-size:.93rem}
.service-strip-grid b{color:var(--gold-1);font-weight:700;margin-right:.35rem}
.service-map-layout{grid-template-columns:.82fr 1.18fr}
.zone-legend{display:grid;gap:.7rem}
.zone-legend span{display:flex;align-items:center;gap:.7rem;color:var(--on-dark-soft);font-size:.94rem}
.zone-legend i{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;box-shadow:0 0 0 6px rgba(255,255,255,.03)}
.zone-legend .core{color:var(--gold-1)}
.zone-legend .extended{color:var(--silver-1)}
.zone-legend .selective{color:#B7A27B}
.gc-map-card{position:relative;border:1px solid rgba(234,206,130,.28);border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(160deg,#15171D 0%,#0B0C10 100%);box-shadow:var(--sh-dark)}
.gc-map{position:relative;min-height:620px;isolation:isolate;overflow:hidden}
.map-land{position:absolute;inset:0 18% 0 0;background:
  linear-gradient(115deg,rgba(234,206,130,.10) 0%,rgba(234,206,130,.03) 42%,rgba(255,255,255,.035) 100%),
  repeating-linear-gradient(24deg,rgba(255,255,255,.03) 0 1px,transparent 1px 28px);clip-path:polygon(0 0,73% 0,62% 18%,70% 34%,58% 52%,63% 71%,48% 100%,0 100%);z-index:-2}
.map-water{position:absolute;inset:0 0 0 auto;width:44%;background:
  linear-gradient(180deg,rgba(42,95,116,.32),rgba(25,50,65,.18)),
  repeating-linear-gradient(165deg,rgba(255,255,255,.10) 0 1px,transparent 1px 24px);z-index:-3}
.map-water span{position:absolute;right:7%;top:7%;color:rgba(232,235,239,.58);font-family:var(--font-display);font-size:1.15rem;line-height:1.25;text-align:right}
.map-route{position:absolute;left:47%;top:5%;bottom:6%;width:9px;border-radius:20px;background:linear-gradient(180deg,rgba(234,206,130,.22),rgba(234,206,130,.70),rgba(234,206,130,.18));box-shadow:0 0 28px rgba(234,206,130,.18);transform:rotate(5deg)}
.map-route::before,.map-route::after{content:"";position:absolute;inset:0;border-radius:20px;border-left:1px solid rgba(255,255,255,.26);transform:translateX(-12px)}
.map-route::after{transform:translateX(12px)}
.map-route span{position:absolute;left:22px;top:47%;white-space:nowrap;color:rgba(234,206,130,.74);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;transform:rotate(-5deg)}
.map-pin{position:absolute;z-index:2;display:grid;grid-template-columns:auto minmax(0,1fr);gap:.5rem .65rem;align-items:center;max-width:min(268px,44%);padding:.64rem .75rem;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:rgba(12,13,16,.74);color:var(--on-dark);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 18px 40px -24px rgba(0,0,0,.85)}
.map-pin::before{content:"";position:absolute;left:19px;bottom:-7px;width:14px;height:14px;transform:rotate(45deg);border-right:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18);background:inherit}
.map-pin strong{position:relative;z-index:1;display:grid;place-items:center;min-width:52px;height:32px;border-radius:10px;font-family:var(--font-sans);font-size:.82rem;letter-spacing:.08em}
.map-pin span{position:relative;z-index:1;color:var(--on-dark-soft);font-size:.78rem;line-height:1.28}
.map-pin.core{border-color:rgba(234,206,130,.52)}
.map-pin.core strong{background:var(--grad-gold);color:#2A1E05}
.map-pin.extended{border-color:rgba(232,235,239,.34)}
.map-pin.extended strong{background:var(--grad-silver);color:#20232A}
.map-pin.selective{border-color:rgba(183,162,123,.45)}
.map-pin.selective strong{background:linear-gradient(135deg,#D0C0A0,#8E7552);color:#21170C}
.p4207{left:48%;top:8%}
.p4209{left:51%;top:22%}
.p4210{left:30%;top:38%}
.p4211{left:23%;top:54%}
.p4212{left:56%;top:48%}
.p4214{left:37%;top:70%}
.p4101{left:11%;top:7%;max-width:236px}
.zone-grid{display:grid;grid-template-columns:1.15fr 1fr .9fr;gap:1.2rem}
.zone-card{position:relative;display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.75rem;box-shadow:var(--sh-1);overflow:hidden}
.zone-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--grad-silver)}
.zone-card.primary-zone::before{background:var(--grad-gold)}
.zone-card.selective-zone::before{background:linear-gradient(90deg,#8E7552,#D0C0A0)}
.zone-card .tagline{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:700;margin-bottom:.4rem}
.zone-card h3{font-size:1.45rem;margin-bottom:.15rem}
.zone-card .sub{color:var(--text-soft);font-size:.94rem}
.postcode-list{display:grid;gap:.7rem;margin-top:1.2rem}
.postcode-list div{display:grid;grid-template-columns:74px 1fr;gap:.8rem;align-items:center;padding:.85rem .9rem;border:1px solid var(--line-soft);border-radius:var(--r-sm);background:var(--pearl-2)}
.postcode-list b{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-2);line-height:1}
.postcode-list span{color:var(--text-soft);font-size:.92rem;line-height:1.4}
.mini-note{margin-top:auto;padding-top:1rem;color:var(--text-mut);font-size:.86rem;line-height:1.5}
.service-area-cta{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;padding:clamp(1.6rem,3.2vw,2.3rem);border-radius:var(--r-lg);background:var(--grad-hero);color:var(--on-dark);box-shadow:var(--sh-dark);overflow:hidden}
.service-area-cta h2{color:var(--on-dark)}
.service-area-cta .lead{color:var(--on-dark-soft);max-width:62ch}
.service-area-cta .eyebrow{color:var(--gold-1)}
.service-area-cta .btn-row{justify-content:flex-end}
@media(max-width:1000px){
  .service-map-layout,.zone-grid,.service-area-cta{grid-template-columns:1fr}
  .service-strip-grid{grid-template-columns:1fr}
  .service-area-cta .btn-row{justify-content:flex-start}
}
@media(max-width:680px){
  .service-area-hero{padding-block:8rem 2.75rem}
  .service-area-hero .lead{font-size:1rem;line-height:1.48}
  .service-area-hero .btn-row{gap:.65rem;margin-top:1.15rem}
  .gc-map{min-height:700px}
  .map-water{width:38%}
  .map-route{left:41%}
  .map-pin{max-width:72%;grid-template-columns:1fr;padding:.58rem .65rem}
  .map-pin strong{min-width:0;width:max-content;min-height:30px;padding:0 .65rem}
  .map-pin::before{display:none}
  .p4101{left:6%;top:5%}
  .p4207{left:41%;top:15%}
  .p4209{left:19%;top:27%}
  .p4210{left:32%;top:42%}
  .p4211{left:8%;top:55%}
  .p4212{left:30%;top:68%}
  .p4214{left:12%;top:81%}
  .postcode-list div{grid-template-columns:1fr;gap:.35rem}
}

/* method six-stage rail */
.stage-row{display:grid;gap:.8rem}
.stage{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start;padding:1.1rem 1.3rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1)}
.stage .sn{font-family:var(--font-display);font-size:1.5rem;line-height:1;color:var(--gold-2);min-width:2.2ch}
.stage h3{font-size:1.1rem;margin-bottom:.15rem}
.stage p{color:var(--text-soft);font-size:.92rem}
.panel-dark .stage{background:rgba(255,255,255,.035);border-color:var(--line-dark)}
.panel-dark .stage h3{color:var(--on-dark)}.panel-dark .stage p{color:var(--on-dark-soft)}
.flow-line{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:center;font-family:var(--font-display);font-size:clamp(1.1rem,2.2vw,1.6rem);color:var(--gold-1)}
.flow-line span{opacity:.5}

/* ============================================================
   CTA VISIBILITY — ghost buttons on hero / dark / header
   gold outline + glass so "Refer a Patient/Client" read on imagery
   ============================================================ */
.hero .btn--ghost,.page-hero .btn--ghost,.panel-dark .btn--ghost,.panel-wood .btn--ghost{
  border-color:rgba(234,206,130,.62);color:var(--on-dark);
  background:rgba(12,13,16,.30);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  box-shadow:0 3px 14px -4px rgba(0,0,0,.30)}
.hero .btn--ghost:hover,.page-hero .btn--ghost:hover,.panel-dark .btn--ghost:hover,.panel-wood .btn--ghost:hover{
  border-color:var(--gold-1);color:#2A1E05;background:var(--grad-gold);box-shadow:var(--sh-gold)}
/* Header "Refer a Client" — visible over hero AND when scrolled */
.site-header .header-cta .btn--ghost{
  border-color:rgba(234,206,130,.7);color:var(--on-dark);
  background:rgba(12,13,16,.34);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);
  box-shadow:0 2px 10px -2px rgba(0,0,0,.28)}
.site-header.scrolled .header-cta .btn--ghost{
  background:rgba(255,255,255,.05);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}
.site-header .header-cta .btn--ghost:hover{
  border-color:var(--gold-1);color:#2A1E05;background:var(--grad-gold);box-shadow:var(--sh-gold)}

/* representative-image badge on photo heroes (legal/AHPRA) */
.page-hero:has(.ph-bg){position:relative}
.page-hero:has(.ph-bg)::before,.hero::before{content:"\793a\610f\5716 \b7 Representative image";position:absolute;right:clamp(14px,3vw,32px);bottom:14px;z-index:3;font-family:var(--font-sans);font-size:.6rem;letter-spacing:.06em;color:rgba(255,255,255,.92);background:rgba(8,9,12,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.28rem .7rem;pointer-events:none}
/* rep-hero-badge */

/* community list + consent checkboxes (neighbourhood-practice) */
.bullets{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.bullets li{position:relative;padding-left:1.5rem;color:var(--text)}
.bullets li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;border-radius:50%;background:var(--gold-1)}
.check{display:flex;align-items:flex-start;gap:.6rem;font-size:.92rem;color:var(--text);line-height:1.5;cursor:pointer}
.check input[type=checkbox]{margin-top:.2rem;width:18px;height:18px;flex:0 0 auto;accent-color:var(--gold-1)}
