/* ============================================================
   XEU LABS — SUBPAGE COMPONENT LAYER (variant 2 "Editorial & Technical")
   Loaded on top of tokens.css + site.css for: dexpace · mex ·
   tokenization · about · privacy · terms.
   Same hairline / mono spec-sheet language as the homepage —
   every value bound to a token, no per-page hardcoding.
   ============================================================ */

/* ---------- AMBIENT PAGE DEPTH (subpages only — soft accent blooms, NO grid) ----------
   Two very soft accent glows fixed in opposite corners give the dark/light canvas
   a little depth without an all-over grid. Cards/panels sit opaque on top. */
body{
  background-color:var(--bg);
  background-image:
    radial-gradient(46% 38% at 92% 4%, color-mix(in srgb,var(--accent) 7%,transparent), transparent 62%),
    radial-gradient(44% 40% at 2% 100%, color-mix(in srgb,var(--accent) 5%,transparent), transparent 66%);
  background-attachment:fixed;
}

/* ---------- PAGE HERO (back-link · breadcrumb · H1 · intro · actions) ---------- */
.page-hero{position:relative;padding:var(--sp-48) 0 var(--sp-56);border-bottom:1px solid var(--border);overflow:hidden}
.page-hero .hero-grid-bg{position:absolute;inset:0;z-index:0;
  -webkit-mask-image:radial-gradient(ellipse 60% 70% at 18% 22%,#000 0%,transparent 70%);
  mask-image:radial-gradient(ellipse 60% 70% at 18% 22%,#000 0%,transparent 70%)}
.page-hero>.wrap{position:relative;z-index:1}

.page-top{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-24);flex-wrap:wrap;margin-bottom:var(--sp-40)}
.back-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;
  color:var(--text-muted);transition:color var(--dur-fast) var(--ease-out)}
.back-link .arw{display:inline-block;transition:transform var(--dur-base) var(--ease-out)}
.back-link:hover{color:var(--text)}
.back-link:hover .arw{transform:translateX(-4px)}
/* project identity lockup — plain logo + name (the page's "who is this") */
.crumb{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-8) var(--sp-12)}
.crumb .status-pill{margin-left:var(--sp-8)}
.crumb .ico{flex:0 0 auto;display:grid;place-items:center;color:var(--accent)}
.crumb .ico svg{width:auto;height:46px;display:block;fill:currentColor}
.crumb b{font-family:'Exo 2';font-weight:600;font-size:1.6rem;color:var(--text);line-height:1;letter-spacing:-.01em}
.crumb .div{color:var(--border-strong);font-size:1.3rem;font-weight:200}
.crumb span{font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;color:var(--text-muted)}

/* status pill — dot + label, used in hero + cards */
.status-pill{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border:1px solid var(--border);
  border-radius:var(--r-pill);font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;color:var(--text-secondary);white-space:nowrap}
.status-pill .dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;background:var(--accent)}
.status-pill .dot.live{box-shadow:0 0 0 0 var(--accent-weak);animation:pulse 2.4s var(--ease-out) infinite}
.status-pill .dot.plan{background:var(--text-muted)}

.page-hero h1{font-family:'Exo 2';font-weight:200;letter-spacing:-.02em;line-height:1.04;
  font-size:clamp(2.4rem,5.2vw,4rem);max-width:18ch;text-wrap:balance}
.page-hero h1 b{font-weight:600}
.page-hero h1 .accent{color:var(--accent-text);font-weight:500}
.page-intro{margin-top:var(--sp-24);font-size:1.14rem;line-height:1.55;color:var(--text-secondary);max-width:64ch}
.page-actions{display:flex;align-items:center;gap:var(--sp-20);flex-wrap:wrap;margin-top:var(--sp-40)}
/* product site links — same height as before, just a little longer (wider) */
.page-actions .btn-primary{padding-left:var(--sp-40);padding-right:var(--sp-40)}

/* ---------- METRICS STRIP (entity-record style, hairline grid) ---------- */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-32);
  margin-top:var(--sp-56);padding-top:var(--sp-32);border-top:1px solid var(--border)}
.metric dt{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}
.metric dd{font-family:'Exo 2';font-size:1.5rem;font-weight:400;color:var(--text);margin-top:10px;line-height:1.1;letter-spacing:-.01em}
.metric dd.mono{font-family:var(--mono);font-size:1.16rem;letter-spacing:0;font-feature-settings:"tnum"}
.metric dd .unit{font-size:.8rem;color:var(--text-muted);margin-left:7px;font-weight:400}

