/* ============================================================
   Synchronous — Scroll motion study
   Dark, cinematic, bold. Apple-style pin + scrub.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&family=Montserrat:wght@400;500;600;700&family=Hanken+Grotesk:wght@400;500;600;700&family=Onest:wght@400;500;600;700&display=swap');

:root{
  --bg:#08080b;
  --bg2:#101016;
  --bg3:#16161d;
  --fg:#f5f4ef;
  --muted:#8f8c85;
  --line:#26262e;
  --accent: oklch(0.66 0.17 256);     /* electric ink-blue */
  --accent-2: color-mix(in oklab, var(--accent) 16%, transparent);
  --eyebrow:#b9b4a9;                   /* neutral kicker colour (no more blue) */
  --grn: oklch(0.74 0.14 150);
  --amb: oklch(0.80 0.13 78);
  --disp:'Space Grotesk', system-ui, sans-serif;
  --mono: var(--disp);                /* labels follow the chosen main font (not monospace) */
}

*{ box-sizing:border-box; }
html{ scroll-behavior:auto; }
body{
  margin:0; background:var(--bg); color:var(--fg);
  font-family:var(--disp); -webkit-font-smoothing:antialiased;
}

/* ---- top progress + nav ---- */
.progress{ position:fixed; top:0; left:0; height:2px; width:100%; transform-origin:0 50%; transform:scaleX(0); background:var(--accent); z-index:100; }
.nav{
  position:fixed; top:0; left:0; right:0; z-index:90;
  display:flex; align-items:center; gap:14px;
  padding:16px 28px;
  backdrop-filter:blur(14px); background:rgba(8,8,11,.55);
  border-bottom:1px solid transparent; transition:border-color .3s;
}
.nav.scrolled{ border-color:var(--line); }
.nav .brand{ font-weight:700; font-size:18px; letter-spacing:.3px; display:flex; align-items:center; gap:9px; }
.nav .blip{ width:12px;height:12px;border-radius:50%;border:2.5px solid var(--fg); position:relative; }
.nav .blip::after{ content:""; position:absolute; inset:2px; border-radius:50%; background:var(--accent); }
.nav .logomark{ width:25px; height:25px; flex:0 0 auto; color:var(--fg); }
.nav .links{ display:flex; gap:22px; margin-left:8px; }
.nav .links span{ font-size:13.5px; color:var(--muted); font-weight:500; }
.nav .sp{ flex:1; }
.nav .cta{
  font-size:13.5px; font-weight:600; padding:9px 18px; border-radius:100px;
  background:var(--fg); color:var(--bg); white-space:nowrap; text-decoration:none;
}

/* ---- scene / pin primitives ---- */
.scene{ position:relative; }
.pin{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  padding:0 28px;
}
.wrap{ width:100%; max-width:1180px; margin:0 auto; }

/* eyebrow */
.eyebrow{
  font-family:var(--disp); font-weight:600; font-size:13px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--eyebrow); margin:0 0 22px;
}
.eyebrow.muted{ color:var(--muted); }

/* big display type */
.display{
  font-weight:700; letter-spacing:-.02em; line-height:.96; margin:0;
  font-size:clamp(46px, 9vw, 132px);
}
.h2{ font-weight:700; letter-spacing:-.015em; line-height:1.0; margin:0; font-size:clamp(32px,5.4vw,72px); }
.lede{ font-size:clamp(17px,2vw,23px); color:var(--muted); line-height:1.45; font-weight:400; max-width:30ch; }
.accent{ color:var(--accent); }

