/* ===========================================================================
   KEYSTONE OS — DESIGN SYSTEM  ·  keystone.css
   Tokens match the deck build exactly. Connection is the visual language;
   settlement (converge + click into place) is the motion language; a quiet
   structural substrate sits beneath; restraint is the trust signal.
   =========================================================================== */

:root{
  /* brand tokens — locked to the deck */
  --ground:#FAFAF8;
  --ink:#1A2E25;
  --body:#4A5853;
  --muted:#7A8580;
  --faint:#B8BFB9;
  --mint:#6EECC1;
  --green:#0A6E54;
  --hairline:#E4E5DF;
  --surface:#F4F4F1;
  /* warm cotton-rag sepia band, toned down from keystoneos.xyz sample */
  --paper:#F6F2EA;
  --paper-rule:#EAE4D8;

  --f-display:'Outfit', sans-serif;
  --f-body:'Inter', sans-serif;
  --f-mono:'JetBrains Mono', monospace;

  --maxw:1280px;
  --pad:clamp(24px, 5vw, 76px);
  --col-gap:clamp(16px, 2vw, 30px);

  /* settlement easing — decisive arrival, no bounce */
  --settle:cubic-bezier(.22,.7,.24,1);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:
    radial-gradient(1100px 760px at 82% 4%, rgba(110,236,193,0.055), transparent 58%),
    radial-gradient(1000px 900px at 2% 52%, rgba(10,110,84,0.04), transparent 52%),
    radial-gradient(900px 800px at 98% 88%, rgba(110,236,193,0.04), transparent 55%),
    var(--ground);
  background-attachment:fixed;
  color:var(--ink);
  font-family:var(--f-body);
  font-size:18px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ---- structural substrate: faint column rules beneath everything ---- */
.substrate{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  display:flex; justify-content:center;
}
.substrate{ display:none; }
.substrate i{
  display:block; width:100%; max-width:var(--maxw);
  margin:0 var(--pad);
  background-image:repeating-linear-gradient(
    90deg, transparent, transparent calc(100%/6 - 1px),
    var(--hairline) calc(100%/6 - 1px), var(--hairline) calc(100%/6));
  opacity:.4;
}
@media (max-width:760px){ .substrate{ display:none; } }
/* mobile scroll perf: fixed multi-gradient layers force full-viewport repaint
   on every scroll frame (esp. iOS Safari) — drop them on small screens */
@media (max-width:760px){
  body{ background-attachment:scroll; }
  body::before{ display:none; }
}

/* content sits above substrate */
.page{ position:relative; z-index:1; }
/* reusable master panel (Solutions / About) — mirrors the chapter-sec panels */
.section.master > .container{ position:relative; background:#FCFCFA; border:1px solid var(--hairline);
  box-shadow:0 30px 80px -48px rgba(26,46,37,0.30), 0 10px 30px -20px rgba(26,46,37,0.10);
  padding-top:clamp(48px,6vw,84px); padding-bottom:clamp(48px,6vw,84px); }
@media (min-width:980px){ .section.master > .container{ padding-left:clamp(48px,5vw,80px); padding-right:clamp(48px,5vw,80px); } }
/* ---- master container: faint elevated square panel per narrative section ---- */
.chapter-sec{ padding-block:clamp(56px,9vw,120px); position:relative; }
.chapter-sec > .container{ position:relative; background:transparent; border:0; box-shadow:none;
  padding-top:0; padding-bottom:0; }
@media (min-width:980px){
  .chapter-sec > .container{ padding-left:var(--pad); padding-right:var(--pad); }
}
/* section divider — a centered hairline that blocks content without a panel or sequence */
.chapter-sec + .chapter-sec::before{ content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:min(var(--maxw), calc(100% - 2*var(--pad))); height:1px; background:var(--hairline); }

/* unified ground — no harsh colour bands; depth comes from soft elevation */
:root{ --elev: 0 30px 70px -40px rgba(26,46,37,0.28), 0 8px 24px -16px rgba(26,46,37,0.12), 0 0 0 1px rgba(26,46,37,0.04), inset 0 1px 0 rgba(255,255,255,0.92), inset 0 -1px 0 rgba(26,46,37,0.07); --elev-sm: 0 14px 40px -28px rgba(26,46,37,0.22), 0 0 0 1px rgba(26,46,37,0.035), inset 0 1px 0 rgba(255,255,255,0.9), inset 0 -1px 0 rgba(26,46,37,0.06); }
.paper{ background:transparent; }
/* B — shared continuous background atmosphere: one faint wash binding all panels on a single surface */
body::before{ content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 70% at 80% 8%, rgba(110,236,193,0.05), transparent 60%),
    radial-gradient(110% 60% at 12% 92%, rgba(10,110,84,0.045), transparent 60%),
    linear-gradient(180deg, var(--ground) 0%, #F4F6F3 50%, var(--ground) 100%); }
.page{ position:relative; z-index:1; }
/* (master-container panels & corner brackets removed — sections now blocked by dividers + spacing) */
/* bespoke faint background motifs — depth behind select sections */
.who, .standard{ position:relative; overflow:hidden; }
.who > .container, .standard > .container{ position:relative; z-index:1; }
.chapter-sec::after{ display:none; }
.manifesto{ position:relative; overflow:hidden; }
.manifesto > .container{ position:relative; z-index:1; }
.opp-block, .opp{ position:relative; overflow:hidden; }
.opp-block > .container{ position:relative; z-index:1; }
/* motif chip — small elevated tile in the panel's top-right corner */
.sec-bg{ position:absolute; z-index:0; top:50%; transform:translateY(-50%); right:clamp(-60px,-3vw,-30px);
  width:clamp(300px,30vw,460px); aspect-ratio:3/2; pointer-events:none; opacity:.5;
  background-repeat:no-repeat; background-position:center right; background-size:contain; }
.sec-bg--arcs{ background-image:url("assets/bg-arcs.svg"); }
.sec-bg--fan{ background-image:url("assets/bg-fan.svg"); }
.sec-bg--orbits{ background-image:url("assets/bg-orbits.svg"); }
.sec-bg--flow{ background-image:url("assets/bg-flow.svg"); }
@media (max-width:980px){ .sec-bg{ display:none; } }
/* elevated cards arrive with weight — shadow grows in as they settle */
.ms-item, .opp-point, .std-pillar{ transition:opacity .55s var(--settle), transform .55s var(--settle), box-shadow .55s var(--settle); }
.ms-item.pre, .opp-point.pre, .std-pillar.pre{ box-shadow:none; }
.paper .split{ border-color:var(--hairline); }
.paper .split .vrule{ background:var(--hairline); }

/* ---- layout primitives ---- */
.container{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.grid{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); }
.rule{ height:1px; background:var(--hairline); border:0; margin:0; }

/* ---- type components ---- */
.eyebrow{
  font-family:var(--f-mono); font-weight:500; font-size:12px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--green);
  display:inline-flex; align-items:center; gap:11px; margin:0;
}
.eyebrow .sq{ width:8px; height:8px; background:var(--mint); display:inline-block; flex:none; }
.eyebrow.muted{ color:var(--muted); }

.kicker{ /* small mono running label, often set in a gutter */
  font-family:var(--f-mono); font-weight:500; font-size:11px;
  letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin:0;
}

.display{
  font-family:var(--f-display); font-weight:300;
  font-size:clamp(44px, 8.4vw, 116px); line-height:1.0; letter-spacing:-.04em;
  color:var(--ink); margin:0; text-wrap:balance;
}
.h2{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(30px, 5vw, 58px); line-height:1.08; letter-spacing:-.028em;
  color:var(--ink); margin:0; text-wrap:balance;
}
.h3{
  font-family:var(--f-display); font-weight:500;
  font-size:clamp(21px, 2.6vw, 28px); line-height:1.18; letter-spacing:-.018em;
  color:var(--ink); margin:0;
}
.lead{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(19px, 2.5vw, 27px); line-height:1.3; letter-spacing:-.016em;
  color:var(--ink); margin:0; text-wrap:pretty;
}
.body{
  font-family:var(--f-body); font-weight:400;
  font-size:clamp(16px, 1.55vw, 18px); line-height:1.55; color:var(--body); margin:0;
}
.body.lg{ font-size:clamp(17px, 1.9vw, 20px); }

/* mint — precious. one moment per viewport. brush is Alex's sovereign hand-built stroke. */
.hl{ display:inline; white-space:nowrap; padding:.06em .16em .12em; color:var(--ink); font-weight:inherit;
  background:url("assets/brush.png") no-repeat center; background-size:100% 82%;
  -webkit-box-decoration-break:clone; box-decoration-break:clone; }
.hl > svg, .hl > img{ display:none; }
.mint-solid{ background:var(--mint); color:var(--ink); padding:0 .12em; -webkit-box-decoration-break:clone; box-decoration-break:clone; }
@media (max-width:560px){ .hl{ white-space:normal; } }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  min-height:52px; padding:0 28px;
  font-family:var(--f-mono); font-weight:500; font-size:13px;
  letter-spacing:.14em; text-transform:uppercase; text-decoration:none;
  border:1px solid transparent; cursor:pointer; white-space:nowrap;
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.btn .arr{ transition:transform .2s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn.primary{ background:var(--ink); color:var(--ground); box-shadow:0 8px 22px -14px rgba(26,46,37,.55); transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .12s var(--ease), box-shadow .2s var(--ease); }
.btn.primary:active{ transform:translateY(1.5px); box-shadow:0 3px 10px -8px rgba(26,46,37,.5); }
.btn.primary:hover{ background:var(--green); }
.btn.ghost{ background:transparent; color:var(--ink); border-color:rgba(26,46,37,.26); }
.btn.ghost:hover{ border-color:var(--ink); background:var(--surface); }
.btn:focus-visible{ outline:2px solid var(--green); outline-offset:3px; }
.cta-row{ display:flex; flex-wrap:wrap; gap:14px 18px; align-items:center; }

/* ===========================================================================
   HEADER / NAV
   =========================================================================== */
.site-header{
  position:sticky; top:0; z-index:50; background:var(--ground);
  border-bottom:1px solid var(--hairline);
}
.site-header .bar{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.brand{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); }
.brand img{ height:26px; width:auto; display:block; }
.brand .wm{ font-family:var(--f-display); font-weight:500; letter-spacing:.2em; font-size:14px; text-transform:uppercase; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a{
  font-family:var(--f-mono); font-weight:500; font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color .18s var(--ease);
}
.nav a:hover, .nav a[aria-current="page"]{ color:var(--ink); }
.nav .btn{ min-height:42px; padding:0 18px; font-size:11px; }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ display:block; width:22px; height:1.5px; background:var(--ink); margin:5px 0; transition:transform .25s var(--ease), opacity .2s; }
.mobile-menu{ display:none; }

@media (max-width:840px){
  .nav .nav-link{ display:none; }
  .nav-toggle{ display:block; }
  .nav > .btn{ display:none; }
  .nav.open .mobile-menu{ display:flex; }
  .mobile-menu{
    display:none; position:fixed; top:64px; left:0; right:0; bottom:0;
    background:var(--ground); flex-direction:column; gap:6px; padding:28px var(--pad);
    border-top:1px solid var(--hairline);
  }
  .mobile-menu a{ font-family:var(--f-display); font-size:30px; font-weight:300; letter-spacing:-.02em; color:var(--ink); padding:14px 0; border-bottom:1px solid var(--hairline); text-transform:none; }
  .mobile-menu .btn{ display:inline-flex; margin-top:22px; }
}

/* ===========================================================================
   MOTION — settle (converge + click into place) + path draw
   Content visible by default; JS adds .settle only to below-fold elements.
   =========================================================================== */
.settle{ transition:opacity .62s var(--settle), transform .62s var(--settle); transition-delay:var(--d,0s); }
.settle.pre{ opacity:0; transform:translateY(18px) scale(.99); }
.draw{ stroke-dasharray:var(--len,1200); stroke-dashoffset:0; transition:stroke-dashoffset .9s var(--settle) var(--d,0s); }
.draw.pre{ stroke-dashoffset:var(--len,1200); }
.pop{ transform-box:fill-box; transform-origin:center; transition:opacity .5s var(--settle) var(--d,.2s), transform .6s var(--settle) var(--d,.2s); }
.pop.pre{ opacity:0; transform:scale(.7); }
@media (prefers-reduced-motion: reduce){
  .settle, .draw, .pop{ transition:none !important; }
  .settle.pre, .pop.pre{ opacity:1 !important; transform:none !important; }
  .draw.pre{ stroke-dashoffset:0 !important; }
}

/* ===========================================================================
   GREEN-CARD  (deck treatment: surface fill + hairline + 3px deep-green top rule)
   =========================================================================== */
.gcard{
  background:var(--surface); border:1px solid var(--hairline);
  border-top:3px solid var(--green); padding:clamp(26px,3vw,38px);
  display:flex; flex-direction:column;
}

/* ===========================================================================
   CONNECTION MOTIFS — recurring across the site
   =========================================================================== */
.connector{ stroke:var(--green); stroke-width:1.25; opacity:.55; }
.node-dot{ fill:var(--ground); stroke:var(--ink); stroke-width:1.4; }
.node-pip{ fill:var(--mint); }

/* shared hub-and-spoke interaction styling */
.ks-node{ cursor:pointer; }
.ks-dot{ fill:var(--ground); stroke:var(--ink); stroke-width:1.5; }
.ks-pip{ fill:var(--mint); }
.ks-dot,.ks-pip,.ks-label{ transition:fill .24s var(--ease), font-weight .24s var(--ease), opacity .24s var(--ease); }
.hub-spokes line{ transition:stroke-width .24s var(--ease), opacity .24s var(--ease), stroke .24s var(--ease); }
.hub-nodes.has-active .ks-node:not(.is-active){ opacity:.3; }
.ks-node.is-active .ks-dot{ fill:var(--mint); }
.ks-node.is-active .ks-pip{ fill:var(--ink); }
.ks-node.is-active .ks-label{ font-weight:700; fill:var(--green); }
.hub-spokes line.is-active{ stroke-width:3.2; opacity:1; stroke:var(--green); }

/* ===========================================================================
   HOME — HERO  (asymmetric, editorial, left-weighted)
   =========================================================================== */
.hero{ background:var(--ground); padding:clamp(56px,10vw,120px) 0 clamp(72px,11vw,140px); min-height:88vh; display:flex; align-items:center; position:relative; overflow:hidden; }
.hero-bg{ position:absolute; top:50%; right:-6%; transform:translateY(-50%); width:min(64vw,820px); z-index:0; pointer-events:none;
  /* height guaranteed by ratio (matches the canvas's virtual space + the SVG),
     so the wave canvas renders even if the fallback <img> fails to load */
  aspect-ratio:820 / 747; }
.hero-bg img{ width:100%; height:auto; display:block; }
.hero-hub-canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.hero .container{ position:relative; z-index:1; }
.hero .grid{ align-items:start; row-gap:clamp(34px,5vw,52px); }
.hero-eyebrow{ grid-column:1 / -1; }
.hero-head{ grid-column:1 / -1; margin-top:clamp(20px,2.5vw,30px); font-size:clamp(38px,6.2vw,82px); }
.hero-head .benefit{ display:block; font-weight:400; }
.hero-side{ grid-column:1 / -1; display:flex; flex-direction:column; gap:22px; max-width:62ch; }
.hero-cat{ font-family:var(--f-display); font-weight:400; font-size:clamp(16px,1.9vw,22px); line-height:1.3; letter-spacing:-.014em; color:var(--ink); margin:0; max-width:none; white-space:nowrap; }
.hero-cap{ color:var(--body); max-width:58ch; }
.hero .cta-row{ margin-top:10px; }
@media (min-width:880px){
  .hero-head{ grid-column:1 / span 10; }
  .hero-side{ grid-column:1 / span 9; }
}
@media (max-width:640px){
  /* Mobile: no hero animation — the hero is pure typography on phones.
     (Canvas + static fallback both removed; hero-hub.js idles harmlessly
     via its IntersectionObserver when the wrap is display:none.) */
  .hero-bg{ display:none; }
  .hero-cat{ white-space:normal; }
}

/* ===========================================================================
   HOME — ONE NEUTRAL LAYER (split canvas, asymmetric)
   =========================================================================== */
.section{ padding:clamp(76px,11vw,150px) 0; }
.section.tight{ padding:clamp(60px,8vw,110px) 0; }
.sec-head{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:baseline; }
.sec-head .kicker{ grid-column:1 / -1; margin-bottom:18px; }
.sec-head .eyebrow{ grid-column:1 / -1; margin-bottom:18px; }
.sec-head .h2{ grid-column:1 / span 9; }
.sec-head .sub{ grid-column:1 / -1; margin-top:clamp(18px,2.4vw,26px); color:var(--body); max-width:56ch; }
@media (min-width:980px){ .sec-head .sub{ grid-column:1 / span 9; } }

.setup-line{ grid-column:1 / -1; }
.split{ display:grid; grid-template-columns:1.06fr 1px .94fr; margin-top:clamp(34px,5vw,56px); border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); }
.split .vrule{ background:var(--hairline); }
.spanel{ padding:clamp(28px,3.5vw,46px) clamp(20px,3vw,42px); }
.spanel .ptitle{ font-family:var(--f-display); font-weight:400; font-size:clamp(18px,2.2vw,25px); line-height:1.16; letter-spacing:-.016em; margin:0 0 clamp(20px,3vw,30px); }
.spanel.left .ptitle{ color:var(--body); }
.spanel .cv{ width:100%; }
.spanel .cv svg{ width:100%; height:auto; display:block; }

.moat-wrap{ margin-top:clamp(56px,8vw,104px); padding-top:clamp(34px,4vw,48px); border-top:1px solid var(--paper-rule); display:flex; flex-direction:column; align-items:center; text-align:center; }
.moat-wrap .eyebrow{ margin-bottom:22px; }
.moat{ max-width:24ch; color:var(--ink); font-family:var(--f-display); font-weight:300; font-size:clamp(26px,4vw,46px); line-height:1.12; letter-spacing:-.025em; margin:0; text-wrap:balance; }

/* ===========================================================================
   HOME — OPPORTUNITY (asymmetric editorial)
   =========================================================================== */
.opp-grid{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:end; row-gap:clamp(30px,4vw,46px); }
.opp-lead{ grid-column:1 / -1; }
.opp-kicker{ font-family:var(--f-mono); font-weight:500; font-size:clamp(12px,1.3vw,14px); letter-spacing:.04em; line-height:1.5; color:var(--green); margin:0 0 clamp(18px,2.4vw,28px); }
.opp-kicker em{ font-style:normal; font-weight:700; color:var(--green); }
.opp-headline{ font-family:var(--f-display); font-weight:400; font-size:clamp(34px,4.4vw,58px); line-height:1.02; letter-spacing:-.035em; color:var(--ink); margin:0; }
@media (min-width:880px){ .opp-headline{ white-space:nowrap; } }
.opp-points{ grid-column:1 / -1; display:flex; flex-direction:column; gap:clamp(18px,2.4vw,28px); }
.opp-point{ background:var(--surface); border-top:3px solid var(--green); box-shadow:var(--elev-sm); padding:clamp(22px,2.6vw,32px); transition:opacity .55s var(--settle), transform .55s var(--settle), box-shadow .55s var(--settle); }
.opp-point:hover{ transform:translateY(-4px); box-shadow:var(--elev); }
.opp-point-t{ font-size:clamp(17px,1.95vw,22px); line-height:1.4; color:var(--ink); margin:0; text-wrap:pretty; }
.opp-point:nth-child(1) .opp-point-t br{ display:none; }
@media (min-width:880px){ .opp-point:nth-child(1) .opp-point-t br{ display:inline; } }
.opp-point:nth-child(2) .opp-point-t{ white-space:nowrap; }
.opp-point-k{ display:block; font-family:var(--f-mono); font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--green); margin:0 0 9px; }
.opp-point-t{ font-size:clamp(16px,1.8vw,20px); line-height:1.4; color:var(--ink); margin:0; text-wrap:pretty; }
.std-head .std-brush{ display:none; }
@media (min-width:980px){
  .standard .std-head .h2{ display:inline-block; max-width:none; background:url("assets/brush-underline-thin.png") no-repeat center bottom; background-size:100% 12px; padding-bottom:18px; }
  .opp-headline.opp-brush{ display:inline-block; background:url("assets/brush-underline-thin.png") no-repeat center bottom; background-size:100% 12px; padding-bottom:18px; }
}
@media (min-width:880px){ .opp-grid{ display:block; } .opp-lead{ margin-bottom:clamp(36px,5vw,60px); } .opp-points{ display:flex; flex-direction:row; align-items:flex-start; gap:clamp(24px,3vw,40px); max-width:980px; } .opp-points .opp-point:nth-child(1){ flex:1; } .opp-points .opp-point:nth-child(2){ flex:0 0 46%; margin-top:clamp(28px,3.5vw,52px); } }