/* ---------- SUBPAGE SECTION HEAD (reuses .s-head idiom; one uniform H2 size) ---------- */
.sub-head{margin-bottom:var(--sp-56)}
.sub-head h2{font-family:'Exo 2';font-size:clamp(2rem,4.4vw,3.4rem);font-weight:300;line-height:1.05;letter-spacing:-.02em;text-wrap:balance;max-width:24ch}
.sub-head h2 b{font-weight:600}
.sub-head .lead{margin-top:var(--sp-20);color:var(--text-secondary);font-size:1.02rem;max-width:56ch}
.eyebrow{display:inline-block;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-text);margin-bottom:var(--sp-16)}

/* ---------- ECOSYSTEM / FEATURE GRID (hairline cards, premium hover) ---------- */
.eco-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-16)}
.eco-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.eco-card{position:relative;display:flex;flex-direction:column;gap:var(--sp-16);padding:var(--sp-32);
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-16);
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.eco-card:hover{border-color:var(--border-strong);transform:translateY(-3px);box-shadow:var(--shadow-card)}
.eco-head{display:flex;align-items:center;gap:var(--sp-16)}
.eco-ic{width:46px;height:46px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--border-strong);color:var(--accent);
  transition:border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out)}
.eco-ic svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.eco-card:hover .eco-ic{border-color:var(--accent);background:var(--accent-weak)}
.eco-name{display:flex;flex-direction:column;gap:5px}
.eco-name h4{font-family:'Exo 2';font-size:1.16rem;font-weight:500;line-height:1.1;color:var(--text)}
.eco-name .tag{font-size:.6rem}
.eco-card p{color:var(--text-secondary);font-size:.92rem;line-height:1.55;flex:1 1 auto}
.eco-stat{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.66rem;letter-spacing:.04em;color:var(--text-muted);
  padding-top:var(--sp-12);border-top:1px solid var(--border)}
.eco-stat .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:0 0 auto}
.eco-stat .dot.plan{background:var(--text-muted)}

/* ---------- STEPS FLOW (numbered process, hairline) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-40)}
.step{position:relative;padding-top:var(--sp-24);border-top:1px solid var(--border-strong)}
.step .step-num{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--accent-text)}
.step h4{font-family:'Exo 2';font-size:1.24rem;font-weight:500;line-height:1.15;margin-top:var(--sp-16)}
.step p{margin-top:var(--sp-12);color:var(--text-secondary);font-size:.92rem;line-height:1.55}

/* ---------- ROADMAP (ledger on a rail that FILLS as you scroll — phased-rollout feel) ---------- */
.roadmap{position:relative;border-top:1px solid var(--border-strong);padding-left:var(--sp-40)}
/* rail track */
.roadmap::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:2px;border-radius:2px;background:var(--border-strong)}
/* accent progress fill — JS sets its height from scroll position */
.rm-fill{position:absolute;left:7px;top:0;width:2px;height:0;border-radius:2px;z-index:1;background:var(--accent);
  box-shadow:0 0 8px 1px color-mix(in srgb,var(--accent) 65%,transparent);transition:height .1s linear}
.rm-row{position:relative;overflow:hidden;display:grid;grid-template-columns:170px minmax(0,1fr) 40px;gap:var(--sp-40);align-items:start;
  padding:var(--sp-40) var(--sp-16);border-bottom:1px solid var(--border);color:inherit}
.rm-row>*{position:relative;z-index:1}
/* node marker sitting ON the rail (the fill grows up to/over it = "reached") */
.rm-dot{position:absolute;left:calc(-1 * var(--sp-40) + 2px);top:calc(var(--sp-40) + 13px);z-index:2;
  width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--border-strong)}
.rm-row.is-now .rm-dot{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 4px var(--accent-weak)}
/* premium hover — teal spotlight + accent line draws in (desktop only) */
.rm-row::before{content:'';position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),color-mix(in srgb,var(--accent) 15%,transparent) 0%,transparent 60%);
  transition:opacity var(--dur-slow) var(--ease-out)}