/* ============ SCENE A — HERO ============ */
.hero-inner{ text-align:center; will-change:transform,opacity; }
.hero-inner .display{ line-height:1.06; transform:scale(calc(1 + var(--p)*0.18)); opacity:calc(1 - var(--p)*0.5); }
.hero-eyebrow{ opacity:calc(1 - var(--p)*2.4); transform:translateY(calc(var(--p)*-26px)); }
.hero-lede{ margin:26px auto 0; opacity:calc(1 - var(--p)*2.4); transform:translateY(calc(var(--p)*30px)); }
.scrollcue{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:11px; letter-spacing:2px; color:var(--muted);
  opacity:calc(1 - var(--p)*3); display:flex; flex-direction:column; align-items:center; gap:9px;
}
.scrollcue .bar{ width:1px; height:34px; background:linear-gradient(var(--muted), transparent); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%{ transform:scaleY(.3); transform-origin:top; } 50%{ transform:scaleY(1);} 100%{ transform:scaleY(.3); transform-origin:bottom;} }
.hero-glow{
  position:absolute; top:50%; left:50%; width:120vw; height:120vw;
  transform:translate(-50%,-50%) scale(calc(0.6 + var(--p)*0.8));
  background:radial-gradient(circle, var(--accent-2), transparent 55%);
  opacity:calc(0.5 + var(--p)*0.5); pointer-events:none;
}

/* ============ SCENE B — PROMISE ============ */
.promise{ text-align:left; }
.promise .l1,.promise .l2{ display:block; transition:none; }
.promise .l1{ opacity:calc(0.18 + var(--p)*1.6); transform:translateY(calc((1 - var(--p))*26px)); }
.promise .l2{ opacity:calc((var(--p) - 0.38)*2.4); transform:translateY(calc((1 - var(--p))*40px)); }
.promise-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin:46px auto 0; max-width:920px; }
.pcard{
  border:1px solid var(--line); border-radius:16px; padding:24px; background:var(--bg2);
  opacity:calc((var(--p) - 0.55)*3); transform:translateY(calc((1 - var(--p))*30px));
}
.pcard h4{ margin:0 0 10px; font-size:19px; font-weight:600; }
.pcard p{ margin:0; color:var(--muted); font-size:15px; line-height:1.5; }

/* ============ SCENE C — MEDIA ZOOM ============ */
.zoom-stage{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.zoom-media{
  position:relative; width:100%; height:100%;
  transform:scale(calc(0.52 + var(--p)*0.48));
  border-radius:calc(34px - var(--p)*34px); overflow:hidden;
  background:
    repeating-linear-gradient(-45deg, transparent 0 16px, rgba(255,255,255,.05) 16px 17px),
    linear-gradient(160deg,#2a2a37,#14141c);
  display:flex; align-items:flex-end;
}
.zoom-media .mlabel{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--mono); font-size:12px; letter-spacing:1px; color:var(--muted);
  border:1px dashed var(--line); border-radius:8px; padding:6px 13px;
  opacity:calc(1 - var(--p)*0.7);
}
.zoom-cap{
  position:relative; z-index:2; padding:48px; max-width:760px;
  opacity:calc((var(--p) - 0.55)*3); transform:translateY(calc((1 - var(--p))*24px));
}
.zoom-cap .display{ font-size:clamp(30px,5vw,68px); }
.zoom-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 45%, rgba(0,0,0,.6)); opacity:var(--p); }