/* ===========================================================================
   HOME — MANIFESTO (lead + scannable symptoms + resolution)
   =========================================================================== */
/* width rhythm handled by chapter-sec system below */
.manifesto-lead{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3.3vw,43px); line-height:1.12; letter-spacing:-.026em; color:var(--ink); margin:0; max-width:none; }
.manifesto-lead .ml-ul{ display:inline; }
@media (min-width:980px){ .manifesto-lead .ml-ul{ white-space:nowrap; background:url("assets/brush-underline-thin.png") no-repeat center bottom; background-size:100% 10px; padding-bottom:14px; } }

/* ===========================================================================
   CONNECTIVE THREAD — indexed vertical line threading the narrative sections
   ("the layer beneath," expressed structurally)
   =========================================================================== */
.chapter{ display:none; }
@media (min-width:980px){
  .chapter-sec{ position:relative; }
  /* clean centered master panels — no spine, no sequence implied; headers + panel edges block content */
  .chapter-sec > .container{
    margin-left:auto; margin-right:auto; max-width:var(--maxw); width:auto;
  }
}
.manifesto-symptoms{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3.4vw,52px); margin:clamp(40px,5.5vw,68px) 0; align-items:start; }
.ms-item{ background:none; border-top:1px solid var(--hairline); box-shadow:none; padding:clamp(22px,2.4vw,30px) 0 0; }
.ms-item:hover{ transform:none; box-shadow:none; }
@media (min-width:760px){ .ms-item{ transform:none; } }
.ms-no{ display:none; }
.ms-txt{ font-family:var(--f-display); font-weight:400; font-size:clamp(15px,1.6vw,17px); line-height:1.45; letter-spacing:-.006em; color:var(--body); margin:0; }
.ms-h{ display:block; color:var(--ink); font-weight:600; font-size:clamp(17px,1.9vw,21px); letter-spacing:-.016em; margin-bottom:.5em; white-space:nowrap; }
@media (max-width:680px){ .ms-h{ white-space:normal; } }
.manifesto-resolve{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3.4vw,46px); line-height:1.1; letter-spacing:-.026em; color:var(--ink); margin:clamp(44px,5.5vw,72px) 0 0; max-width:none; }
.manifesto-resolve .mr-lead{ display:block; font-size:clamp(24px,2.7vw,34px); line-height:1.1; }
@media (min-width:980px){ .manifesto-resolve .mr-lead{ white-space:nowrap; } }
.manifesto-resolve .mr-em{ display:block; margin-top:clamp(16px,1.8vw,24px); font-size:clamp(17px,1.7vw,21px); font-weight:300; line-height:1.4; letter-spacing:-.012em; color:var(--body); max-width:34ch; }
.manifesto-prime{ font-family:var(--f-mono); font-weight:500; font-size:clamp(13px,1.4vw,15px); letter-spacing:.04em; line-height:1.5; color:var(--green); margin:0 0 clamp(18px,2.2vw,26px); max-width:none; text-transform:none; }
.manifesto-bridge{ font-family:var(--f-display); font-weight:300; font-size:clamp(18px,2vw,24px); line-height:1.3; letter-spacing:-.016em; color:var(--body); margin:clamp(40px,5.5vw,68px) 0 0; max-width:none; text-wrap:pretty; }
.manifesto-bridge .mb-a{ display:block; }
.manifesto-bridge .mb-b{ display:block; margin-top:.4em; color:var(--ink); }
/* manifesto turn — problem and answer composed side by side, framed by a rule */
.manifesto-turn{ margin-top:clamp(48px,6vw,84px); border-top:1px solid var(--hairline); padding-top:clamp(34px,4vw,52px); display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,44px); align-items:start; }
@media (min-width:860px){ .manifesto-turn{ grid-template-columns:1fr 1fr; gap:clamp(48px,6vw,96px); } }
.mt-gap{ font-family:var(--f-display); font-weight:300; font-size:clamp(20px,2.3vw,28px); line-height:1.34; letter-spacing:-.018em; color:var(--body); margin:0; text-wrap:pretty; }
.mt-answer{ align-self:start; }
.mt-lead{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3.1vw,40px); line-height:1.08; letter-spacing:-.028em; color:var(--ink); margin:0; text-wrap:balance; }
.mt-em{ font-family:var(--f-body); font-weight:400; font-size:clamp(16px,1.7vw,19px); line-height:1.45; color:var(--body); margin:clamp(16px,1.8vw,22px) 0 0; max-width:38ch; text-wrap:pretty; }
@media (min-width:760px){ .manifesto-bridge .mb-a{ white-space:nowrap; } }
.hero-proof{ display:flex; align-items:center; gap:11px; margin:clamp(20px,2.6vw,30px) 0 0; font-family:var(--f-mono); font-size:clamp(12px,1.3vw,13.5px); font-weight:500; letter-spacing:.03em; color:var(--green); }
.hero-proof .hp-live{ position:relative; width:11px; height:11px; background:var(--mint); flex:none; box-shadow:0 0 0 1px rgba(10,110,84,.5) inset; }
.hero-proof .hp-live::after{ content:""; position:absolute; inset:0; background:var(--mint); animation:ks-live 2.2s ease-out infinite; }
@keyframes ks-live{ 0%{ box-shadow:0 0 0 0 rgba(110,236,193,.6); opacity:1; } 70%{ box-shadow:0 0 0 12px rgba(110,236,193,0); opacity:1; } 100%{ box-shadow:0 0 0 0 rgba(110,236,193,0); opacity:1; } }
@media (prefers-reduced-motion:reduce){ .hero-proof .hp-live::after{ animation:none; } }
@media (max-width:680px){ .manifesto-symptoms{ grid-template-columns:1fr; gap:0; } .ms-item{ padding-bottom:clamp(18px,4vw,24px); } }