.rm-row:hover::before{opacity:1}
[data-theme="light"] .rm-row::before{background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),color-mix(in srgb,var(--t-turquoise-300) 30%,transparent) 0%,transparent 62%)}
.rm-row::after{content:'';position:absolute;left:0;bottom:0;height:1.5px;width:100%;z-index:2;
  background:linear-gradient(90deg,var(--accent),transparent);transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur-slow) var(--ease-out)}
.rm-row:hover::after{transform:scaleX(1)}
.rm-when{display:flex;align-items:baseline;gap:10px}
.rm-when b{font-family:'Exo 2';font-size:clamp(1.7rem,2.4vw,2.2rem);font-weight:300;line-height:1;letter-spacing:-.02em;color:var(--text);
  transition:color var(--dur-base) var(--ease-out)}
.rm-when .rm-yr{font-family:var(--mono);font-size:.72rem;color:var(--text-muted)}
.rm-label{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-text)}
.rm-body h4{font-family:'Exo 2';font-size:1.3rem;font-weight:500;line-height:1.15;margin-top:9px}
.rm-body p{margin-top:9px;color:var(--text-secondary);font-size:.96rem;line-height:1.55;max-width:60ch}
.rm-idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--text-muted);justify-self:end;padding-top:8px;
  transition:color var(--dur-base) var(--ease-out)}
.rm-row:hover .rm-when b,.rm-row.is-now .rm-when b{color:var(--accent-text)}
.rm-row:hover .rm-idx{color:var(--accent-text)}

/* ---------- HIGHLIGHT PANEL (in-house protocol — quiet tinted surface, accent bracket) ---------- */
.panel{position:relative;overflow:hidden;padding:var(--sp-48);border:1px solid var(--border-strong);border-radius:var(--r-24);
  background:var(--surface-2)}
.panel>*{position:relative;z-index:1}
.panel .brk{position:absolute;right:var(--sp-24);top:var(--sp-24);width:26px;height:26px;
  border-right:1.5px solid var(--accent);border-top:1.5px solid var(--accent);opacity:.55;z-index:1}
.panel .eyebrow{margin-bottom:var(--sp-20)}
.panel h3{font-family:'Exo 2';font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:400;line-height:1.15;letter-spacing:-.01em;max-width:20ch}
.panel h3 b{font-weight:600}
.panel p{margin-top:var(--sp-20);color:var(--text-secondary);font-size:1.02rem;line-height:1.6;max-width:60ch}
/* panel with a code-native visual on the right (live P2P mesh) — top-aligned */
.panel-viz{display:grid;grid-template-columns:1.12fr .88fr;gap:var(--sp-40);align-items:center}
.panel-viz .panel-copy{min-width:0}
.panel-viz h3{max-width:24ch}
.p2p{position:relative;justify-self:center;width:100%;max-width:380px;pointer-events:none}
.p2p::before{content:'';position:absolute;inset:8% 6%;z-index:0;border-radius:50%;
  background:radial-gradient(circle at 52% 50%,var(--accent-weak),transparent 60%);filter:blur(24px);opacity:.7}
.p2p svg{position:relative;z-index:1;width:100%;height:auto;display:block;overflow:visible}
.p2p-edges line{stroke:var(--border-strong);stroke-width:1}
.p2p-link line{stroke:var(--accent);stroke-width:1.2;opacity:.42}
.p2p-nodes circle{fill:var(--bg);stroke:var(--border-strong);stroke-width:1.4}
.p2p-hot circle{fill:var(--accent);transform-box:fill-box;transform-origin:center;animation:p2pPulse 2.8s var(--ease-inout) infinite}
.p2p-hot circle:nth-child(2){animation-delay:-.9s}
.p2p-hot circle:nth-child(3){animation-delay:-1.8s}
.p2p-ripple circle{fill:none;stroke:var(--accent);stroke-width:1;transform-box:fill-box;transform-origin:center;opacity:0;
  animation:p2pRipple 3.4s var(--ease-out) infinite}
.p2p-ripple circle:nth-child(2){animation-delay:-1.7s}
.p2p-pk circle{fill:var(--accent);filter:drop-shadow(0 0 5px var(--accent))}
@keyframes p2pPulse{0%,100%{opacity:.55;transform:scale(.86)}50%{opacity:1;transform:scale(1.18)}}
@keyframes p2pRipple{0%{transform:scale(.55);opacity:.6}100%{transform:scale(3.1);opacity:0}}