/* ============ SCENE D — HORIZONTAL CAPABILITIES ============ */
.htrack-pin{ position:sticky; top:0; height:100vh; overflow:hidden; display:flex; flex-direction:column; justify-content:center; }
.htrack-head{ padding:0 28px 26px; max-width:1180px; margin:0 auto; width:100%; }
.htrack{
  display:flex; gap:20px; padding:0 28px; will-change:transform;
  transform:translateX(calc(var(--p) * var(--shift, 0px)));
}
.cap-card{
  flex:0 0 300px; height:340px; border-radius:20px; border:1px solid var(--line);
  background:var(--bg2); padding:26px; display:flex; flex-direction:column; justify-content:space-between;
  position:relative;
}
.cap-card .cn{ font-family:var(--mono); font-size:13px; color:var(--muted); }
.cap-card .ct{ font-size:27px; font-weight:700; line-height:1.04; letter-spacing:-.01em; }
.cap-card .cstat{ display:inline-flex; align-items:center; gap:9px; font-size:13px; color:var(--muted); }
.cap-card .dot{ width:11px;height:11px;border-radius:50%; border:1.5px solid var(--muted); }
.cap-card .dot.g{ background:var(--grn); border-color:var(--grn); }
.cap-card .dot.a{ background:var(--amb); border-color:var(--amb); }
.cap-card.intro{ flex:0 0 360px; background:transparent; border:none; padding:26px 26px 26px 0; justify-content:center; }
.cap-card.intro .eyebrow{ margin-bottom:16px; }
.cap-card.divider{ flex:0 0 300px; background:linear-gradient(160deg,var(--accent),oklch(0.5 0.16 262)); border:none; color:#fff; }
.cap-card.divider .ct{ font-size:34px; }
.cap-card.divider .cn{ color:rgba(255,255,255,.7); }

/* ============ SCENE E — VISION ============ */
.vision-pin{ position:sticky; top:0; height:100vh; display:flex; align-items:center; }
.vline-track{ position:relative; margin-top:54px; }
.vline-base{ height:2px; background:var(--line); width:100%; }
.vline-fill{ height:2px; background:var(--accent); width:100%; position:absolute; top:0; left:0; transform-origin:0 50%; transform:scaleX(var(--p)); }
.vsteps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:30px; }
.vstep .vk{ font-family:var(--mono); font-size:12px; letter-spacing:2px; color:var(--muted); display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.vstep .vk .dot{ width:11px;height:11px;border-radius:50%;border:1.5px solid var(--muted); }
.vstep.on .vk{ color:var(--fg); }
.vstep.on .vk .dot{ background:var(--accent); border-color:var(--accent); }
.vstep h4{ margin:0 0 8px; font-size:21px; font-weight:600; }
.vstep p{ margin:0; color:var(--muted); font-size:15px; line-height:1.5; }

/* ============ SCENE F — PROOF + CTA ============ */
.proof{ padding:120px 28px; }
.metrics{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:30px; max-width:1180px; margin:0 auto 90px; }
.metric .num{ font-size:clamp(38px,4.8vw,68px); font-weight:700; letter-spacing:-.03em; line-height:.9; white-space:nowrap; }
.metric .cap{ font-family:var(--mono); font-size:12px; letter-spacing:1px; color:var(--muted); margin-top:12px; text-transform:uppercase; }
.logos{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:24px; max-width:1180px; margin:0 auto; align-items:center; }
.logo-tile{ height:64px; display:flex; align-items:center; justify-content:center; opacity:.82; transition:opacity .25s; }
.logo-tile:hover{ opacity:1; }
.logo-tile img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; }
.logobox{ height:70px; border:1px solid var(--line); border-radius:12px; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:11px; color:var(--muted); }