/* ===========================================================================
   HOME — WHO IT'S FOR (interactive selector)
   =========================================================================== */
.who-head{ max-width:60ch; }
.who-kicker{ margin:0 0 clamp(16px,2vw,22px); }
.who-right{ grid-column:1 / -1; }
@media (min-width:880px){ .who-right{ grid-column:7 / -1; align-self:center; } }
.who-payoff-line{ font-family:var(--f-display); font-weight:400; font-size:clamp(21px,2.5vw,31px); line-height:1.12; letter-spacing:-.02em; color:#A2A9A2; text-align:center; margin:clamp(22px,2.8vw,34px) 0 0; text-wrap:balance; }
@media (min-width:980px){ .who-head .h2{ white-space:nowrap; } }
.who-head .sub{ color:var(--body); margin-top:clamp(16px,2vw,24px); max-width:52ch; }
.who-select{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); margin-top:clamp(40px,6vw,68px); row-gap:clamp(26px,3vw,38px); align-items:start; }
.who-tabs{ grid-column:1 / -1; display:flex; flex-direction:column; }
.who-tab{ width:100%; text-align:left; background:none; border:0; border-top:1px solid var(--hairline); cursor:pointer; padding:clamp(15px,1.9vw,22px) 4px; position:relative;
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:18px;
  font-family:var(--f-display); font-weight:500; font-size:clamp(20px,2.3vw,28px); letter-spacing:-.018em; color:var(--muted);
  transition:color .2s var(--ease), padding-left .25s var(--ease); }
