:root{
  --bg:#050d11;--bg2:#091620;--card:#0e1d26;--line:#1c3744;
  --text:#eafbff;--muted:#8bb4c1;--soft:#bce6ef;
  --accent:#21bed0;--accent2:#74ecf5;--ink:#04141a;--glow:33,190,208;--max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:
   radial-gradient(1200px 680px at 82% -12%, rgba(var(--glow),.18), transparent 60%),
   radial-gradient(900px 520px at -5% 2%, rgba(var(--glow),.07), transparent 55%),
   var(--bg);
 color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
 line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.stars{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.6;
 background-image:
  radial-gradient(1.4px 1.4px at 20% 30%, rgba(255,255,255,.7), transparent),
  radial-gradient(1.2px 1.2px at 70% 20%, rgba(255,255,255,.55), transparent),
  radial-gradient(1.3px 1.3px at 40% 70%, rgba(255,255,255,.5), transparent),
  radial-gradient(1.1px 1.1px at 85% 60%, rgba(255,255,255,.5), transparent),
  radial-gradient(1.2px 1.2px at 55% 45%, rgba(255,255,255,.45), transparent),
  radial-gradient(1.1px 1.1px at 10% 80%, rgba(255,255,255,.45), transparent);
 background-size:auto;animation:tw 7s ease-in-out infinite alternate}
@keyframes tw{from{opacity:.35}to{opacity:.7}}
@media(prefers-reduced-motion:reduce){.stars{animation:none}}
header{position:sticky;top:0;z-index:20;background:rgba(0,0,0,.34);
 backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;
 padding:13px 22px;max-width:var(--max);margin:0 auto}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;letter-spacing:.2px;color:var(--text)}
.brand:hover{text-decoration:none}
.mk{width:30px;height:30px;flex:0 0 auto}
.brand small{display:block;color:var(--muted);font-weight:500;font-size:11.5px;letter-spacing:.4px}
.menu{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.menu a{color:var(--soft);font-size:14px;padding:7px 11px;border-radius:9px}
.menu a:hover{background:rgba(var(--glow),.12);text-decoration:none}
.menu a.cur{color:var(--text);background:rgba(var(--glow),.14)}
.langsw{display:inline-flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:2px;margin-left:4px}
.langsw a{color:var(--muted);font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px;letter-spacing:.5px}
.langsw a:hover{color:var(--text);text-decoration:none}
.langsw a.cur{color:var(--ink);background:var(--accent)}
/* ---- global group bar (identical structure on every site, top + bottom) ---- */
.groupbar{background:linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,0,0,.26));
 border-bottom:1px solid var(--line);position:relative}
.groupbar::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;
 background:linear-gradient(90deg,transparent,rgba(var(--glow),.7),transparent)}
.gbin{max-width:var(--max);margin:0 auto;padding:7px 22px;display:flex;align-items:center;
 justify-content:space-between;gap:14px;flex-wrap:wrap}
.gblogo{display:inline-flex;align-items:center;gap:8px;color:var(--soft);font-weight:600;
 font-size:12px;letter-spacing:1.4px;text-transform:uppercase}
.gblogo:hover{text-decoration:none;color:var(--text)}
.gblogo svg{width:15px;height:15px;flex:0 0 auto}
.gblinks{display:flex;gap:2px;flex-wrap:wrap;align-items:center}
.gblinks a{color:var(--muted);padding:4px 11px;border-radius:8px;font-size:12.5px;font-weight:500;
 transition:background .15s ease,color .15s ease}
.gblinks a:hover{color:var(--text);background:rgba(var(--glow),.12);text-decoration:none}
.gblinks a.cur{color:var(--accent2);background:rgba(var(--glow),.15)}
.gblinks a.cur::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;
 background:var(--accent);margin-right:7px;vertical-align:middle;box-shadow:0 0 7px var(--accent)}