/* ---------- INTERFACE PREVIEW (device mockup + copy) — compact, centred ---------- */
.preview{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-56);align-items:center;padding:0}
.preview-copy .eyebrow{margin-bottom:var(--sp-16)}
.preview-copy h3{font-family:'Exo 2';font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:400;line-height:1.15;letter-spacing:-.01em}
.preview-copy p{margin-top:var(--sp-20);color:var(--text-secondary);font-size:1rem;line-height:1.6;max-width:46ch}
.preview-tags{display:flex;flex-wrap:wrap;gap:var(--sp-12);margin-top:var(--sp-40)}
/* stage — accent glow tied behind the device image */
.preview-stage{position:relative;display:grid;place-items:center;align-self:stretch}
.preview-stage::before{content:'';position:absolute;left:50%;top:56%;transform:translate(-50%,-50%);
  width:122%;height:108%;z-index:0;border-radius:50%;
  background:radial-gradient(ellipse at 50% 50%,rgba(63,152,152,.32),rgba(63,152,152,.11) 42%,transparent 70%);filter:blur(46px);opacity:1}
[data-theme="light"] .preview-stage::before{opacity:1;top:60%;width:114%;height:92%;
  background:radial-gradient(ellipse at 50% 50%,rgba(63,152,152,.30),rgba(63,152,152,.09) 46%,transparent 72%)}
[data-theme="light"] .preview-img{filter:drop-shadow(0 26px 40px rgba(22,42,38,.16))}
/* theme-adaptive device mockup — only the active theme's image is fetched (CSS background);
   image-set serves WebP with a PNG fallback for old browsers */
.preview-img{position:relative;z-index:1;width:100%;max-width:470px;aspect-ratio:760/950;
  background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 26px 52px rgba(0,0,0,.24))}

/* ---------- REGION GRID (prospective platforms / geographic presence) ---------- */
.region-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-16)}
.region-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.region-card{display:flex;flex-direction:column;gap:var(--sp-12);padding:var(--sp-32);
  border:1px solid var(--border);border-radius:var(--r-16);background:var(--surface);
  transition:border-color var(--dur-base) var(--ease-out)}
.region-card:hover{border-color:var(--border-strong)}
.region-code{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-text)}
.region-card h5{font-family:'Exo 2';font-size:1.14rem;font-weight:500;line-height:1.2;color:var(--text)}
.region-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;flex:1 1 auto}
.region-card .eco-stat{margin-top:auto}

/* ---------- GEOGRAPHIC — region legend (left, readable) + compact dotted world map (right) ---------- */
.geo{display:grid;grid-template-columns:1fr minmax(300px,440px);gap:var(--sp-64);align-items:center}
.geo-map{width:100%;min-width:0;justify-self:end}
.worldmap{width:100%;height:auto;display:block;overflow:visible}
.wm-base circle{r:1px;fill:var(--text-muted);opacity:.42}
.wm-hot circle{r:1.5px}
.wm-hot .wm-now{fill:var(--accent)}
.wm-hot .wm-planned{fill:var(--accent);opacity:.5}
.wm-marks text{font-family:var(--mono);font-size:7px;letter-spacing:.3px;fill:var(--text);text-anchor:middle;
  paint-order:stroke;stroke:var(--bg);stroke-width:1.1px;stroke-linejoin:round}
.wm-mark .wm-pin{fill:var(--accent)}
.wm-mark.wm-planned .wm-pin{fill:var(--accent);opacity:.7}
.wm-mark .wm-ring{fill:none;stroke:var(--accent);stroke-width:1;transform-box:fill-box;transform-origin:center;opacity:0;
  animation:wmPing 3s var(--ease-out) infinite;animation-delay:calc(var(--i,0) * .55s)}
@keyframes wmPing{0%{transform:scale(1);opacity:.7}100%{transform:scale(3.2);opacity:0}}
.geo-legend{display:flex;flex-direction:column}
.geo-item{display:grid;grid-template-columns:54px minmax(0,1fr);gap:var(--sp-16);align-items:start;
  padding:var(--sp-20) 0;border-top:1px solid var(--border)}