.who-tab:last-child{ border-bottom:1px solid var(--hairline); }
.who-tab:not(.is-active){ opacity:.55; }
.who-tab:hover{ color:var(--ink); opacity:1; padding-left:14px; }
.who-tab.is-active{ color:var(--ink); padding-left:14px; }
.who-tab .mn{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.14em; color:var(--faint); transition:color .2s; }
.who-tab .ar{ opacity:0; transform:translateX(-6px); transition:opacity .2s var(--ease), transform .2s var(--ease); color:var(--green); }
.who-tab.is-active .mn{ color:var(--green); }
.who-tab.is-active .ar{ opacity:1; transform:none; }
.who-prog{ position:absolute; left:0; bottom:-1px; height:2px; width:0; background:var(--mint); pointer-events:none; z-index:1; }
.who-panel{ grid-column:1 / -1; background:var(--surface); border-top:3px solid var(--green); box-shadow:var(--elev); padding:clamp(28px,3.4vw,44px); }
.who-pno{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.18em; color:var(--green); margin:0 0 16px; }
.who-pdesc{ font-family:var(--f-display); font-weight:300; font-size:clamp(15px,1.8vw,22px); line-height:1.34; letter-spacing:-.014em; color:var(--ink); margin:0; text-wrap:pretty; max-width:34ch; }
.who-cta{ display:inline-flex; margin-top:clamp(36px,5vw,56px); }
@media (min-width:880px){ .who-tabs{ grid-column:1 / span 5; } .who-panel{ grid-column:7 / -1; align-self:center; min-height:320px; display:flex; flex-direction:column; justify-content:flex-start; } }

/* ===========================================================================
   HOME — (legacy) DISTRIBUTION CHART — retained for reference, unused
   =========================================================================== */
.opp-chart{ position:relative; }
.opp-chart img{ width:100%; height:auto; display:block; }
.grow-reveal img, .grow-reveal svg{ clip-path:inset(0 0 0 0); transition:clip-path 1.5s var(--settle); }
.grow-reveal.pre img, .grow-reveal.pre svg{ clip-path:inset(0 100% 0 0); }
@media (prefers-reduced-motion:reduce){ .grow-reveal img, .grow-reveal svg{ transition:none; } .grow-reveal.pre img, .grow-reveal.pre svg{ clip-path:none; } }

/* ===========================================================================
   THE SWIFT ANALOGY
   =========================================================================== */