.cta{ text-align:center; padding:130px 28px 150px; position:relative; overflow:hidden; }
.cta .display{ position:relative; z-index:2; }
#ctaHead{ transition:opacity .4s ease; min-height:2.95em; display:flex; align-items:center; justify-content:center; }
.cta .btn{ position:relative; z-index:2; display:inline-flex; margin-top:34px; font-size:17px; font-weight:600; padding:16px 34px; border-radius:100px; background:var(--accent); color:#fff; text-decoration:none; }

/* ---- contact form ---- */
.cform{ position:relative; z-index:2; max-width:560px; margin:38px auto 0; text-align:left; }
.cform .frow{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cform .field{ margin-bottom:14px; }
.cform label{ display:block; font-size:13px; letter-spacing:.2px; color:var(--muted); margin:0 0 7px; }
.cform input, .cform textarea{
  width:100%; box-sizing:border-box; background:var(--bg2); color:var(--fg);
  border:1px solid var(--line); border-radius:12px; padding:13px 15px;
  font-family:inherit; font-size:15px; transition:border-color .2s, background .2s;
}
.cform input::placeholder, .cform textarea::placeholder{ color:#5c6072; }
.cform input:focus, .cform textarea:focus{ outline:none; border-color:var(--accent); background:var(--bg3); }
.cform textarea{ resize:vertical; min-height:110px; }
.cform .submit{
  width:100%; margin-top:6px; cursor:pointer; border:none;
  font-family:inherit; font-size:16px; font-weight:600; padding:15px;
  border-radius:100px; background:var(--accent); color:#fff; transition:opacity .2s, transform .1s;
}
.cform .submit:hover{ opacity:.92; }
.cform .submit:active{ transform:translateY(1px); }
.cform .formnote{ font-size:12.5px; color:var(--muted); margin:14px 2px 0; text-align:center; }
.cform-success{
  position:relative; z-index:2; max-width:560px; margin:38px auto 0;
  border:1px solid var(--accent); border-radius:18px; background:var(--bg2);
  padding:34px 28px; text-align:center; display:none;
}
.cform-success.show{ display:block; }
.cform-success .tick{ width:48px; height:48px; border-radius:50%; background:var(--accent); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.cform-success h3{ margin:0 0 8px; font-size:22px; font-weight:700; }
.cform-success p{ margin:0; color:var(--muted); font-size:15px; }
@media(max-width:560px){ .cform .frow{ grid-template-columns:1fr; gap:0; } }
.cta-glow{ position:absolute; bottom:-40%; left:50%; transform:translateX(-50%); width:90vw; height:90vw; background:radial-gradient(circle, var(--accent-2), transparent 55%); pointer-events:none; }

.foot{ padding:40px 28px; border-top:1px solid var(--line); display:flex; gap:22px; flex-wrap:wrap; align-items:center; font-family:var(--mono); font-size:12px; color:var(--muted); }
.foot .sp{ flex:1; }
.foot .foot-brand{ display:inline-flex; align-items:center; gap:9px; color:var(--fg); }
.foot .logomark{ width:20px; height:20px; flex:0 0 auto; }

/* ---- media zoom image slot ---- */
.zoom-img{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }

/* ---- sectors section ---- */
.sectors{ padding:120px 28px; max-width:1180px; margin:0 auto; }
.sectors-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:40px; }
.sectors-head .h2{ max-width:16ch; }
.sector-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; }
.sector-card{ border:1px solid var(--line); border-radius:20px; overflow:hidden; background:var(--bg2); }
.sector-card image-slot{ display:block; width:100%; height:230px; }
.sector-card .sbody{ padding:22px 22px 24px; }
.sector-card .ct{ font-size:23px; font-weight:700; letter-spacing:-.01em; margin-bottom:12px; display:block; line-height:1.05; }
.sector-card .cstat{ display:inline-flex; align-items:center; gap:9px; font-size:13px; color:var(--muted); }
.sector-card .dot{ width:11px;height:11px;border-radius:50%;background:var(--grn);border:1.5px solid var(--grn); }

/* ---- roadmap chips ---- */
.roadmap{ margin-top:48px; }
.roadmap .rk{ font-family:var(--mono); font-size:12px; letter-spacing:2px; color:var(--muted); margin-bottom:16px; display:flex; align-items:center; gap:9px; }
.roadmap .rk .dot{ width:11px;height:11px;border-radius:50%;border:1.5px solid var(--muted); }
.chips{ display:flex; flex-wrap:wrap; gap:12px; margin-top:8px; }
.chip{ border:1px solid var(--line); border-radius:100px; padding:12px 20px; font-size:16px; font-weight:500; color:var(--fg); background:var(--bg2); display:inline-flex; align-items:center; gap:10px; transition:transform .2s, border-color .2s; cursor:default; }
.chip::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--accent); flex:0 0 auto; }
.chip:hover{ border-color:var(--accent); transform:translateY(-2px); }

/* ---- logo slots ---- */
.logos image-slot{ display:block; width:100%; height:70px; }