.geo-item:first-child{border-top:none}
.geo-code{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:var(--accent-text);padding-top:3px}
.geo-code.planned{color:var(--text-muted)}
.geo-txt h5{font-family:'Exo 2';font-size:1.04rem;font-weight:500;line-height:1.2;color:var(--text)}
.geo-txt p{margin-top:4px;color:var(--text-secondary);font-size:.86rem;line-height:1.5}
.geo-stat{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.64rem;color:var(--text-muted);white-space:nowrap;padding-top:4px}
.geo-stat .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:0 0 auto}
.geo-stat.planned .dot{background:var(--text-muted)}

/* ---------- CONNECT BLOCK (for developers — clickable key/value spec rows) ---------- */
.connect{border-top:1px solid var(--border-strong)}
.kv-row{position:relative;display:grid;grid-template-columns:210px minmax(0,1fr) auto 32px;gap:var(--sp-24);align-items:center;
  padding:var(--sp-24) var(--sp-16);border-bottom:1px solid var(--border);color:inherit}
a.kv-row{transition:background var(--dur-base) var(--ease-out)}
a.kv-row::after{content:'';position:absolute;left:0;bottom:-1px;height:1.5px;width:100%;
  background:linear-gradient(90deg,var(--accent),transparent);transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur-slow) var(--ease-out)}
a.kv-row:hover{background:color-mix(in srgb,var(--accent) 5%,transparent)}
a.kv-row:hover::after{transform:scaleX(1)}
a.kv-row:hover .kv-label b{color:var(--accent-text)}
.kv-row .kv-label{display:flex;flex-direction:column;gap:5px}
.kv-row .kv-label b{font-family:'Exo 2';font-size:1.04rem;font-weight:500;color:var(--text);transition:color var(--dur-base) var(--ease-out)}
.kv-row .kv-label span{font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.kv-row .kv-value{font-family:var(--mono);font-size:.86rem;color:var(--text-secondary);word-break:break-word}
.kv-row .kv-note{font-family:var(--mono);font-size:.66rem;color:var(--text-muted);justify-self:end;white-space:nowrap}
.kv-arw{width:32px;height:32px;flex:0 0 auto;justify-self:end;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--border-strong);color:var(--text-muted);
  transition:border-color var(--dur-base) var(--ease-out),color var(--dur-base),background var(--dur-base),transform var(--dur-base)}
.kv-arw svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
a.kv-row:hover .kv-arw{border-color:var(--accent);color:var(--accent);background:var(--accent-weak);transform:translate(2px,-2px)}
.kv-soon{opacity:.58}
.kv-soon .kv-arw{border-style:dashed}

/* ---------- ABOUT — mission (copy left · radar visual right) ---------- */
.mission{display:grid;grid-template-columns:1.04fr .96fr;gap:var(--sp-64);align-items:start}
.mission-copy .eyebrow{margin-bottom:var(--sp-16)}
.mission-copy h2{font-family:'Exo 2';font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:300;line-height:1.1;letter-spacing:-.02em;text-wrap:balance}
.mission-copy h2 b{font-weight:600}
.mission-copy p{margin-top:var(--sp-24);color:var(--text-secondary);font-size:1.08rem;line-height:1.65;max-width:52ch}
.mission-viz{align-self:center;justify-self:center;width:100%;max-width:320px;pointer-events:none}
.mission-viz svg{width:100%;height:auto;display:block;overflow:visible;animation:stFloat 8s var(--ease-inout) infinite}
/* MISSION viz — wireframe globe + sovereign core (theme-adaptive, hairline, single accent) */
.mv-s{fill:none;stroke:var(--border-strong);stroke-width:1}
.mv-g{fill:none;stroke:color-mix(in srgb,var(--text) 10%,transparent);stroke-width:1}
.mv-dash{fill:none;stroke:var(--accent);stroke-width:1;opacity:.32;stroke-dasharray:1.5 6;stroke-linecap:round}
.mv-link{fill:none;stroke:var(--accent);stroke-width:1;opacity:.42;stroke-linecap:round}
.mv-node{fill:var(--surface);stroke:var(--border-strong);stroke-width:1}
.mv-nodeac{fill:color-mix(in srgb,var(--accent) 14%,transparent);stroke:var(--accent);stroke-width:1.5}
.mv-dot{fill:var(--accent)}
.mv-core{fill:color-mix(in srgb,var(--accent) 14%,transparent);stroke:var(--accent);stroke-width:1.5;stroke-linejoin:round}
.mv-acd{fill:none;stroke:var(--accent);stroke-width:1.5;stroke-linejoin:round}
/* motion: spinning meridians + rays flowing into the core + orbiting ring + node pulse */
.mv-merid,.mv-merid2{fill:none;stroke:color-mix(in srgb,var(--text) 10%,transparent);stroke-width:1;animation:mvMerid 7s ease-in-out infinite}
.mv-merid2{animation-delay:-3.5s}
.mv-dash{animation:mvRing 22s linear infinite}
.mv-nodeac{transform-box:fill-box;transform-origin:center;animation:mvNode 2.8s ease-in-out infinite}
.mv-flow{fill:var(--accent)}
@keyframes mvMerid{0%,100%{rx:106px}50%{rx:0px}}
@keyframes mvRing{to{stroke-dashoffset:-160}}
@keyframes mvNode{0%,100%{transform:scale(1);opacity:.95}50%{transform:scale(1.3);opacity:.7}}
@keyframes stFloat{0%,100%{transform:translateY(-5px)}50%{transform:translateY(5px)}}
@keyframes stRise{0%{transform:translateY(0);opacity:0}20%{opacity:1}80%{opacity:1}100%{transform:translateY(-210px);opacity:0}}