.swift-sec{ text-align:center; }
.swift-wrap{ display:flex; flex-direction:column; align-items:center; }
.swift-sec .eyebrow{ margin-bottom:clamp(28px,4vw,44px); }
.swift-frame{ font-family:var(--f-display); font-weight:300; font-size:clamp(20px,2.8vw,32px); line-height:1.2; letter-spacing:-.02em; color:var(--muted); margin:0 0 clamp(26px,3.5vw,42px); max-width:24ch; }
.swift-mark{ display:flex; justify-content:center; max-width:100%; }
.swift-brush-line{ position:relative; display:inline-block; padding:clamp(20px,2.4vw,30px) clamp(34px,4vw,58px); max-width:100%; }
.swift-brush{ position:absolute; left:-2%; right:-2%; top:50%; transform:translateY(-50%); width:104%; height:128%; z-index:0; pointer-events:none; object-fit:fill; }
.swift-text{ position:relative; z-index:1; font-family:var(--f-display); font-weight:300; font-size:clamp(26px,4.4vw,52px); line-height:1.12; letter-spacing:-.025em; color:var(--ink); }
.swift-text .globe{ display:inline-flex; vertical-align:-.06em; }
.swift-text .globe svg{ width:.78em; height:.78em; display:block; }
.swift-word{ font-weight:600; letter-spacing:-.015em; }
.swift-sub{ margin-top:clamp(30px,4vw,46px); color:var(--body); font-size:clamp(16px,1.8vw,19px); line-height:1.5; max-width:46ch; }
@media (max-width:600px){ .swift-text{ font-size:clamp(24px,7vw,32px); } }
/* chart life — a light travelling up the mint line; layers breathe softly */
@keyframes ks-flow{ to{ stroke-dashoffset:-1200; } }
@keyframes ks-breathe{ 0%,100%{ opacity:.42; } 50%{ opacity:.62; } }
.chart-mintflow{ fill:none; stroke:#EAFBF4; stroke-width:5; stroke-linecap:round; stroke-dasharray:36 1164; stroke-dashoffset:0; animation:ks-flow 3.8s linear infinite; opacity:.85; }
.chart-layers{ animation:ks-breathe 5.5s ease-in-out infinite; }
@media (prefers-reduced-motion:reduce){ .chart-mintflow{ display:none; } .chart-layers{ animation:none; } }

/* ===========================================================================
   HOME — PROBLEM: two parallel rows (text + static graphic)
   =========================================================================== */
.prob-row{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:center; row-gap:clamp(26px,4vw,40px); }
.prob-row + .prob-row{ margin-top:clamp(56px,8vw,104px); }
.prob-text{ grid-column:1 / -1; }
.prob-text .eyebrow{ margin-bottom:20px; }
.prob-text .h2{ margin:0 0 clamp(16px,2vw,22px); }
.prob-text .sub{ color:var(--body); max-width:42ch; margin:0; }
.prob-graphic{ grid-column:1 / -1; }
.prob-graphic img{ width:100%; height:auto; display:block; }
.prob-cap{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:18px 0 0; text-align:center; }
@media (min-width:880px){
  .prob-text{ grid-column:1 / span 5; }
  .prob-graphic{ grid-column:7 / -1; }
  /* row 2: graphic left, text right */
  .prob-row.reverse .prob-graphic{ grid-column:1 / span 6; }
  .prob-row.reverse .prob-text{ grid-column:8 / -1; }
}

/* section transition — subtle continuous data-grid motif (no colour change) */
.close-hubsec{ position:relative; overflow:hidden; }
.close-hub{ position:absolute; top:50%; right:-6%; transform:translateY(-50%); width:min(46vw,560px); z-index:0; pointer-events:none; opacity:.9; }
.close-hub img{ width:100%; height:auto; display:block; }
.close-hubsec .container{ position:relative; z-index:1; }
@media (max-width:760px){ .close-hub{ opacity:.4; width:80%; right:-20%; } }
.manifesto{ position:relative; overflow:hidden; }
.manifesto > .grid-field{ position:absolute; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; opacity:.55;
  -webkit-mask-image:radial-gradient(120% 90% at 70% 50%, #000 0%, #000 45%, transparent 85%);
  mask-image:radial-gradient(120% 90% at 70% 50%, #000 0%, #000 45%, transparent 85%); }
.manifesto > .container{ position:relative; z-index:1; }
.grid-transition{ position:relative; width:100%; height:clamp(120px,16vh,190px); overflow:hidden;
  background:transparent; }
.grid-field{ position:absolute; inset:0; width:100%; height:100%; display:block; pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 34%, #000 66%, transparent 100%);
  mask-image:linear-gradient(180deg, transparent 0%, #000 34%, #000 66%, transparent 100%); }

/* ===========================================================================
   HOME — PROBLEM & SOLUTION (tabbed reveal, Chainlink-style)
   =========================================================================== */
.ps-tabs{ margin-top:clamp(6px,1vw,14px); }
.ps-tabrow{ display:flex; gap:clamp(24px,4vw,48px); border-bottom:1px solid var(--paper-rule); }
.ps-tab{ position:relative; background:none; border:0; cursor:pointer; padding:0 0 18px; margin:0;
  font-family:var(--f-display); font-weight:500; font-size:clamp(20px,2.6vw,30px); letter-spacing:-.018em;
  color:var(--muted); transition:color .2s var(--ease); }
.ps-tab:hover{ color:var(--ink); }
.ps-tab.is-active{ color:var(--ink); }
.ps-tab.is-active::after{ content:""; position:absolute; left:0; bottom:-1px; width:100%; height:2px; background:var(--ink); }
.ps-panels{ margin-top:clamp(36px,5vw,60px); }
.ps-panel[hidden]{ display:none; }
.ps-panel{ animation:psFade .35s cubic-bezier(.22,.7,.24,1); }
@keyframes psFade{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .ps-panel{ animation:none; } }
.ps-grid{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:center; row-gap:clamp(26px,4vw,38px); }
.ps-visual{ grid-column:1 / -1; margin:0; }
.ps-card{ background:transparent; border:none; border-top:2px solid rgba(10,110,84,.35);
  padding:clamp(16px,2.4vw,32px) 0 0; display:flex; align-items:center; justify-content:center; }
.ps-card img{ width:100%; height:auto; display:block; max-width:520px; }
.ps-cap{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:16px 0 0; text-align:center; }
.ps-points{ grid-column:1 / -1; }
.ps-head{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3.2vw,40px); line-height:1.08; letter-spacing:-.024em; color:var(--ink); margin:0 0 clamp(16px,2vw,22px); text-wrap:balance; }
.ps-lead{ font-size:clamp(16px,1.8vw,19px); line-height:1.5; color:var(--body); margin:0 0 clamp(26px,3.4vw,36px); max-width:46ch; }
.ps-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:clamp(18px,2.4vw,26px); }
.ps-list li{ display:grid; grid-template-columns:auto 1fr; gap:clamp(16px,2vw,24px); align-items:start; }
.ps-no{ font-family:var(--f-mono); font-size:13px; font-weight:600; letter-spacing:.14em; color:var(--green); padding-top:3px; }
.ps-pt{ font-size:clamp(15px,1.7vw,18px); line-height:1.5; color:var(--body); text-wrap:pretty; }
.ps-pt-h{ color:var(--ink); font-weight:600; }
@media (min-width:880px){
  .ps-visual{ grid-column:1 / span 6; }
  .ps-points{ grid-column:8 / -1; }
}

/* ===========================================================================
   HOME — WHAT IT DOES: capability explorer (menu + detail panel)
   =========================================================================== */
.cap-explorer{ grid-column:1 / -1; display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); margin-top:clamp(40px,6vw,68px); align-items:stretch; }
.cap-menu{ grid-column:1 / span 6; list-style:none; margin:0; padding:0; border-top:1px solid var(--hairline); }
.cap-menu li{ margin:0; }
.cap-menu button{
  width:100%; text-align:left; background:none; border:0; cursor:pointer;
  position:relative;
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:18px;
  padding:clamp(18px,2.4vw,26px) 4px; border-bottom:1px solid var(--hairline);
  font-family:var(--f-display); font-weight:500; font-size:clamp(20px,2.4vw,28px);
  letter-spacing:-.016em; color:var(--muted); transition:color .2s var(--ease), padding-left .25s var(--ease);
}
.cap-menu button .mn{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.14em; color:var(--faint); transition:color .2s; }
.cap-menu button .ar{ opacity:0; transform:translateX(-6px); transition:opacity .2s var(--ease), transform .2s var(--ease); color:var(--green); }
.cap-menu button:hover{ color:var(--ink); padding-left:14px; }
.cap-menu button.is-active{ color:var(--ink); padding-left:14px; }
.cap-menu button.is-active .mn{ color:var(--green); }
.cap-menu button.is-active .ar{ opacity:1; transform:none; }
.cap-prog{ position:absolute; left:0; bottom:-1px; height:2px; width:0; background:var(--mint); pointer-events:none; }
.cap-detail{ grid-column:8 / -1; align-self:start; padding-top:clamp(20px,2.6vw,30px); }
.cap-detail .dno{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.18em; color:var(--green); margin:0 0 16px; }
.cap-detail .dname{ font-family:var(--f-display); font-weight:400; font-size:clamp(28px,3.4vw,42px); letter-spacing:-.022em; color:var(--ink); margin:0 0 18px; line-height:1.06; text-wrap:balance; }
.cap-detail .ddesc{ font-size:clamp(16px,1.8vw,19px); line-height:1.5; color:var(--body); margin:0 0 24px; max-width:42ch; }
.cap-detail .ditems{ transition:opacity .28s var(--ease), transform .28s var(--ease); }
.cap-detail .ditems.swap{ opacity:0; transform:translateY(8px); }
@media (max-width:820px){
  .cap-explorer{ display:block; }
  .cap-menu{ display:none; }
  .cap-usecase .cap-tabrow, .cap-usecase .cap-panel{ display:none; }
  .cap-accordion{ display:block; border-top:1px solid var(--hairline); }
  .acc-item{ border-bottom:1px solid var(--hairline); }
  .acc-head{ width:100%; text-align:left; background:none; border:0; cursor:pointer; display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:center; padding:20px 2px; font-family:var(--f-display); font-weight:500; font-size:22px; letter-spacing:-.014em; color:var(--ink); }
  .acc-head .mn{ font-family:var(--f-mono); font-size:12px; letter-spacing:.14em; color:var(--green); }
  .acc-head .pl{ color:var(--green); font-family:var(--f-mono); transition:transform .25s var(--ease); }
  .acc-item.open .acc-head .pl{ transform:rotate(45deg); }
  .acc-body{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
  .acc-item.open .acc-body{ max-height:260px; }
  .acc-body p{ font-size:16px; line-height:1.5; color:var(--body); margin:0 0 18px; max-width:46ch; }
}
@media (min-width:821px){ .cap-accordion{ display:none; } }

/* ---- WHAT IT DOES variant: Chainlink-style tabs + visual/checkmarks ---- */
.caps.section{ padding-block:clamp(58px,8vw,104px); }
/* Problem & Solution — tighter vertical rhythm, flows into next section */
.ps-sec.section.paper{ padding-block:clamp(44px,6vw,80px); }
.cap-usecase{ display:block; margin-top:clamp(34px,4.5vw,56px); }
.cap-tabrow{ display:flex; flex-wrap:wrap; gap:clamp(20px,3vw,42px); border-bottom:1px solid var(--hairline); }
.cap-tabrow .captab{ position:relative; background:none; border:0; cursor:pointer; padding:0 0 16px; margin:0;
  font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); transition:color .2s var(--ease); }
.cap-tabrow .captab:hover{ color:var(--ink); }
.cap-tabrow .captab.is-active{ color:var(--ink); }
.cap-tabrow .captab .cap-prog{ bottom:-1px; height:2px; }
.cap-tabrow .captab.is-active::after{ content:""; position:absolute; left:0; bottom:-1px; width:100%; height:2px; background:var(--ink); }
.cap-tabrow .captab.is-active .cap-prog{ background:var(--mint); z-index:1; }

.cap-panel{ margin-top:clamp(36px,5vw,60px); }
.cap-panel-grid{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:center; row-gap:clamp(28px,4vw,40px);
  transition:opacity .28s var(--ease), transform .28s var(--ease); }
.cap-panel-grid.swap{ opacity:0; transform:translateY(8px); }
.cap-visual{ grid-column:1 / -1; margin:0; }
.cap-card{ position:relative; background:var(--surface); border-top:3px solid var(--green); box-shadow:var(--elev);
  aspect-ratio:16/10; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.cap-card-no{ position:absolute; top:clamp(16px,2vw,24px); left:clamp(18px,2.2vw,26px); font-family:var(--f-mono);
  font-size:13px; font-weight:600; letter-spacing:.16em; color:var(--green); margin:0; }
.cap-card-glyph{ width:min(56%,260px); height:auto; display:block; }
.cap-card-cap{ font-family:var(--f-display); font-weight:500; font-size:clamp(18px,2vw,23px); letter-spacing:-.016em;
  color:var(--ink); margin:clamp(18px,2vw,24px) 0 0; text-wrap:balance; }
.cap-points{ grid-column:1 / -1; }
.cap-points-head{ font-family:var(--f-display); font-weight:400; font-size:clamp(24px,3vw,36px); letter-spacing:-.022em;
  line-height:1.08; color:var(--ink); margin:0 0 clamp(22px,3vw,30px); text-wrap:balance; }
.cap-checks{ list-style:none; margin:0 0 clamp(26px,3vw,34px); padding:0; display:flex; flex-direction:column; gap:clamp(16px,2vw,22px); }
.cap-checks li{ position:relative; padding-left:38px; font-size:clamp(16px,1.7vw,18px); line-height:1.5; color:var(--ink); text-wrap:pretty; }
.cap-checks li::before{ content:""; position:absolute; left:0; top:.05em; width:22px; height:22px; border-radius:50%;
  background:var(--mint); box-shadow:inset 0 0 0 1px var(--ink); }
.cap-checks li::after{ content:""; position:absolute; left:7px; top:.43em; width:8px; height:4px;
  border-left:1.6px solid var(--ink); border-bottom:1.6px solid var(--ink); transform:rotate(-45deg); }
@media (min-width:821px){
  .cap-visual{ grid-column:1 / span 6; }
  .cap-points{ grid-column:8 / -1; }
}

/* Solutions explorer — taller menu + detail with headline & flow steps */
.sol-explorer{ margin-top:clamp(20px,3vw,40px); align-items:stretch; }
.sol-explorer .cap-menu button{ font-size:clamp(19px,2.1vw,25px); }
.sol-detail-panel{ align-self:start; display:flex; flex-direction:column; justify-content:flex-start; padding-top:clamp(8px,1.5vw,20px); }
.sol-detail-panel .dno{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.18em; color:var(--green); margin:0 0 18px; }
.sol-detail-panel .dhead{ font-family:var(--f-display); font-weight:400; font-size:clamp(28px,3.6vw,46px); line-height:1.06; letter-spacing:-.024em; color:var(--ink); margin:0 0 20px; text-wrap:balance; }
.sol-detail-panel .ddesc{ font-size:clamp(16px,1.9vw,20px); line-height:1.5; color:var(--body); margin:0 0 28px; max-width:46ch; }
.sol-detail-panel .dsteps{ margin:0; }
/* Per CTO: reserve a min-height on the explorer SECTION (desktop two-column only)
   sized to the TALLEST capability at ANY width, so switching capabilities never
   pushes the section below. Peak measured ~565px (Multilateral/Fund near ~1150px);
   Treasury's headline ("Fragmented treasuries," + <br>) can wrap to 3 lines at
   intermediate widths. Reserve 600px for comfortable headroom. Content flows
   naturally inside; any surplus is calm trailing space at the bottom. */
@media (min-width:821px){ .sol-explorer{ min-height:600px; } }
.sol-bullets{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:clamp(14px,1.8vw,20px); }
.sol-bullets li{ position:relative; padding-left:30px; font-size:clamp(15px,1.7vw,18px); line-height:1.5; color:var(--ink); text-wrap:pretty; }
.sol-bullets li::before{ content:""; position:absolute; left:0; top:.5em; width:11px; height:11px; background:var(--mint); border:1px solid var(--ink); }

/* ===========================================================================
   SOLUTIONS — COMPLIANCE STACK (independent stream asset + layer stack)
   =========================================================================== */
.compliance .comp-head{ max-width:62ch; }
.compliance .eyebrow{ margin-bottom:22px; }
.comp-title{ display:inline-block; }
.comp-brush{ display:block; width:100%; height:auto; margin:10px 0 0; }
.comp-lead{ color:var(--body); margin-top:clamp(20px,2.6vw,30px); max-width:54ch; }
.comp-body{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:stretch; margin-top:clamp(38px,5vw,60px); row-gap:clamp(20px,3vw,28px); }
.comp-stream-panel{ grid-column:1 / -1; position:relative; display:flex; flex-direction:column; min-height:300px;
  border-top:3px solid var(--green); background:var(--surface); overflow:hidden; box-shadow:var(--elev); }
.comp-stream{ position:absolute; left:0; right:0; top:48px; bottom:48px; width:100%; height:auto; display:block; pointer-events:none; opacity:.9;
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
  mask-image:linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%); }
.comp-flowtag{ position:relative; z-index:1; text-align:center; padding:16px 0; font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); }
.comp-flowtag--out{ margin-top:auto; color:var(--green); }
.comp-layers{ grid-column:1 / -1; display:flex; flex-direction:column; border-top:3px solid var(--green); background:var(--ground); box-shadow:var(--elev); }
.comp-layer{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex:1;
  padding:clamp(22px,2.8vw,32px) clamp(22px,3vw,40px); border-bottom:1px solid var(--hairline);
  transition:background .3s var(--ease); }
.comp-layer:last-child{ border-bottom:0; }
.comp-layer:hover{ background:rgba(110,236,193,.10); }
.comp-layer-l{ display:flex; align-items:baseline; gap:clamp(16px,2vw,26px); min-width:0; }
.comp-no{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.16em; color:var(--green); flex:none; }
.comp-fn{ font-family:var(--f-display); font-weight:500; font-size:clamp(19px,2.2vw,27px); letter-spacing:-.018em; color:var(--ink); }
.comp-partner{ font-family:var(--f-mono); font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink);
  background:var(--surface); border:1px solid var(--hairline); border-left:2px solid var(--green); padding:9px 16px; white-space:nowrap; flex:none;
  min-width:128px; text-align:center; }
@media (min-width:880px){
  .comp-stream-panel{ grid-column:1 / span 4; }
  .comp-layers{ grid-column:5 / -1; }
}
@media (max-width:560px){
  .comp-layer{ flex-direction:column; align-items:flex-start; gap:14px; }
}

/* ===========================================================================
   HOME — CAPABILITIES TEASER (connected editorial list)
   =========================================================================== */
.caps .grid{ row-gap:0; }
.caps-head{ grid-column:1 / span 5; align-self:start; position:sticky; top:96px; }
.caps-head .h2{ margin-top:8px; }
.caps-head .lk{ margin-top:26px; display:inline-flex; }
.caps-list{ grid-column:7 / -1; border-top:1px solid var(--hairline); }
@media (max-width:860px){ .caps-head{ grid-column:1 / -1; position:static; } .caps-list{ grid-column:1 / -1; margin-top:34px; } }
.cap-row{
  display:grid; grid-template-columns:auto 1fr; column-gap:22px; align-items:baseline;
  padding:clamp(20px,2.6vw,30px) 0; border-bottom:1px solid var(--hairline);
  position:relative; text-decoration:none;
}
.cap-row .ix{ font-family:var(--f-mono); font-weight:500; font-size:12px; letter-spacing:.16em; color:var(--green); padding-top:6px; }
.cap-row .nm{ display:block; font-family:var(--f-display); font-weight:500; font-size:clamp(20px,2.3vw,26px); letter-spacing:-.016em; color:var(--ink); }
.cap-row .ds{ display:block; font-size:15px; line-height:1.5; color:var(--body); margin:8px 0 0; max-width:52ch; }
.cap-row:hover .nm{ color:var(--green); }

/* ===========================================================================
   HOME — THE SWIFT MOMENT (hub alone + full-line brush)
   =========================================================================== */
.swift{ padding:clamp(80px,12vw,160px) 0; text-align:center; }
.swift .hub-hold{ max-width:560px; margin:0 auto clamp(48px,7vw,84px); }
.swift .hub-hold svg{ width:100%; height:auto; display:block; }
.swift-line{
  position:relative; display:inline-block;
  font-family:var(--f-display); font-weight:300;
  font-size:clamp(30px,5.6vw,68px); line-height:1.1; letter-spacing:-.03em;
  color:var(--ink); margin:0; max-width:18ch; text-wrap:balance;
}
.swift-line .swift-brush{ position:absolute; left:-2%; right:-2%; top:8%; width:104%; height:84%; z-index:-1; pointer-events:none; }
.swift-word{ font-weight:500; }

/* ===========================================================================
   HOME — PROOF BAND
   =========================================================================== */
.proof{ border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); }
.proof .row{ display:grid; grid-template-columns:1fr 1px 1fr 1px 1fr; }
.proof .pv{ background:var(--hairline); }
.proof .cell{ padding:clamp(32px,4.5vw,50px) clamp(18px,2.6vw,38px); }
.proof .plabel{ font-family:var(--f-display); font-weight:500; font-size:clamp(16px,1.9vw,20px); letter-spacing:-.012em; margin:0 0 11px; }
.proof .pdetail{ font-family:var(--f-mono); font-size:clamp(10.5px,1vw,12px); font-weight:500; letter-spacing:.08em; color:var(--muted); margin:0; line-height:1.6; white-space:nowrap; }
@media (max-width:760px){ .proof .pdetail{ white-space:normal; } }
@media (max-width:760px){ .proof .row{ grid-template-columns:1fr; } .proof .pv{ height:1px; } }