@media(max-width:600px){.gblogo span{display:none}.gbin{justify-content:center}}
.ladder{border-bottom:1px solid var(--line);background:rgba(0,0,0,.18)}
.ladder .in{max-width:var(--max);margin:0 auto;padding:9px 22px;display:flex;flex-wrap:wrap;
 gap:7px;align-items:center;font-size:12.5px;color:var(--muted)}
.ladder a{color:var(--soft)}
.ladder .sep{opacity:.5}
.ladder .here{color:var(--accent2)}
.hero{padding:78px 0 56px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--accent2);font-size:12.5px;
 letter-spacing:2.2px;text-transform:uppercase;margin:0 0 18px;
 border:1px solid var(--line);padding:6px 13px;border-radius:999px;background:rgba(var(--glow),.07)}
.eyebrow a{color:var(--accent2)}
h1{font-size:clamp(33px,5vw,55px);line-height:1.08;margin:0 0 20px;font-weight:760;letter-spacing:-.6px}
.lede{font-size:clamp(17px,2vw,20px);color:var(--soft);max-width:720px;margin:0}
.cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:var(--ink);
 font-weight:700;padding:12px 20px;border-radius:12px;font-size:15px}
.btn:hover{background:var(--accent2);text-decoration:none}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn .ic{width:17px;height:17px}
section{padding:54px 0;border-top:1px solid var(--line)}
.kicker{font-size:12.5px;letter-spacing:2.2px;text-transform:uppercase;color:var(--accent2);
 margin:0 0 10px;font-weight:600}
h2{font-size:clamp(23px,3vw,30px);margin:0 0 14px;font-weight:720;letter-spacing:-.3px}
.sub{color:var(--soft);max-width:720px;margin:0 0 30px;font-size:16.5px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g3,.g4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.g2,.g3,.g4{grid-template-columns:1fr}}
.panel{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:16px;padding:24px 22px}
.panel.l{border-left:3px solid var(--accent)}
.panel h3{margin:0 0 4px;font-size:20px;letter-spacing:-.2px;display:flex;align-items:center;gap:10px}
.panel .dom{color:var(--muted);font-size:12.5px;font-family:ui-monospace,Menlo,monospace;margin:0 0 13px}
.panel p{margin:0 0 15px;color:var(--soft)}
.panel p:last-child{margin-bottom:0}
.ic{width:20px;height:20px;flex:0 0 auto;color:var(--accent2)}
.iconbox{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
 background:rgba(var(--glow),.12);border:1px solid var(--line);margin-bottom:14px}
.iconbox .ic{width:22px;height:22px}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.pill{font-size:13px;color:var(--soft);background:rgba(var(--glow),.10);border:1px solid var(--line);
 border-radius:999px;padding:5px 12px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:700px){.stats{grid-template-columns:1fr 1fr}}