/* ---------- ABOUT — company details (info + faint brand mark, NO card backing) ---------- */
.entity-card{position:relative;display:grid;grid-template-columns:1fr auto;gap:var(--sp-48);align-items:center}
.entity-card .cmeta{margin-top:0;position:relative;z-index:1;max-width:520px;border-top:1px solid var(--border-strong)}
.entity-mark{justify-self:end;width:clamp(140px,18vw,230px);color:var(--text);opacity:.07;pointer-events:none}
.entity-mark svg{width:100%;height:auto;display:block}
.entity-mark svg path{fill:currentColor}

/* ---------- LEGAL (privacy / terms) — TOC + prose ---------- */
.legal{display:grid;grid-template-columns:240px minmax(0,1fr);gap:var(--sp-80);align-items:start}
.legal-toc{position:sticky;top:104px;display:flex;flex-direction:column;gap:var(--sp-8);padding-left:var(--sp-20)}
/* faint track + an accent indicator that slides to the section you're reading */
.legal-toc::before{content:'';position:absolute;left:0;top:32px;bottom:6px;width:1px;background:var(--border)}
.toc-rail{position:absolute;left:0;width:2px;height:0;border-radius:2px;background:var(--accent);opacity:0;
  transition:transform .32s var(--ease-out),height .32s var(--ease-out),opacity var(--dur-base) var(--ease-out)}
.legal-toc .tag{margin-bottom:var(--sp-8)}
.legal-toc a{font-size:.9rem;color:var(--text-secondary);padding:6px 0;width:fit-content;
  transition:color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}
.legal-toc a:hover{color:var(--accent-text);transform:translateX(3px)}
.legal-toc a.active{color:var(--accent-text);font-weight:500}
.legal-body{max-width:72ch}
.legal-body section{padding-bottom:var(--sp-48);margin-bottom:var(--sp-48);border-bottom:1px solid var(--border);scroll-margin-top:108px}
.legal-body section:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.legal-body h2{font-family:'Exo 2';font-size:1.6rem;font-weight:500;line-height:1.2;letter-spacing:-.01em;
  display:flex;align-items:baseline;gap:var(--sp-16);scroll-margin-top:104px}
.legal-body h2 .ix{font-family:var(--mono);font-size:.8rem;color:var(--accent-text);font-weight:400}
.legal-body h3{font-family:'Exo 2';font-size:1.1rem;font-weight:500;margin-top:var(--sp-24)}
.legal-body p{margin-top:var(--sp-16);color:var(--text-secondary);font-size:.98rem;line-height:1.7}
.legal-body ul{margin-top:var(--sp-16);padding-left:var(--sp-20);display:flex;flex-direction:column;gap:var(--sp-8)}
.legal-body li{color:var(--text-secondary);font-size:.98rem;line-height:1.6}
.legal-body li::marker{color:var(--accent)}
.legal-body p a{color:var(--accent-text);border-bottom:1px solid var(--border-strong);transition:border-color var(--dur-base) var(--ease-out)}
.legal-body p a:hover{border-bottom-color:var(--accent)}
.legal-note{margin-top:var(--sp-32);padding:var(--sp-24);border:1px solid var(--border);border-radius:var(--r-12);
  background:var(--surface-2);font-size:.88rem;color:var(--text-muted);line-height:1.6}