/* ===========================================================================
   HOME — CLOSE
   =========================================================================== */
.close{ background:var(--ground); padding:clamp(90px,14vw,170px) 0; }
.close-streams .grid{ align-items:center; row-gap:clamp(36px,5vw,56px); }
.close-copy{ grid-column:1 / -1; }
.close-anim{ grid-column:1 / -1; position:relative; height:clamp(300px,40vw,440px); }
.close-anim .stream-field{ position:absolute; inset:0; width:100%; height:100%; display:block; pointer-events:none;
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 16%, #000 84%, transparent 100%);
  mask-image:linear-gradient(90deg, transparent 0%, #000 16%, #000 84%, transparent 100%); }
@media (min-width:900px){
  .close-copy{ grid-column:1 / span 6; }
  .close-anim{ grid-column:8 / -1; }
}
/* Mobile: no close-section animation on phones (Home close keeps copy + CTAs only).
   Scoped to .close-streams so the Solutions compliance stream is unaffected. */
@media (max-width:640px){
  .close-streams .close-anim{ display:none; }
}
.close .eyebrow{ margin-bottom:20px; }
/* plain close (Solutions/About/Docs) — full-width grid rows, no scattered tracks */
.close:not(.close-streams) .grid{ align-items:start; }
.close:not(.close-streams) .eyebrow{ grid-column:1 / -1; white-space:nowrap; }
.close:not(.close-streams) .close-line{ grid-column:1 / -1; }
.close:not(.close-streams) .cta-row{ grid-column:1 / -1; }
/* Solutions close — copy left, hub-and-spoke graphic parallel on the right */
.close-graphic .close-copy-col{ grid-column:1 / -1; }
.close-graphic .close-copy-col .eyebrow{ white-space:nowrap; margin-bottom:20px; }
.close-graphic .close-copy-col .cta-row{ margin-top:clamp(26px,3vw,38px); }
/* Ecosystem access — payoff statements folded into the Solutions close */
.eco-eyebrow{ font-family:var(--f-mono); font-weight:600; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--green); margin:0 0 18px; }
.eco-lead{ color:var(--body); margin:clamp(20px,2.4vw,28px) 0 0; max-width:46ch; }
.eco-points{ list-style:none; margin:clamp(26px,3vw,36px) 0 0; padding:0; display:flex; flex-direction:column; max-width:52ch; }
.eco-point{ display:grid; grid-template-columns:minmax(96px,0.32fr) 1fr; gap:clamp(14px,2vw,28px); align-items:baseline; padding:clamp(15px,1.9vw,20px) 0; border-top:1px solid var(--hairline); }
.eco-point:last-child{ border-bottom:1px solid var(--hairline); }
.eco-k{ font-family:var(--f-mono); font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--green); }
.eco-t{ font-family:var(--f-body); font-weight:400; font-size:clamp(15px,1.55vw,16.5px); line-height:1.5; color:var(--body); margin:0; text-wrap:pretty; }
@media (max-width:520px){ .eco-point{ grid-template-columns:1fr; gap:5px; } }
.close-graphic.close-graphic{ position:relative; overflow:hidden; }
.close-graphic .close-graphic-col{ grid-column:1 / -1; }
.close-graphic .close-graphic-col img{ width:100%; height:auto; display:block; }
@media (min-width:880px){
  .close-graphic .grid{ align-items:center; }
  .close-graphic .close-copy-col{ grid-column:1 / -1; position:relative; z-index:1; max-width:60%; }
  .close-graphic .close-hub-bg{ position:absolute; top:50%; right:-8%; transform:translateY(-50%);
    width:min(52vw,640px); opacity:.9; z-index:0; pointer-events:none; }
  .close-graphic .close-line{ font-size:clamp(36px,4.6vw,60px); }
}
.close-line{ font-family:var(--f-display); font-weight:400; font-size:clamp(36px,5.6vw,72px); line-height:1.04; letter-spacing:-.035em; margin:0; text-wrap:balance; }
.close-streams .close-line{ font-size:clamp(32px,4.4vw,56px); }
.close-sub{ max-width:48ch; margin-top:clamp(18px,2.4vw,26px); }
.close .cta-row{ margin-top:clamp(26px,3vw,38px); }