/* ---- where we work (global) ---- */
.globe{ padding:120px 28px; max-width:1180px; margin:0 auto; }
.globe-head{ max-width:700px; margin-bottom:38px; }
.globe-head .lede{ margin-top:18px; max-width:46ch; }
.globe-canvas-wrap{ position:relative; width:100%; height:480px; margin-bottom:34px; }
.globe-canvas-wrap::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 46%, var(--accent-2), transparent 62%); pointer-events:none; }
#globe-canvas{ display:block; width:100%; height:100%; cursor:grab; touch-action:pan-y; position:relative; z-index:1; }
#globe-canvas:active{ cursor:grabbing; }
.globe-hint{ position:absolute; bottom:8px; left:50%; transform:translateX(-50%); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); pointer-events:none; z-index:2; }
@media (max-width:600px){ .globe-canvas-wrap{ height:360px; } }
.loc-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(228px,1fr)); gap:14px; }
.loc{ border:1px solid var(--line); border-radius:16px; padding:22px; background:var(--bg2); }
.loc .lname{ display:block; font-size:22px; font-weight:700; letter-spacing:-.01em; line-height:1.05; margin-bottom:10px; }
.loc .lmeta{ display:inline-flex; align-items:center; gap:9px; font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.loc .mk{ width:9px; height:9px; border-radius:50%; background:var(--accent); border:1.5px solid var(--accent); flex:0 0 auto; display:inline-block; }
.loc.open{ border-style:dashed; }
.loc.open .lname{ color:var(--muted); }
.loc.open .mk{ background:transparent; border-color:var(--muted); }
.loc.prev .mk{ background:transparent; border-color:var(--muted); }

/* ---- vision timeline (calm, un-pinned) ---- */
.vision{ padding:120px 28px; max-width:1180px; margin:0 auto; }
.vtimeline{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; position:relative; }
.vtimeline::before{ content:""; position:absolute; top:6px; left:2px; right:2px; height:2px; background:var(--line); }
.vfill{ position:absolute; top:6px; left:2px; height:2px; width:calc(100% - 4px); background:var(--accent); transform-origin:0 50%; transform:scaleX(var(--vfill,0)); }
.vnode{ position:relative; padding-top:30px; }
.vnode::before{ content:""; position:absolute; top:0; left:0; width:14px; height:14px; border-radius:50%; background:var(--line); border:3px solid var(--bg); transition:background .3s ease, box-shadow .3s ease; }
.vnode.on::before{ background:var(--accent); box-shadow:0 0 0 5px var(--accent-2); }
.vnode .vk{ font-size:12px; letter-spacing:2px; color:var(--muted); margin-bottom:12px; transition:color .3s ease; }
.vnode.on .vk{ color:var(--fg); }
.vnode h4{ margin:0 0 8px; font-size:21px; font-weight:600; }
.vnode p{ margin:0; color:var(--muted); font-size:15px; line-height:1.5; max-width:30ch; }
@media(max-width:760px){ .vtimeline{ grid-template-columns:1fr; gap:22px; } .vtimeline::before{ display:none; } }

/* ---- entrance reveals ---- */
[data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }

/* float note (study annotations) */
.studynote{
  position:fixed; bottom:18px; left:18px; z-index:80; max-width:300px;
  background:var(--bg3); border:1px solid var(--line); border-radius:12px;
  padding:13px 15px; font-size:13px; line-height:1.4; color:var(--muted);
  box-shadow:0 14px 40px rgba(0,0,0,.5);
}
.studynote b{ color:var(--fg); font-weight:600; }
.studynote .x{ position:absolute; top:8px; right:11px; cursor:pointer; color:var(--muted); font-family:var(--mono); }
.studynote.hidden{ display:none; }

@media (max-width:760px){
  .nav .links{ display:none; }
  .promise-cards,.vsteps{ grid-template-columns:1fr; }
  .cap-card{ flex-basis:74vw; }
  .cap-card.intro{ flex-basis:80vw; }
}

/* reduced motion: drop scrub + sticky, show final states */
@media (prefers-reduced-motion: reduce){
  .pin,.htrack-pin,.vision-pin{ position:relative; height:auto; padding-top:90px; padding-bottom:90px; }
  .hero-inner .display,.hero-eyebrow,.hero-lede,.promise .l1,.promise .l2,.pcard,.zoom-cap,.zoom-media .mlabel{ opacity:1 !important; transform:none !important; }
  .zoom-media{ transform:none !important; border-radius:20px !important; height:60vh; }
  .htrack{ flex-wrap:wrap; transform:none !important; }
  .vline-fill{ transform:scaleX(1); }
  [data-reveal]{ opacity:1; transform:none; }
}

/* ============================================================
   FONT CHOICES  (SF real on Apple; others are readable stand-ins
   until licensed files are supplied)
   ============================================================ */
body.font-sf      { --disp:-apple-system,"SF Pro Display","SF Pro Text",system-ui,sans-serif; }
body.font-gotham  { --disp:'Montserrat',system-ui,sans-serif; }
body.font-dublin  { --disp:'Hanken Grotesk',system-ui,sans-serif; }
body.font-rollbox { --disp:'Onest',system-ui,sans-serif; }

/* ============================================================
   COLOUR SCHEMES — all dark, calm, low-chroma accents
   ============================================================ */
body.scheme-bone  { --bg:#0b0b0c; --bg2:#141416; --bg3:#1a1a1d; --fg:#f3f1ec; --muted:#9a958c; --line:#27272c; --eyebrow:#b9b4a9; --accent:oklch(0.80 0.025 80); }
body.scheme-ember { --bg:#0c0b0a; --bg2:#161311; --bg3:#1c1815; --fg:#f4f1ea; --muted:#9c9389; --line:#2a2520; --eyebrow:#bcae9f; --accent:oklch(0.72 0.12 55); }
body.scheme-sage  { --bg:#0a0c0b; --bg2:#121613; --bg3:#181d19; --fg:#eef2ee; --muted:#929a92; --line:#242a25; --eyebrow:#aab3a8; --accent:oklch(0.74 0.075 150); }
body.scheme-royal { --bg:#0a0b10; --bg2:#13151f; --bg3:#181b28; --fg:#f1f2f6; --muted:#969aa8; --line:#242a3a; --eyebrow:#b6bac8; --accent:oklch(0.54 0.19 266); }

/* ============================================================
   STYLE CHOOSER (study control)
   ============================================================ */
.styler{
  position:fixed; right:18px; bottom:18px; z-index:96;
  background:var(--bg3); border:1px solid var(--line); border-radius:14px;
  padding:14px 15px; width:252px; box-shadow:0 18px 50px rgba(0,0,0,.55);
}
.styler h5{ margin:0 0 11px; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); font-family:var(--mono); }
.styler .grp{ margin-bottom:14px; }
.styler .grp:last-child{ margin-bottom:0; }
.styler .opts{ display:flex; gap:7px; flex-wrap:wrap; }
.sbtn{ font-size:13px; padding:7px 11px; border-radius:8px; border:1px solid var(--line); background:transparent; color:var(--fg); cursor:pointer; transition:.15s; }
.sbtn:hover{ border-color:var(--muted); }
.sbtn.on{ background:var(--fg); color:var(--bg); border-color:var(--fg); }
.swatch{ width:34px; height:34px; border-radius:9px; border:2px solid var(--line); cursor:pointer; padding:0; overflow:hidden; position:relative; }
.swatch.on{ border-color:var(--fg); }
.swatch i{ position:absolute; right:5px; bottom:5px; width:11px; height:11px; border-radius:50%; }
.styler .collapse{ position:absolute; top:11px; right:13px; cursor:pointer; color:var(--muted); font-family:var(--mono); font-size:13px; background:none; border:none; }
.styler.min .sbody{ display:none; }
.styler.min{ width:auto; padding-right:34px; }

@media (max-width:760px){
  .styler{ left:18px; width:auto; }
  .studynote{ display:none; }
}

/* ============================================================
   NAV ANCHORS · UK DRILL-DOWN · WORK / ABOUT / CONTACT
   ============================================================ */
.nav .links a{ font-size:13.5px; color:var(--muted); font-weight:500; text-decoration:none; transition:color .2s; }
.nav .links a:hover{ color:var(--fg); }

.loc.has-map{ cursor:pointer; transition:border-color .2s; }
.loc.has-map:hover{ border-color:var(--accent); }
.loc-cta{ display:block; margin-top:14px; font-size:13px; color:var(--accent); }

.uk-modal{ position:fixed; inset:0; z-index:120; background:rgba(0,0,0,.62); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:24px; }
.uk-modal.open{ display:flex; }
.uk-panel{ position:relative; width:min(680px,94vw); background:var(--bg2); border:1px solid var(--line); border-radius:20px; padding:26px; }
.uk-panel canvas{ display:block; width:100%; height:min(72vh,640px); }
.uk-close{ position:absolute; top:13px; right:15px; background:none; border:none; color:var(--muted); font-size:16px; cursor:pointer; line-height:1; }
.uk-note{ font-size:13px; color:var(--muted); margin:12px 0 0; }

.work{ padding:120px 28px; max-width:1180px; margin:0 auto; }
.work-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:20px; margin-top:44px; }
.case{ border:1px solid var(--line); border-radius:20px; overflow:hidden; background:var(--bg2); }
.case image-slot{ display:block; width:100%; height:200px; }
.case .cbody{ padding:24px; }
.case .ctag{ font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--accent); margin-bottom:12px; display:block; }
.case h4{ margin:0 0 12px; font-size:21px; font-weight:700; line-height:1.15; }
.case p{ margin:0; color:var(--muted); font-size:15px; line-height:1.5; }
.case .cmetric{ margin-top:16px; font-size:15px; color:var(--fg); font-weight:600; }

.about{ padding:120px 28px; max-width:1180px; margin:0 auto; }
.about-grid{ display:grid; grid-template-columns:1fr 1.25fr; gap:48px; align-items:center; margin-top:30px; }
.about image-slot{ display:block; width:100%; height:430px; border-radius:20px; }
.about h2{ margin:0 0 20px; }
.about p{ color:var(--muted); font-size:17px; line-height:1.6; margin:0 0 16px; max-width:48ch; }
.leadcredit{ display:flex; flex-direction:column; gap:2px; margin:4px 0 22px; padding-top:18px; border-top:1px solid var(--line); }
.leadcredit .lname{ font-size:18px; font-weight:700; color:var(--fg); }
.leadcredit .lrole{ font-size:14px; color:var(--muted); }
@media(max-width:760px){ .about-grid{ grid-template-columns:1fr; gap:24px; } .about image-slot{ height:300px; } }

.contact-detail{ margin-top:26px; font-size:15px; color:var(--muted); position:relative; z-index:2; }
.contact-detail b{ color:var(--fg); font-weight:600; }

/* ---- legal & compliance ---- */
.legal{ padding:90px 28px; max-width:1180px; margin:0 auto; border-top:1px solid var(--line); }
.legal-grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:48px; margin-top:28px; }
.legal h4{ font-size:13px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); margin:0 0 18px; font-weight:600; }
.accreds{ display:flex; flex-wrap:wrap; gap:10px; }
.accred{ display:inline-flex; align-items:center; gap:11px; border:1px solid var(--line); border-radius:10px; padding:10px 14px; font-size:14px; color:var(--fg); background:var(--bg2); }
.accred .aname{ font-weight:600; }
.accred .astatus{ font-size:10.5px; letter-spacing:.5px; text-transform:uppercase; display:inline-flex; align-items:center; gap:6px; color:var(--muted); }
.accred .astatus::before{ content:""; width:7px; height:7px; border-radius:50%; background:currentColor; flex:0 0 auto; }
.accred .astatus.done{ color:oklch(0.74 0.13 150); }
.accred .astatus.prog{ color:oklch(0.80 0.13 78); }
.accreds image-slot{ display:block; width:120px; height:74px; border:1px solid var(--line); border-radius:8px; }
.policy-list{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.policy-list li{ font-size:15px; color:var(--muted); border-bottom:1px solid var(--line); padding-bottom:12px; cursor:pointer; transition:color .2s; }
.policy-list li:hover{ color:var(--fg); }
.policy-list a{ color:inherit; text-decoration:none; display:block; }
.policy-list li:hover a{ color:var(--fg); }
.legal-reg{ margin-top:40px; font-size:13px; color:var(--muted); line-height:1.6; }
@media(max-width:760px){ .legal-grid{ grid-template-columns:1fr; gap:28px; } }

/* ---- careers ---- */
.careers{ padding:120px 28px; max-width:1180px; margin:0 auto; border-top:1px solid var(--line); }
.careers-grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:48px; align-items:center; }
.careers image-slot{ display:block; width:100%; height:380px; border-radius:20px; }
.careers h2{ margin:0 0 18px; }
.careers p{ color:var(--muted); font-size:17px; line-height:1.6; margin:0 0 16px; max-width:46ch; }
.careers-cta{ display:inline-block; margin-top:10px; font-size:16px; font-weight:600; color:var(--accent); text-decoration:none; }
.pagelink{ display:inline-block; margin-top:22px; font-size:15px; font-weight:600; color:var(--accent); text-decoration:none; }
.pagelink:hover{ opacity:.8; }
.foot-links a{ color:inherit; text-decoration:none; }
.foot-links a:hover{ color:var(--fg); }
@media(max-width:760px){ .careers-grid{ grid-template-columns:1fr; gap:24px; } .careers image-slot{ height:280px; } }