.stat{background:rgba(var(--glow),.06);border:1px solid var(--line);border-radius:14px;padding:18px}
.stat b{display:block;font-size:30px;font-weight:760;letter-spacing:-.5px;line-height:1}
.stat span{display:block;color:var(--muted);font-size:13.5px;margin-top:7px}
.feat .iconbox{margin-bottom:12px}
.feat h4{margin:0 0 5px;font-size:16.5px}
.feat p{margin:0;color:var(--soft);font-size:14.5px}
.tree{display:flex;flex-direction:column;gap:12px}
.tnode{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:14px;padding:16px 18px}
.tnode .top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tnode .top b{font-size:16.5px}
.tnode .top .dom{color:var(--muted);font-size:12px;font-family:ui-monospace,Menlo,monospace}
.tnode p{margin:8px 0 0;color:var(--soft);font-size:14px}
.tchildren{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
@media(max-width:600px){.tchildren{grid-template-columns:1fr}}
.tchild{background:rgba(var(--glow),.05);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.tchild b{font-size:14.5px}
.tchild .dom{color:var(--muted);font-size:11.5px;font-family:ui-monospace,Menlo,monospace;margin-top:1px}
.tchild p{margin:6px 0 0;color:var(--soft);font-size:13px}
.prose{max-width:760px}
.prose p{color:var(--soft);margin:0 0 16px}
.prose h2{font-size:24px;margin:34px 0 12px}
.prose h3{font-size:18px;margin:26px 0 8px}
.prose ul{color:var(--soft);padding-left:20px;margin:0 0 16px}
.prose li{margin:6px 0}
.faq{display:flex;flex-direction:column;gap:12px}
.qa{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:14px;padding:18px 20px}
.qa b{display:block;margin-bottom:6px;font-size:16px}
.qa p{margin:0;color:var(--soft);font-size:14.5px}
.articlelist{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.articlelist{grid-template-columns:1fr}}
.acard{display:block;background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:14px;padding:18px 20px;color:var(--text)}
.acard:hover{border-color:var(--accent);text-decoration:none}
.acard b{display:flex;align-items:center;gap:9px;font-size:16px}
.acard span{display:block;color:var(--soft);font-size:14px;margin-top:6px}
.mailbtn{display:inline-flex;align-items:center;gap:9px;background:var(--accent);color:var(--ink);
 font-weight:700;padding:13px 22px;border-radius:12px;margin-top:4px}
.mailbtn:hover{background:var(--accent2);text-decoration:none}
footer{border-top:1px solid var(--line);padding:40px 0 56px;color:var(--muted);font-size:13.5px;margin-top:8px}
.fcols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:26px;margin-bottom:26px}
@media(max-width:820px){.fcols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.fcols{grid-template-columns:1fr}}
.fcols h5{margin:0 0 10px;font-size:12px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);font-weight:600}
.fcols a{display:block;color:var(--soft);margin:5px 0}
.fblurb{margin:0 0 12px;color:var(--soft);max-width:300px}
.fbar{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
 border-top:1px solid var(--line);padding-top:18px}
.fcols a{transition:color .15s ease}
.fcols a:hover{color:var(--accent2)}
.fbrand{display:flex;align-items:center;gap:10px;margin:0 0 12px}
.fbrand svg{width:26px;height:26px;flex:0 0 auto}
.fbrand b{font-size:15px;color:var(--text);letter-spacing:.2px}
/* footer group strip: mirrors the header group bar so top and bottom match */
.fgroup{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start;margin-top:20px;padding-top:18px;
 border-top:1px solid var(--line)}
.fgroup .lab{margin-top:6px}
.fgroup .lab{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);
 margin-right:6px;font-weight:600}
.fgroup a{color:var(--soft);font-size:13px;padding:5px 12px;border-radius:999px;
 border:1px solid var(--line);background:rgba(var(--glow),.05);margin:0;
 transition:background .15s ease,border-color .15s ease}
.fgroup a:hover{background:rgba(var(--glow),.13);border-color:var(--accent);text-decoration:none}
.fgroup a.cur{color:var(--accent2);border-color:var(--accent);background:rgba(var(--glow),.12)}