/* ===========================================================================
   HOME — WHY / THE STANDARD (three-pillar confidence band)
   =========================================================================== */
.standard .std-head{ max-width:none; }
.standard .std-head .h2{ font-weight:400; font-size:clamp(30px,4.3vw,56px); }
@media (min-width:980px){ .standard .std-head .h2{ white-space:normal; max-width:none; } }
.d-br{ display:none; }
@media (min-width:980px){ .d-br{ display:inline; } }
.standard .eyebrow{ margin-bottom:22px; }
.standard .std-lead{ color:var(--body); margin-top:clamp(18px,2.4vw,26px); max-width:60ch; }
.std-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(24px,3vw,40px); margin-top:clamp(40px,6vw,68px); align-items:stretch; }
.std-pillar{ background:var(--surface); border-top:3px solid var(--green); box-shadow:var(--elev-sm); padding:clamp(30px,3.2vw,42px) clamp(28px,3vw,38px) clamp(28px,3vw,36px); display:flex; flex-direction:column; transition:transform .6s var(--settle), opacity .6s var(--settle), box-shadow .3s var(--ease); }
.std-pillar:hover{ transform:translateY(-4px); box-shadow:var(--elev); }
@media (min-width:760px){ .std-pillar:nth-child(1){ --dx:72px; } .std-pillar:nth-child(3){ --dx:-72px; } .std-pillar.settle.pre{ opacity:0; transform:translateX(var(--dx,0)) scale(.93); } }
.std-no{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.18em; color:var(--green); margin:0 0 16px; }
.std-name{ font-family:var(--f-display); font-weight:500; font-size:clamp(19px,2vw,24px); letter-spacing:-.018em; color:var(--ink); margin:0 0 16px; white-space:nowrap; }
@media (max-width:760px){ .std-name{ white-space:normal; } }
.std-body{ font-size:clamp(15px,1.55vw,16.5px); line-height:1.62; color:var(--body); margin:0; text-wrap:pretty; }
.std-detail{ font-family:var(--f-mono); font-size:clamp(9.5px,0.82vw,10.5px); font-weight:500; letter-spacing:.05em; text-transform:uppercase; color:var(--green); margin:18px 0 0; white-space:nowrap; }
.std-pillar .std-detail{ margin-top:auto; padding-top:clamp(22px,3vw,30px); }
/* About — elevated principle cards + emphasized opening line */
.about-prime{ font-family:var(--f-display); font-weight:300; font-size:clamp(15px,1.82vw,22px); line-height:1.32; letter-spacing:-.018em; color:var(--ink); text-wrap:pretty; }
.about-cards{ display:flex; flex-direction:column; gap:clamp(18px,2.4vw,28px); }
.about-card{ background:var(--surface); border-top:3px solid var(--green); box-shadow:var(--elev-sm); padding:clamp(24px,2.8vw,34px); transition:opacity .55s var(--settle), transform .55s var(--settle), box-shadow .55s var(--settle); }
.about-card.pre{ box-shadow:none; }
.about-card:hover{ transform:translateY(-4px); box-shadow:var(--elev); }
.about-card p{ font-size:clamp(16px,1.7vw,19px); line-height:1.5; color:var(--body); margin:0; }
/* About — neutrality "three nevers" structured facts */
.neu-facts{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.neu-fact{ display:grid; grid-template-columns:minmax(120px,0.4fr) 1fr; gap:clamp(14px,2.4vw,32px); align-items:baseline;
  padding:clamp(18px,2.2vw,26px) 0; border-top:1px solid var(--hairline); }
.neu-fact:last-child{ border-bottom:1px solid var(--hairline); }
.neu-k{ font-family:var(--f-display); font-weight:500; font-size:clamp(19px,2.1vw,26px); letter-spacing:-.018em; color:var(--ink); }
.neu-v{ font-family:var(--f-body); font-weight:400; font-size:clamp(15px,1.6vw,17px); line-height:1.5; color:var(--body); }
.neu-principle{ font-family:var(--f-display); font-weight:300; font-size:clamp(18px,2vw,24px); line-height:1.32; letter-spacing:-.014em; color:var(--ink); margin:clamp(22px,3vw,32px) 0 0; text-wrap:pretty; }
@media (max-width:520px){ .neu-fact{ grid-template-columns:1fr; gap:6px; } }
@media (max-width:760px){ .std-grid{ grid-template-columns:1fr; gap:0; } .std-pillar{ padding-bottom:clamp(24px,5vw,32px); } .std-pillar + .std-pillar{ margin-top:0; } .std-pillar .std-detail{ margin-top:18px; padding-top:0; } }

/* ===========================================================================
   FOOTER
   =========================================================================== */
.site-footer{ position:relative; z-index:1; border-top:1px solid var(--ink); background:var(--ground); }
.site-footer .top{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); padding:clamp(48px,6vw,72px) 0 clamp(36px,4vw,52px); row-gap:34px; }
.foot-brand{ grid-column:1 / span 5; display:flex; flex-direction:column; gap:16px; }
.foot-brand .wm{ font-family:var(--f-display); font-weight:500; letter-spacing:.2em; font-size:15px; text-transform:uppercase; display:inline-flex; align-items:center; gap:11px; color:var(--ink); text-decoration:none; align-self:flex-start; }
.foot-brand .wm img{ height:24px; width:auto; }
.foot-vision{ font-family:var(--f-display); font-weight:300; font-size:clamp(20px,2.4vw,28px); letter-spacing:-.02em; line-height:1.16; color:var(--ink); margin:0; max-width:none; }
.foot-vision br{ display:block; }
.foot-nav{ grid-column:7 / span 3; display:flex; flex-direction:column; gap:14px; }
.foot-social{ grid-column:10 / -1; display:flex; flex-direction:column; gap:14px; }
.foot-col-h{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 4px; }
.foot-nav a, .foot-social a{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:color .18s; }
.foot-nav a:hover, .foot-social a:hover{ color:var(--green); }
.site-footer .legal{ border-top:1px solid var(--hairline); padding:22px 0 30px; display:flex; flex-wrap:wrap; gap:8px 26px; justify-content:space-between; }
.site-footer .legal p{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.08em; line-height:1.7; color:var(--muted); margin:0; max-width:none; }
@media (min-width:980px){ .site-footer .legal p{ white-space:nowrap; font-size:clamp(6px,0.63vw,8.2px); letter-spacing:.015em; line-height:1.6; } }
@media (max-width:760px){
  .foot-brand{ grid-column:1 / -1; } .foot-nav{ grid-column:1 / span 6; } .foot-social{ grid-column:7 / -1; }
}