/* ============================================================
   RESPONSIVE — mobile nav + phone / tablet scaling
   ============================================================ */
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; flex-direction:column; gap:5px; padding:8px; margin-left:auto; }
.nav-toggle span{ display:block; width:22px; height:2px; background:var(--fg); transition:transform .25s, opacity .2s; }
.nav.open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.open .nav-toggle span:nth-child(2){ opacity:0; }
.nav.open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* tablets / small laptops */
@media (max-width:1024px){
  .sectors,.globe,.vision,.work,.about,.careers,.legal,.proof{ padding-left:24px; padding-right:24px; }
  .about-grid,.careers-grid{ gap:32px; }
}

/* phones */
@media (max-width:760px){
  .nav{ padding:14px 18px; }
  .nav-toggle{ display:flex; }
  .nav .links{
    display:none; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0; margin:0;
    background:rgba(8,8,11,.97); backdrop-filter:blur(16px);
    border-bottom:1px solid var(--line);
  }
  .nav.open .links{ display:flex; }
  .nav .links a{ padding:15px 18px; font-size:16px; border-top:1px solid var(--line); }
  .nav .cta{ display:none; }

  .pin{ padding:0 20px; }
  .display{ font-size:clamp(40px,12vw,72px); }
  .h2{ font-size:clamp(28px,8vw,46px); }
  .lede{ font-size:17px; }

  .promise-cards{ grid-template-columns:1fr; gap:14px; max-width:none; }
  .zoom-cap{ padding:24px; }
  .zoom-cap .display{ font-size:clamp(26px,9vw,46px); }

  .cap-card{ flex-basis:78vw; height:300px; }
  .cap-card.intro{ flex-basis:84vw; }

  .sector-grid,.work-grid,.metrics{ grid-template-columns:1fr; }
  .metrics{ gap:20px; text-align:center; }
  .loc-grid{ grid-template-columns:1fr 1fr; }

  .globe-canvas-wrap{ height:340px; }
  .vtimeline{ grid-template-columns:1fr; gap:22px; }
  .vtimeline::before{ display:none; }
  .about-grid,.careers-grid,.legal-grid{ grid-template-columns:1fr; gap:24px; }
  .about image-slot,.careers image-slot{ height:280px; }

  .sectors,.globe,.vision,.work,.about,.careers,.legal{ padding-top:80px; padding-bottom:80px; }
  .proof{ padding:80px 20px; }
  .cta{ padding:90px 20px 110px; }

  .uk-panel{ padding:18px; }
  .styler{ right:12px; bottom:12px; }
}

@media (max-width:420px){
  .loc-grid{ grid-template-columns:1fr; }
}