/* ---------- CLOSING CTA BAND (compact, top-anchored; eyebrow rule + corner bracket) ---------- */
.end-cta{position:relative;overflow:hidden;display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-64);align-items:start;
  padding:var(--sp-48) var(--sp-56);border:1px solid var(--border-strong);border-radius:var(--r-24);background:var(--surface-2)}
.end-cta::before{content:'';position:absolute;right:-8%;top:-80%;width:42%;height:180%;z-index:0;pointer-events:none;
  background:radial-gradient(50% 50% at 50% 50%,var(--accent-weak) 0%,transparent 70%);filter:blur(44px);opacity:.5}
.end-cta>*{position:relative;z-index:1}
.end-cta .brk{position:absolute;right:var(--sp-24);top:var(--sp-24);width:22px;height:22px;
  border-right:1.5px solid var(--accent);border-top:1.5px solid var(--accent);opacity:.5}
.end-cta .ec-head{display:flex;flex-direction:column}
.end-cta .ec-head .eyebrow{display:inline-flex;align-items:center;gap:var(--sp-12);margin-bottom:var(--sp-16)}
.end-cta .ec-head .eyebrow::before{content:'';width:24px;height:1px;background:var(--accent)}
.end-cta h2{font-family:'Exo 2';font-size:clamp(1.8rem,3vw,2.5rem);font-weight:300;line-height:1.08;letter-spacing:-.02em;max-width:14ch}
.end-cta h2 b{font-weight:600}
.end-cta .ec-side{display:flex;flex-direction:column;gap:var(--sp-24);align-items:flex-start;max-width:42ch}
.end-cta .ec-side p{color:var(--text-secondary);font-size:1rem;line-height:1.6}