/* ---- depth components ---- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.4px;
 padding:3px 10px;border-radius:999px;border:1px solid var(--line);text-transform:uppercase;color:var(--muted);white-space:nowrap}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--muted)}
.badge.live{color:#7ef0c0;border-color:rgba(126,240,192,.4);background:rgba(126,240,192,.08)}
.badge.live::before{background:#46e0a0;box-shadow:0 0 8px #46e0a0}
.badge.infra{color:var(--accent2);border-color:var(--line);background:rgba(var(--glow),.10)}
.badge.infra::before{background:var(--accent)}
.badge.soon{color:#ffd591;border-color:rgba(255,213,145,.35);background:rgba(255,213,145,.07)}
.badge.soon::before{background:#ffce6a}
.badge.build::before{background:var(--muted)}
.facts{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.fact{display:flex;flex-direction:column;gap:2px;background:rgba(var(--glow),.06);border:1px solid var(--line);
 border-radius:12px;padding:11px 16px;min-width:118px}
.fact b{font-size:19px;font-weight:740;letter-spacing:-.3px;line-height:1.1}
.fact span{font-size:12px;color:var(--muted)}
.dtable{width:100%;border-collapse:collapse;font-size:14.5px}
.dtable th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;letter-spacing:1px;
 text-transform:uppercase;padding:0 14px 12px;border-bottom:1px solid var(--line)}
.dtable td{padding:14px;border-bottom:1px solid var(--line);color:var(--soft);vertical-align:top}
.dtable tr:hover td{background:rgba(var(--glow),.04)}
.dtable td b{color:var(--text)}
.dtable .dom{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--muted)}
.dtable a{color:var(--accent2)}
@media(max-width:720px){.dtable thead{display:none}
 .dtable,.dtable tbody{display:block}
 .dtable tr{display:block;border-bottom:1px solid var(--line);padding:14px 0}
 .dtable td{display:block;border:none;padding:3px 0}}
.maplist{display:flex;flex-direction:column;gap:10px}
.maprow{display:flex;align-items:center;gap:16px;background:linear-gradient(180deg,var(--card),var(--bg2));
 border:1px solid var(--line);border-radius:13px;padding:15px 18px}
.maprow .reg{font-weight:700;min-width:150px;display:flex;align-items:center;gap:10px;font-size:15px}
.maprow .desc{color:var(--soft);font-size:14px;flex:1;min-width:200px}
@media(max-width:600px){.maprow{flex-wrap:wrap;gap:8px}.maprow .reg{min-width:0}}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:14px;padding:18px;position:relative}
.step .n{font-size:12px;font-weight:700;color:var(--accent2);letter-spacing:1px}
.step h4{margin:8px 0 5px;font-size:15.5px}
.step p{margin:0;color:var(--soft);font-size:13.5px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
@media(max-width:760px){.split{grid-template-columns:1fr;gap:20px}}
.split ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.split li{display:flex;gap:11px;color:var(--soft);font-size:14.5px;align-items:flex-start}
.split li .ic{width:18px;height:18px;margin-top:2px;color:var(--accent2);flex:0 0 auto}
.callout{background:rgba(var(--glow),.07);border:1px solid var(--line);border-left:3px solid var(--accent);
 border-radius:13px;padding:18px 20px;color:var(--soft)}
.callout b{color:var(--text)}
.lead{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);border-radius:16px;
 padding:26px 24px;display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between}
.lead h3{margin:0 0 6px;font-size:21px}
.lead p{margin:0;color:var(--soft)}
.anchors{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.anchors a{font-size:13px;color:var(--soft);background:rgba(var(--glow),.08);border:1px solid var(--line);
 border-radius:999px;padding:6px 13px}
.anchors a:hover{background:rgba(var(--glow),.16);text-decoration:none}
.rowcard{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(180deg,var(--card),var(--bg2));
 border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.rowcard .iconbox{margin:0}
.rowcard .bd{flex:1}
.rowcard h3{margin:0 0 3px;font-size:18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rowcard .dom{color:var(--muted);font-size:12px;font-family:ui-monospace,Menlo,monospace;margin:0 0 9px}
.rowcard p{margin:0 0 12px;color:var(--soft);font-size:14.5px}
.rowcard p:last-child{margin-bottom:0}
.disc{color:var(--muted);font-size:12.5px;margin-top:10px}
.badge.plan{color:#9aa0b6;border-color:rgba(154,160,182,.30);background:rgba(154,160,182,.06)}
.badge.plan::before{background:#6b7088;box-shadow:none}

/* ---- global presence map ---- */
.presence{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:6px}
@media(max-width:900px){.presence{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.presence{grid-template-columns:1fr}}
.region{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:14px;padding:18px 18px 16px;position:relative;overflow:hidden}
.region .rtop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.region .rname{font-weight:700;font-size:16px;letter-spacing:-.2px}
.region .rdesc{color:var(--soft);font-size:13.5px;margin:0}
.region.planned{opacity:.62;border-style:dashed}
.region.planned .rname{color:var(--muted)}
.region.planned .rdesc{color:var(--muted)}
.region .dot{position:absolute;right:16px;bottom:14px;width:8px;height:8px;border-radius:50%;background:var(--muted)}
.region.on .dot{background:#46e0a0;box-shadow:0 0 10px #46e0a0}
.presence-note{color:var(--muted);font-size:12.5px;margin-top:14px}
.world{display:block;width:100%;height:auto;margin:8px 0 4px;border:1px solid var(--line);border-radius:16px;
 background:linear-gradient(180deg,var(--bg2),var(--bg))}

/* ---- depth: motion + hover lift (subtle, respects reduced-motion) ---- */
.btn{transition:background .16s ease,transform .16s ease,box-shadow .16s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px -10px rgba(var(--glow),.6)}
.btn.ghost:hover{box-shadow:none;border-color:var(--accent)}
.mailbtn,.cta a{transition:transform .16s ease,box-shadow .16s ease,background .16s ease}
.mailbtn:hover{transform:translateY(-1px);box-shadow:0 8px 22px -10px rgba(var(--glow),.6)}
.panel,.rowcard,.step,.region,.tnode,.qa,.maprow{transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.panel:hover,.rowcard:hover,.step:hover,.tnode:hover{transform:translateY(-2px);border-color:rgba(var(--glow),.45);
 box-shadow:0 14px 34px -22px rgba(0,0,0,.85)}
.region.on:hover{transform:translateY(-2px);border-color:rgba(var(--glow),.5);
 box-shadow:0 14px 34px -22px rgba(0,0,0,.85)}
.feat .iconbox,.rowcard .iconbox{transition:background .18s ease,border-color .18s ease}
.panel:hover .iconbox,.rowcard:hover .iconbox{background:rgba(var(--glow),.2);border-color:var(--accent)}
.eyebrow{transition:border-color .18s ease,background .18s ease}
.stat{transition:border-color .18s ease,background .18s ease}
.stat:hover{border-color:rgba(var(--glow),.4);background:rgba(var(--glow),.1)}
@media(prefers-reduced-motion:reduce){
 .btn,.mailbtn,.panel,.rowcard,.step,.region,.tnode,.cta a{transition:none}
 .btn:hover,.mailbtn:hover,.panel:hover,.rowcard:hover,.step:hover,.tnode:hover,.region.on:hover{transform:none}
}

/* one clean top bar: group mark + Structure trigger (left), switcher (right) */
.gbin{align-items:center}
.gbleft{display:flex;align-items:center;gap:16px;min-width:0}
/* hierarchical cross-group switcher: 3 primary dots (holding + two divisions); each
   division dot reveals its subdivisions vertically beneath in deeper family shades */
.gblinks{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.gbswitch{position:relative;display:inline-flex;align-items:center}
.gblinks .gbsw,.fgroup .gbsw{display:inline-flex;align-items:center;gap:7px;color:var(--muted);padding:4px 11px;
 border-radius:999px;font-size:12.5px;font-weight:600;border:1px solid transparent;
 transition:color .15s ease,background .15s ease,border-color .15s ease}
.gblinks .gbsw .gbdot,.fgroup .gbsw .gbdot{width:7px;height:7px;border-radius:50%;background:var(--c,currentColor);
 box-shadow:0 0 7px var(--c,transparent);flex:0 0 auto}
.gblinks .gbsw.cur::before,.fgroup .gbsw.cur::before{content:none;display:none}
.gblinks .gbsw:hover,.fgroup .gbsw:hover{color:var(--c2,var(--text));background:rgba(255,255,255,.05);text-decoration:none}
.gblinks .gbsw.cur,.fgroup .gbsw.cur{color:var(--c2,var(--accent2));
 border-color:color-mix(in srgb,var(--c) 55%,transparent);background:color-mix(in srgb,var(--c) 14%,transparent)}
.gblinks .gbsw.anc{color:var(--c2,var(--soft))}
/* fallback if color-mix is unsupported */
@supports not (color:color-mix(in srgb,red,blue)){.gblinks .gbsw.cur,.fgroup .gbsw.cur{background:rgba(255,255,255,.07);border-color:var(--line)}}
/* division reveal (hover on desktop, click anywhere via the caret) */
.gbcv-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;
 cursor:pointer;color:var(--muted);padding:3px 3px;margin-left:-4px}
.gbcv-btn:hover{color:var(--soft)}
.gbcv{width:10px;height:10px;transition:transform .18s ease}
.gbswitch.has-sub:hover .gbcv,.gbswitch.open .gbcv{transform:rotate(180deg)}
.gbsub{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;z-index:60;
 background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
 border-radius:13px;padding:8px;box-shadow:0 22px 52px rgba(0,0,0,.55);
 opacity:0;visibility:hidden;transform:translateY(-6px);
 transition:opacity .16s ease,transform .16s ease}
.gbswitch.has-sub:hover .gbsub,.gbswitch.open .gbsub{opacity:1;visibility:visible;transform:translateY(0)}
.gbsub::before{content:"";position:absolute;top:-9px;left:0;right:0;height:9px}
.gbsub-in{position:relative;display:flex;flex-direction:column;gap:3px;padding-left:15px}
.gbsub-in::before{content:"";position:absolute;left:5px;top:7px;bottom:7px;width:1px;
 background:color-mix(in srgb,var(--c,var(--line)) 38%,var(--line))}
.gblinks .gbsub .gbsw{width:100%;justify-content:flex-start;position:relative}
.gblinks .gbsub .gbsw::after{content:"";position:absolute;left:-10px;top:50%;width:7px;height:1px;
 background:color-mix(in srgb,var(--c,var(--line)) 38%,var(--line))}
/* Structure trigger */
.gstruct{position:static}
.gstruct-t{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;cursor:pointer;
 color:var(--soft);font:600 12px/1 inherit;letter-spacing:1.3px;text-transform:uppercase;padding:5px 2px}
.gstruct-t:hover{color:var(--text)}
.gstruct-cv{width:11px;height:11px;transition:transform .2s ease}
.gstruct:hover .gstruct-cv,.gstruct.open .gstruct-cv{transform:rotate(180deg)}
/* the tiered sub-menu it opens (hover on desktop, click anywhere) */
.gstruct-menu{position:absolute;top:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(-6px);
 width:min(1120px,calc(100vw - 28px));max-height:78vh;overflow:auto;z-index:60;
 background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);border-radius:16px;
 padding:18px;box-shadow:0 26px 64px rgba(0,0,0,.6);opacity:0;visibility:hidden;
 transition:opacity .18s ease,transform .18s ease}
.gstruct:hover .gstruct-menu,.gstruct.open .gstruct-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.gstruct-menu::before{content:"";position:absolute;top:-11px;left:0;right:0;height:11px}
.org-cap{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 12px}
.org-name{font-weight:inherit}
.org-node{display:flex;align-items:center;gap:9px;text-decoration:none;border-radius:11px;
 border:1px solid var(--line);transition:border-color .15s ease,background .15s ease,color .15s ease}
.org-node em{font-style:normal;color:var(--muted);font-size:11.5px;margin-left:auto;white-space:nowrap}
.org-node:hover{border-color:var(--fam,var(--accent));color:var(--text);text-decoration:none}
.org-node.cur{border-color:var(--fam,var(--accent));box-shadow:inset 0 0 0 1px var(--fam,var(--accent))}
.org-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:var(--fam,var(--accent));
 box-shadow:0 0 8px var(--fam,transparent)}
/* one colour family per branch; the shade deepens with depth holding>division>sub>front */
.org-top{padding:12px 15px;color:var(--text);font-weight:760;font-size:15.5px;
 background:color-mix(in srgb,var(--fam) 16%,transparent);border-color:color-mix(in srgb,var(--fam) 50%,transparent)}
.org-top em{color:var(--fam2,var(--accent2));border:1px solid var(--line);border-radius:999px;padding:2px 9px;font-size:10.5px;
 letter-spacing:1.2px;text-transform:uppercase}
.org-top svg{width:18px;height:18px;flex:0 0 auto}
.org-stem{width:2px;height:14px;margin:0 auto;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 60%,transparent),var(--line))}
.org-divs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.org-div{position:relative}
.t-division{padding:10px 13px;color:var(--text);font-weight:700;font-size:14px;
 background:color-mix(in srgb,var(--fam) 14%,transparent);border-color:color-mix(in srgb,var(--fam) 40%,transparent)}