/* ===========================================================================
   INTERIOR PAGE HERO (Solutions / About / Docs)
   =========================================================================== */
.page-hero{ padding:clamp(54px,8vw,104px) 0 clamp(40px,6vw,72px); border-bottom:1px solid var(--hairline); }
.page-hero .eyebrow{ margin-bottom:22px; }
.page-hero .grid{ align-items:end; row-gap:26px; }
.page-hero .display{ grid-column:1 / span 10; font-size:clamp(40px,6.6vw,88px); }
.page-hero .sub{ grid-column:1 / -1; color:var(--body); max-width:54ch; margin-top:6px; }
@media (min-width:980px){ .page-hero .sub{ grid-column:1 / span 7; } }

/* Solutions hero — animated connection field on the right */
.sol-hero{ position:relative; overflow:hidden; min-height:clamp(360px,52vh,540px); display:flex; align-items:center; }
.sol-hero .container{ position:relative; z-index:1; width:100%; }
.hero-anim{ position:absolute; top:0; right:0; height:100%; width:64%; z-index:0; pointer-events:none; display:block;
  opacity:0; transition:opacity 1.1s var(--ease);
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,.5) 26%, #000 60%);
  mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,.5) 26%, #000 60%); }
.hero-anim.in{ opacity:1; }
@media (min-width:980px){
  .sol-hero .display{ grid-column:1 / span 7; }
  .sol-hero .sub{ grid-column:1 / span 6; }
}
@media (max-width:760px){
  .hero-anim{ width:100%; opacity:0; }
  .hero-anim.in{ opacity:.32; }
}

/* ===========================================================================
   SOLUTIONS
   =========================================================================== */
.sol-spine{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); align-items:start; }
.sol-index{ grid-column:1 / span 4; position:sticky; top:96px; align-self:start; display:flex; flex-direction:column; }
.sol-index .ix-h{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 22px; }
.sol-index a{
  display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:baseline;
  padding:15px 0; border-top:1px solid var(--hairline); text-decoration:none;
  color:var(--muted); transition:color .2s var(--ease);
}
.sol-index a:last-child{ border-bottom:1px solid var(--hairline); }
.sol-index a .n{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.12em; color:var(--faint); transition:color .2s var(--ease); }
.sol-index a .t{ font-family:var(--f-display); font-weight:500; font-size:18px; letter-spacing:-.012em; }
.sol-index a:hover, .sol-index a.is-current{ color:var(--ink); }
.sol-index a:hover .n, .sol-index a.is-current .n{ color:var(--green); }
.sol-detail{ grid-column:6 / -1; }
@media (max-width:880px){ .sol-index{ display:none; } .sol-detail{ grid-column:1 / -1; } }
.sol-item{ padding:clamp(30px,4vw,48px) 0; border-bottom:1px solid var(--hairline); scroll-margin-top:88px; }
.sol-item:first-child{ padding-top:0; }
.sol-item .ix{ font-family:var(--f-mono); font-weight:500; font-size:12px; letter-spacing:.18em; color:var(--green); margin:0 0 14px; }
.sol-item .nm{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3.6vw,42px); letter-spacing:-.022em; color:var(--ink); margin:0 0 16px; }
.sol-item .one{ font-size:clamp(17px,1.9vw,20px); line-height:1.5; color:var(--ink); margin:0 0 24px; max-width:50ch; }
.sol-flow{ display:flex; flex-wrap:wrap; gap:10px; }
.sol-step{ font-family:var(--f-mono); font-size:11.5px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--body); background:var(--surface); border:1px solid var(--hairline); border-left:2px solid var(--green); padding:10px 14px; }

/* ===========================================================================
   ABOUT
   =========================================================================== */
.mv{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); row-gap:clamp(40px,6vw,64px); }
.mv .vision{ grid-column:1 / -1; }
.mv .vision .line{ font-family:var(--f-display); font-weight:400; font-size:clamp(40px,7vw,96px); letter-spacing:-.038em; line-height:1.02; margin:10px 0 0; text-wrap:balance; }
.mv .vision-lead{ font-family:var(--f-display); font-weight:400; font-size:clamp(18px,2.4vw,27px); line-height:1.3; letter-spacing:-.014em; color:var(--muted); margin:0; }
.mv .vision-brush{ display:block; width:min(640px,82%); height:auto; margin:clamp(6px,1vw,12px) 0 0; }
.mv .mission{ grid-column:1 / span 8; }
.mv .mission .line{ font-family:var(--f-display); font-weight:300; font-size:clamp(22px,3vw,38px); letter-spacing:-.018em; line-height:1.22; color:var(--body); margin:14px 0 0; text-wrap:pretty; }
@media (max-width:760px){ .mv .mission{ grid-column:1 / -1; } }

.intention{ display:grid; grid-template-columns:repeat(12,1fr); column-gap:var(--col-gap); }
.intention .lead-col{ grid-column:1 / span 5; }
.intention .lead-col .kicker{ margin-bottom:18px; }
.intention .copy{ grid-column:7 / -1; display:flex; flex-direction:column; gap:22px; }
.intention .copy p{ font-family:var(--f-display); font-weight:300; font-size:clamp(14px,1.75vw,21px); line-height:1.4; letter-spacing:-.014em; color:var(--ink); margin:0; text-wrap:pretty; }
.intention .copy .neu-v, .intention .copy .neu-principle{ font-size:revert; }
@media (max-width:860px){ .intention .lead-col, .intention .copy{ grid-column:1 / -1; } .intention .copy{ margin-top:26px; } }

.team{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.5vw,28px); }
.tm-card{ gap:20px; }
.tm-card .photo{ width:100%; aspect-ratio:1/1; background:var(--surface); overflow:hidden; }
.tm-card .photo img{ width:100%; height:100%; object-fit:cover; display:block; filter:grayscale(1) contrast(1.02); }
.tm-card .nm{ font-family:var(--f-display); font-weight:500; font-size:clamp(20px,2.2vw,25px); letter-spacing:-.014em; margin:0; }
.tm-card .role{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--green); margin:8px 0 14px; }
.tm-card .bio{ font-size:15px; line-height:1.5; color:var(--body); margin:0; }
@media (max-width:620px){ .team{ grid-template-columns:1fr; } }

/* ===========================================================================
   DOCS
   =========================================================================== */
.docs-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.5vw,26px); }
.doc-card{ text-decoration:none; color:inherit; gap:0; transition:transform .2s var(--ease); }
.doc-card:hover{ transform:translateY(-3px); }
.doc-card .ix{ font-family:var(--f-mono); font-size:11px; font-weight:500; letter-spacing:.18em; color:var(--green); margin:0 0 18px; }
.doc-card .nm{ font-family:var(--f-display); font-weight:500; font-size:clamp(22px,2.6vw,28px); letter-spacing:-.016em; margin:0 0 10px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.doc-card .nm .arr{ color:var(--green); transition:transform .2s var(--ease); }
.doc-card:hover .nm .arr{ transform:translate(3px,-3px); }
.doc-card .ds{ font-size:15px; line-height:1.5; color:var(--body); margin:0; }
@media (max-width:620px){ .docs-grid{ grid-template-columns:1fr; } }

/* utility */
.center{ text-align:center; }
.mt-s{ margin-top:clamp(16px,2vw,24px); }
.lk{ font-family:var(--f-mono); font-weight:500; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); text-decoration:none; border-bottom:1px solid var(--ink); padding-bottom:5px; display:inline-flex; align-items:center; gap:9px; white-space:nowrap; }
.lk .arr{ transition:transform .2s var(--ease); }
.lk:hover .arr{ transform:translateX(4px); }

/* ── "Free to integrate" callout tag — ported verbatim from Alex's handoff ──
   Only adjustment: the --inline indent is 6/12 here (our who-panel starts at
   grid column 7; Alex's starts at column 6, hence his 5/12). */
.integrate-tag{
  display:flex; align-items:center; justify-content:center;
  padding:clamp(20px,2.8vw,36px) var(--pad);
  background:#fff;
}
.integrate-tag-inner{
  display:inline-flex; align-items:center; gap:12px;
  padding:clamp(18px,2.2vw,26px) clamp(36px,5vw,64px);
  border:1px solid var(--mint);
  font-family:var(--f-mono); font-size:clamp(12px,1.2vw,15px);
  letter-spacing:.05em; color:var(--green);
  background:rgba(110,236,193,0.08);
}
.integrate-tag .sq{ width:7px; height:7px; background:var(--mint); display:inline-block; flex:none; }
/* --panel: sits inside .who-right directly beneath .who-panel, spanning the
   panel's full width so the pair reads as one purposefully stacked element. */
.integrate-tag--panel{ background:none; padding:0; margin-top:clamp(12px,1.6vw,20px); }
.integrate-tag--panel .integrate-tag-inner{ width:100%; justify-content:center; }