/* generic spacing helpers used across subpages */
.block{margin-top:var(--sp-40)}
.block-lg{margin-top:var(--sp-80)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1068px){
  .metrics{grid-template-columns:repeat(2,1fr);row-gap:var(--sp-32)}
  .eco-grid{grid-template-columns:repeat(2,1fr)}
  .mission{grid-template-columns:1fr;gap:var(--sp-40)}
  .mission-viz{max-width:300px;justify-self:center}
  .entity-card{grid-template-columns:1fr;gap:var(--sp-32)}
  .entity-mark{justify-self:start;opacity:.05}
  .geo{grid-template-columns:1fr;gap:var(--sp-40)}
  .geo-map{max-width:620px}
  .legal{grid-template-columns:1fr;gap:var(--sp-24)}
  /* TOC → sticky horizontal pill scroller that tracks the section you're reading */
  .legal-toc{position:sticky;top:76px;z-index:5;flex-direction:row;align-items:center;gap:var(--sp-8);
    padding:var(--sp-12) 0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;
    background:color-mix(in srgb,var(--bg) 90%,transparent);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--border)}
  .legal-toc::-webkit-scrollbar{display:none}
  .legal-toc::before,.toc-rail{display:none}
  .legal-toc .tag{display:none}
  .legal-toc a{flex:0 0 auto;white-space:nowrap;font-size:.82rem;padding:7px 14px;border:1px solid var(--border);
    border-radius:var(--r-pill);color:var(--text-secondary)}
  .legal-toc a:hover{transform:none}
  .legal-toc a.active{color:var(--action-text);background:var(--accent);border-color:var(--accent);font-weight:500}
  .legal-body section{scroll-margin-top:140px}/* clear nav + sticky TOC bar on click-scroll */
}
@media(max-width:834px){
  .steps{grid-template-columns:repeat(2,1fr);gap:var(--sp-32)}
  .preview{grid-template-columns:1fr;gap:var(--sp-48)}
  .region-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .panel-viz{grid-template-columns:1fr;gap:var(--sp-32)}
  .p2p{max-width:320px}
  /* roadmap → quarter on top, body below; drop the index column; tighter rail */
  .roadmap{padding-left:var(--sp-24)}
  .rm-row{grid-template-columns:1fr;gap:var(--sp-12);padding:var(--sp-32) var(--sp-12)}
  .rm-dot{left:calc(-1 * var(--sp-24) + 2px);top:calc(var(--sp-32) + 11px)}
  .rm-idx{display:none}
  .end-cta{grid-template-columns:1fr;gap:var(--sp-32)}
  /* connect rows stack; the arrow keeps its own column, vertically centered */
  .kv-row{grid-template-columns:1fr auto;gap:var(--sp-4) var(--sp-16);align-items:center}
  .kv-row .kv-label{grid-column:1;grid-row:1}
  .kv-row .kv-value{grid-column:1;grid-row:2}
  .kv-row .kv-note{grid-column:1;grid-row:3;justify-self:start}
  .kv-arw{grid-column:2;grid-row:1 / 4;align-self:center}
}
@media(max-width:640px){
  .page-hero{padding:var(--sp-32) 0 var(--sp-40)}
  .metrics{grid-template-columns:1fr 1fr;gap:var(--sp-24)}
  .eco-grid,.eco-grid.cols-2{grid-template-columns:1fr}
  .eco-card{padding:var(--sp-24);gap:var(--sp-12)}
  /* steps — tighter from the dividers, less tall */
  .steps{grid-template-columns:1fr;gap:var(--sp-24)}
  .step{padding-top:var(--sp-16)}
  .step h4{margin-top:var(--sp-8)}
  .step p{margin-top:var(--sp-8)}
  /* corner bracket overlaps the status pill on a narrow panel → hide it */
  .panel .brk{display:none}
  .crumb-lg .status-pill{margin-left:0}
  .region-grid,.region-grid.cols-4{grid-template-columns:1fr}
  .panel,.end-cta{padding:var(--sp-32)}
  .preview{gap:var(--sp-32)}
  .preview-img{max-width:320px}
  .preview-tags{margin-top:var(--sp-24)}
  /* two CTAs → stacked, full-width, equal clickable height. Secondary STAYS an underlined link
     (no border/pill), just full-width & same height as the primary. */
  .page-actions{flex-direction:column;align-items:stretch;gap:var(--sp-16)}
  .page-actions>*{width:100%}
  .page-actions .btn{justify-content:center}
  .page-actions .link-ghost{justify-content:center;gap:var(--sp-12);padding:14px 0;border:none;font-size:.98rem}
  .page-actions .link-ghost .roll{border-bottom:1.5px solid var(--border-strong);padding-bottom:3px}
  /* legal: tighter section rhythm on phones (TOC stays a horizontal pill scroller) */
  .legal-toc a{font-size:.78rem;padding:6px 12px}
  .legal-body section{padding-bottom:var(--sp-32);margin-bottom:var(--sp-32)}
  .legal-body h2{font-size:1.4rem}
  .legal-note{margin-top:var(--sp-24);padding:var(--sp-20)}
  .end-cta{grid-template-columns:1fr;gap:var(--sp-28)}
  /* compact vertical rhythm on phones */
  .sub-head{margin-bottom:var(--sp-32)}
  .block{margin-top:var(--sp-48)}
  .block-lg{margin-top:var(--sp-48)}
  .metrics{margin-top:var(--sp-32);padding-top:var(--sp-24)}
  .crumb .ico{width:42px;height:42px}
  .crumb .ico svg{width:25px;height:25px}
  .crumb b{font-size:1.34rem}
  .p2p{max-width:260px}
  .mission-viz{max-width:380px}
  .entity-mark{display:none}
  .geo-item{grid-template-columns:46px minmax(0,1fr);gap:var(--sp-8) var(--sp-12)}
  .geo-item .geo-stat{grid-column:2;justify-self:start;padding-top:0}
}

/* reduced-motion: freeze all decorative loops, keep visuals legible */
@media(prefers-reduced-motion:reduce){
  .p2p-hot circle,.p2p-ripple circle,.wm-mark .wm-ring,.mission-viz svg,.st-rise,.mv-merid,.mv-merid2,.mv-dash,.mv-nodeac{animation:none}
  .mv-flow{display:none}
  .p2p-hot circle{opacity:1;transform:none}
  .st-rise{opacity:1}
  .p2p-ripple circle,.p2p-pk,.wm-mark .wm-ring{display:none}
}
/* roadmap cursor-spotlight — touch devices only off (kept on real mouse pointers, any width) */
@media (hover:none),(pointer:coarse){.rm-row::before{display:none}}