.org-subs{margin:12px 0 0 13px;padding-left:15px;
 border-left:1px solid color-mix(in srgb,var(--fam,var(--line)) 35%,var(--line));
 display:flex;flex-direction:column;gap:13px}
.org-subwrap{position:relative}
.org-subwrap::before{content:"";position:absolute;left:-15px;top:18px;width:11px;height:1px;
 background:color-mix(in srgb,var(--fam,var(--line)) 35%,var(--line))}
.t-sub{padding:8px 12px;color:var(--soft);font-weight:650;font-size:13px;
 background:color-mix(in srgb,var(--fam) 11%,transparent);border-color:color-mix(in srgb,var(--fam) 30%,transparent)}
.org-fronts{display:flex;flex-wrap:wrap;gap:6px;margin:9px 0 0 13px;padding-left:15px;
 border-left:1px dashed color-mix(in srgb,var(--fam,var(--line)) 30%,var(--line))}
.org-front{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--soft);
 background:color-mix(in srgb,var(--fam) 12%,transparent);
 border:1px solid color-mix(in srgb,var(--fam) 28%,transparent);border-radius:999px;padding:3px 10px;white-space:nowrap}
.org-front .org-dot{width:6px;height:6px}
@supports not (color:color-mix(in srgb,red,blue)){
 .org-top,.t-division,.t-sub,.org-front{background:rgba(255,255,255,.05);border-color:var(--line)}}
@media(max-width:760px){.org-divs{grid-template-columns:1fr}}
@media(max-width:600px){.gbleft{gap:11px}.gblogo span{display:none}.gbin{justify-content:space-between}
 .gstruct-menu{padding:14px}.gbsub{right:auto;left:0}}
@media(prefers-reduced-motion:reduce){.gstruct-menu,.gstruct-cv,.gbsub,.gbcv,.gbsw{transition:none}}
/* footer group tree: holding on top, divisions below with subdivisions nested */
.fgroup .ftree{display:flex;flex-direction:column;gap:8px;margin-top:2px}
.ftbranch{display:flex;flex-direction:column;gap:5px}
.ftsubs{display:flex;flex-direction:column;gap:4px;margin-left:13px;padding-left:13px;
 border-left:1px solid color-mix(in srgb,var(--c,var(--line)) 35%,var(--line))}
.fgroup .gbsw{border:1px solid var(--line);background:rgba(var(--glow),.05);align-self:flex-start}
.fgroup .gbsw.cur{border-color:var(--c,var(--accent))}
.fgroup .ftsubs .gbsw{position:relative}
.fgroup .ftsubs .gbsw::after{content:"";position:absolute;left:-13px;top:50%;width:8px;height:1px;
 background:color-mix(in srgb,var(--c,var(--line)) 35%,var(--line))}
