/* OCSS site — shared design kit. NEUTRAL LIGHT institutional standards-body theme
   (eIDAS / FIDO Alliance / W3C feel). Vendor-neutral — NOT a product brand. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  /* deeper neutral field so white surfaces lift tonally AND via shadow (was a <1.5% delta) */
  --bg:#F1F4FA; --bg-2:#E7EEF7;
  --surface:#FFFFFF; --surface-2:#F5F8FC; --surface-3:#EDF2F8;
  /* cool, faintly-translucent hairlines so the page isn't a wall of equal-weight boxes */
  --line:#E4E9F1; --line-2:#D1D9E6;
  --t1:#16212E; --t2:#414E5C; --t3:#5F6B7A; --t4:#8A95A3;
  /* institutional accent (neutral blue, the "trust/standards" color) */
  --accent:#2456E6; --accent-bright:#3D6BFF; --accent-deep:#163F9E;
  --accent-soft:rgba(36,86,230,0.08); --accent-line:rgba(36,86,230,0.26);
  /* semantic */
  --green:#15924F; --green-soft:rgba(21,146,79,0.10); --green-line:rgba(21,146,79,0.30);
  --amber:#B5791C; --amber-soft:rgba(181,121,28,0.12); --amber-line:rgba(181,121,28,0.30);
  --red:#C5372C; --red-soft:rgba(197,55,44,0.09); --red-line:rgba(197,55,44,0.30);
  /* layered soft elevation ladder — shadow hue derived from ink (#16212E) for a faintly cool, non-grey cast.
     each tier pairs a tight near-opaque CONTACT layer (grounds the object) with wide ambient spread (lifts it). */
  --shadow-1:0 1px 1px rgba(22,33,46,0.06),0 2px 5px -1px rgba(22,33,46,0.05);
  --shadow-2:0 1px 1px rgba(22,33,46,0.10),0 2px 4px -1px rgba(22,33,46,0.07),0 6px 14px -4px rgba(22,33,46,0.09),0 16px 32px -12px rgba(22,33,46,0.11);
  --shadow-3:0 1px 2px rgba(22,33,46,0.12),0 4px 8px -2px rgba(22,33,46,0.09),0 14px 28px -8px rgba(22,33,46,0.13),0 34px 60px -22px rgba(22,33,46,0.17);
  --shadow-4:0 2px 6px rgba(22,33,46,0.14),0 18px 36px -10px rgba(22,33,46,0.18),0 40px 84px -26px rgba(22,33,46,0.26);
  /* full bevel: top inset highlight + faint bottom inset shade for material thickness */
  --edge-hi:inset 0 1px 0 rgba(255,255,255,0.9);
  --edge-lo:inset 0 -1px 0 rgba(22,33,46,0.05);
  --radius:14px; --radius-sm:9px;
  /* disciplined spacing rhythm — whitespace does more of the separating */
  --section-py:clamp(104px,10.5vw,156px);
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --serif:'Source Serif 4',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --wrap:1140px;
  /* richer accent moments (placed, not diluted) */
  --accent-glow:rgba(36,86,230,0.13); --accent-wash:rgba(36,86,230,0.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--t1);font-family:var(--sans);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:radial-gradient(1100px 540px at 50% -240px,var(--accent-glow),transparent 64%),
    radial-gradient(640px 320px at 50% 88vh,var(--accent-wash),transparent 72%),
    linear-gradient(180deg,#FFFFFF 0%,var(--bg) 360px);
  background-repeat:no-repeat;}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;line-height:1.14;letter-spacing:-0.012em;font-weight:600;font-optical-sizing:auto}
p{margin:0}

/* layout */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.section{padding:var(--section-py) 0;border-top:1px solid var(--line)}
.section--tight{padding:clamp(64px,6vw,90px) 0}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--t3)}
.eyebrow .g{color:var(--accent)}
.display{font-family:var(--serif);font-weight:500;letter-spacing:-0.015em;line-height:1.06;color:var(--t1);
  font-optical-sizing:auto;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1,"liga" 1;text-wrap:balance}
.h-xl{font-size:clamp(45px,6vw,70px);font-weight:560;letter-spacing:-0.03em;line-height:0.99}.h-l{font-size:clamp(32px,3.9vw,46px);letter-spacing:-0.02em}.h-m{font-size:clamp(28px,2.4vw,33px);letter-spacing:-0.018em}.h-s{font-size:22px}
.lead{font-size:clamp(17px,calc(1rem + 0.6vw),21px);color:var(--t2);line-height:1.5;letter-spacing:-0.006em;max-width:60ch}
.muted{color:var(--t2)}.dim{color:var(--t3)}.mono{font-family:var(--mono)}
.center{text-align:center}.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mt40{margin-top:40px}
.maxw{max-width:680px}.maxw-c{max-width:680px;margin-left:auto;margin-right:auto}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,252,254,0.82);backdrop-filter:blur(14px) saturate(1.3);border-bottom:1px solid var(--line);box-shadow:0 1px 0 var(--line),0 8px 24px -18px rgba(22,33,46,0.28)}
.nav__in{display:flex;align-items:center;gap:28px;max-width:var(--wrap);margin:0 auto;padding:13px 24px}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:-0.01em;color:var(--t1)}
.brand__mark{width:23px;height:23px;border-radius:6px;background:linear-gradient(135deg,var(--accent),var(--accent-deep));display:grid;place-items:center;color:#fff;font-family:var(--mono);font-weight:700;font-size:12px}
.brand__logo{width:30px;height:30px;border-radius:7px;display:block;flex:none}
.brand__word{font-size:18px;font-weight:700;color:var(--t1);letter-spacing:-0.01em;line-height:1}
.brand__sub{font-family:var(--mono);font-size:9.5px;letter-spacing:0.11em;text-transform:uppercase;color:var(--t3);font-weight:500;padding-left:9px;margin-left:2px;border-left:1px solid var(--line-2);line-height:1}
.brand small{font-family:var(--mono);font-size:9.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--t3);font-weight:500;margin-top:1px}
.nav__links{display:flex;gap:22px;margin-left:8px}
.nav__links a{font-size:13.5px;color:var(--t2);font-weight:500}
.nav__links a:hover{color:var(--t1)}
.nav__links a.is-active{color:var(--accent);font-weight:600}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:14px;font-weight:600;
  padding:10px 18px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}
.btn--primary{background:linear-gradient(180deg,var(--accent-bright) 0%,var(--accent) 100%);border-color:var(--accent-deep);color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.22),0 1px 2px rgba(22,33,46,0.18),0 8px 18px -8px rgba(36,86,230,0.40)}
.btn--primary:hover{background:linear-gradient(180deg,#5078FF 0%,#2A5BE9 100%);transform:translateY(-1px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.24),0 2px 4px rgba(22,33,46,0.18),0 12px 24px -8px rgba(36,86,230,0.46)}
.btn--ghost{background:var(--surface);border-color:var(--line-2);color:var(--t1);box-shadow:0 1px 2px rgba(22,33,46,0.05)}
.btn--ghost:hover{border-color:var(--accent-line);color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px -4px rgba(22,33,46,0.14)}
.btn--sm{padding:7px 13px;font-size:12.5px}

/* hero */
.hero{padding:clamp(96px,12vh,168px) 0 clamp(72px,9vh,116px);text-align:center}
.hero .eyebrow{margin-bottom:32px;display:inline-block}
.hero .display{margin:0 auto}
.hero .lead{max-width:640px;margin:30px auto 0}
.hero .chip-row{justify-content:center;margin-top:24px}
.hero .fig{margin-top:clamp(60px,6.5vw,84px)}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:44px}

/* chips */
.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;font-weight:500;
  padding:4px 11px;border-radius:999px;border:1px solid var(--line-2);color:var(--t2);background:var(--surface)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.chip--ok{border-color:var(--green-line);color:var(--green);background:var(--green-soft)}
.chip--deny{border-color:var(--red-line);color:var(--red);background:var(--red-soft)}
.chip--deny .dot{background:var(--red)}
.chip--amber{border-color:var(--amber-line);color:var(--amber);background:var(--amber-soft)}
.chip--amber .dot{background:var(--amber)}
.chip--accent{border-color:var(--accent-line);color:var(--accent);background:var(--accent-soft)}
.chip--accent .dot{background:var(--accent)}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}

/* metrics strip */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2)}
.metric{background:var(--surface);padding:34px 20px;text-align:center}
.metric b{display:block;font-family:var(--serif);font-size:42px;font-weight:500;color:var(--t1);line-height:1;
  letter-spacing:-0.012em;font-optical-sizing:auto;font-variant-numeric:tabular-nums}
.metric span{display:block;margin-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:0.07em;text-transform:uppercase;color:var(--t3)}
.metric em{font-style:normal;background:linear-gradient(135deg,var(--accent-deep) 0%,var(--accent) 48%,var(--accent-bright) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}

/* cards + grids */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow-2),var(--edge-hi),var(--edge-lo);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-3),inset 0 1px 0 rgba(255,255,255,0.95),var(--edge-lo);border-color:var(--line-2)}
.card--raised{background:var(--surface);box-shadow:var(--shadow-3),var(--edge-hi),var(--edge-lo)}
.card--sunk{background:var(--surface-3);box-shadow:inset 0 1px 2px rgba(22,33,46,0.06),inset 0 0 0 1px rgba(22,33,46,0.02)}
.card--sunk:hover{transform:none;box-shadow:inset 0 1px 2px rgba(22,33,46,0.06),inset 0 0 0 1px rgba(22,33,46,0.02);border-color:var(--line)}
.card h3{font-size:19px;font-weight:600;letter-spacing:-0.01em;color:var(--t1)}
.card .k{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--t3)}
.card p{color:var(--t2);font-size:14.5px;margin-top:8px}

/* diagram frame — engineered canvas: gentle vertical gradient + inner highlight, sits at the floor tier */
.fig{background:linear-gradient(180deg,#FFFFFF 0%,var(--surface-2) 100%);border:1px solid var(--line);border-radius:var(--radius);padding:32px;margin:0;
  box-shadow:var(--shadow-1),var(--edge-hi),var(--edge-lo)}
.hero .fig{padding:28px;box-shadow:var(--shadow-3),var(--edge-hi),var(--edge-lo)}
.fig--sunk{background:var(--surface-3);box-shadow:inset 0 1px 2px rgba(22,33,46,0.06),inset 0 0 0 1px rgba(22,33,46,0.02)}
.figcap{font-family:var(--mono);font-size:11.5px;color:var(--t3);text-align:center;margin-top:16px}
.fig svg{display:block;width:100%;height:auto}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--t3);text-align:left;padding:11px 12px;border-bottom:1px solid var(--line-2)}
.tbl td{padding:12px;border-bottom:1px solid var(--line);color:var(--t2);font-variant-numeric:tabular-nums}
.tbl td:first-child{color:var(--t1);font-weight:500}
.tbl tr:hover td{background:var(--surface-2)}
.pill{display:inline-block;font-family:var(--mono);font-size:10.5px;padding:2px 9px;border-radius:999px;border:1px solid var(--line-2);color:var(--t3)}
.pill--ok{color:var(--green);border-color:var(--green-line);background:var(--green-soft)}
.pill--amber{color:var(--amber);border-color:var(--amber-line);background:var(--amber-soft)}
.pill--red{color:var(--red);border-color:var(--red-line);background:var(--red-soft)}

/* section heading helper */
.shead{max-width:660px;margin-bottom:clamp(44px,5vw,68px)}
.shead h2{font-family:var(--serif);font-weight:560;font-size:clamp(28px,3vw,36px);margin-top:13px;color:var(--t1);letter-spacing:-0.022em;line-height:1.1;
  font-optical-sizing:auto;text-rendering:optimizeLegibility;text-wrap:balance}
.shead p{color:var(--t3);font-size:15px;line-height:1.55;margin-top:13px}
.shead p em{color:var(--t2);font-style:italic}

/* seat board */
.seats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.seat{aspect-ratio:1.6;border:1px dashed var(--line-2);border-radius:var(--radius-sm);display:grid;place-items:center;text-align:center;
  font-family:var(--mono);font-size:11px;color:var(--t3);padding:10px;
  background:linear-gradient(180deg,#FCFDFF 0%,var(--surface-2) 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.seat:hover{transform:translateY(-2px);box-shadow:var(--shadow-2),inset 0 1px 0 rgba(255,255,255,0.6);border-color:var(--accent-line)}
.seat--filled{border:1px solid var(--accent-line);background:var(--accent-soft);color:var(--accent-deep);font-weight:600;
  box-shadow:0 1px 2px rgba(22,33,46,0.05),0 16px 40px -16px rgba(36,86,230,0.26)}
.seat--filled:hover{box-shadow:0 2px 4px rgba(22,33,46,0.06),0 20px 48px -16px rgba(36,86,230,0.32)}

/* footer */
.footer{position:relative;overflow:hidden;border-top:1px solid var(--line);padding:46px 0 56px;margin-top:24px;color:var(--t3);font-size:13px;background:var(--bg-2)}
.footer::before{content:"";position:absolute;inset:auto 0 -120px 0;height:240px;pointer-events:none;
  background:radial-gradient(55% 130% at 50% 100%,rgba(36,86,230,0.10),var(--accent-soft) 44%,transparent 72%)}
.footer__in{position:relative;display:flex;gap:40px;flex-wrap:wrap;align-items:flex-start;max-width:var(--wrap);margin:0 auto;padding:0 24px}
.footer a{color:var(--t3)}.footer a:hover{color:var(--t1)}
.footer__links{display:flex;gap:18px;flex-wrap:wrap}

/* SVG diagram tokens — neutral light, rounded/engineered linework */
.s-node{fill:var(--surface-2);stroke:var(--line-2)}
.s-node-g{fill:var(--accent-soft);stroke:var(--accent-line)}
.s-node,.s-node-g{rx:8}
.s-edge{stroke:var(--t4);stroke-width:1.3;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:.9}
.s-edge-g{stroke:var(--accent-bright);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.s-edge-red{stroke:var(--red);stroke-width:1.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.s-label{fill:var(--t1);font-family:var(--mono);font-size:12px;font-weight:500}
.s-label-sm{fill:var(--t3);font-family:var(--mono);font-size:10.5px}

/* ============================================================================
   DIAGRAM DESIGN LANGUAGE — reusable high-end primitives (.dgm-*)
   Neutral-light, single blue accent (#2456E6 = var(--accent)). Institutional
   "engineering canvas" look. Two layers: (1) HTML component nodes/chips for
   foreignObject or absolutely-positioned overlays; (2) SVG element classes for
   inline <rect>/<path>/<circle>/<text>. Pair every diagram <svg> with the
   shared <defs> snippet documented in the design spec (gradients dgmNodeGrad /
   dgmAccentGrad / dgmFlow, marker dgmArrow, filter dgmShadow, pattern dgmGrid).
   ========================================================================== */

/* --- diagram accent ramp (rationed: tints for fills, core for the ONE focal) -- */
:root{
  --dgm-tint-50:#EEF2FE; --dgm-tint-100:#DCE4FD; --dgm-mid-300:#7E9BF5;
  --dgm-core:#2456E6; --dgm-ink:#1B3FAE;
  --dgm-node-border:#DFE5F2; --dgm-canvas-dot:rgba(36,86,230,0.07);
  --dgm-reg:#CFD8EA;
  /* two desaturated STATE tints — used ONLY as icon colors inside diagrams,
     never as a full node fill (keeps #2456E6 the only structural accent). */
  --dgm-state-ok:#3F8F63; --dgm-state-off:#76839A;
  /* node depth: contact + ambient + faint accent ambient */
  --dgm-node-shadow:0 1px 2px rgba(16,24,40,0.06),0 6px 16px rgba(36,86,230,0.05);
  --dgm-node-hi:inset 0 1px 0 rgba(255,255,255,0.7);
}

/* --- the canvas frame: faint radial dot-grid + soft inner gradient + corner ticks - */
.dgm{position:relative;background:
    radial-gradient(var(--dgm-canvas-dot) 1px,transparent 1px) 0 0/16px 16px,
    linear-gradient(180deg,#FFFFFF 0%,#FAFBFF 100%);
  border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  box-shadow:var(--shadow-1),var(--edge-hi),var(--edge-lo)}
.dgm__eyebrow{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--t4);margin-bottom:14px}
.dgm svg{display:block;width:100%;height:auto;overflow:visible;shape-rendering:geometricPrecision}
/* 4 corner registration ticks — the deliberate "engineering drawing" tell.
   Drop four <span class="dgm-corner dgm-corner--tl|tr|bl|br"> inside .dgm. */
.dgm-corner{position:absolute;width:9px;height:9px;border:0 solid var(--dgm-reg);pointer-events:none;z-index:2}
.dgm-corner--tl{top:12px;left:12px;border-top-width:1.5px;border-left-width:1.5px}
.dgm-corner--tr{top:12px;right:12px;border-top-width:1.5px;border-right-width:1.5px}
.dgm-corner--bl{bottom:12px;left:12px;border-bottom-width:1.5px;border-left-width:1.5px}
.dgm-corner--br{bottom:12px;right:12px;border-bottom-width:1.5px;border-right-width:1.5px}

/* --- HTML component node: crafted card, NOT a flat box ---------------------- */
.dgm-node{display:inline-flex;align-items:center;gap:11px;min-width:0;
  padding:11px 14px;border-radius:12px;border:1px solid var(--dgm-node-border);
  background:linear-gradient(180deg,#FFFFFF 0%,#F6F8FE 100%);
  box-shadow:var(--dgm-node-shadow),var(--dgm-node-hi)}
.dgm-node--lg{padding:14px 18px;border-radius:14px;gap:13px}
.dgm-node--sm{padding:8px 11px;border-radius:10px;gap:9px}
/* the ONE hero node per diagram: stronger border + accent halo (single focal) */
.dgm-node--accent{border:1.5px solid var(--dgm-core);
  background:linear-gradient(180deg,#FFFFFF 0%,var(--dgm-tint-50) 100%);
  box-shadow:0 1px 2px rgba(16,24,40,0.06),0 8px 22px rgba(36,86,230,0.16),var(--dgm-node-hi)}
.dgm-node--ghost{border-style:dashed;border-color:var(--line-2);
  background:linear-gradient(180deg,#FCFDFF 0%,var(--surface-2) 100%);box-shadow:var(--dgm-node-hi)}

/* --- icon chip (left of label): differentiates ROLE without changing box fill - */
.dgm-ico{flex:none;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;
  background:var(--dgm-tint-50);color:var(--dgm-core)}
.dgm-ico svg,.dgm-ico .ico{width:17px;height:17px;display:block;stroke:currentColor;stroke-width:1.6;
  fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}
/* small-scale crispness: keep bespoke glyph geometry pixel-clean as the chip scales */
.dgm-ico svg{shape-rendering:geometricPrecision}
.dgm-ico--accent{background:var(--dgm-core);color:#fff}/* inverts on the primary node */
.dgm-ico--ok{background:rgba(63,143,99,0.12);color:var(--dgm-state-ok)}
.dgm-ico--off{background:rgba(118,131,154,0.14);color:var(--dgm-state-off)}

/* --- bespoke sprite glyph drawn via <use href="#ic-…"> inside an SVG icon chip ---
   The ONE owned icon family. stroke=currentColor on every <symbol>, so these color
   tokens (and only these) drive the glyph — chip role stays decoupled from icon path. */
.dgm-gly{color:var(--dgm-core)}
.dgm-gly--inv{color:#fff}            /* on a solid-accent chip */
.dgm-gly--off{color:var(--dgm-state-off)}
.dgm-gly--ok{color:var(--dgm-state-ok)}
.dgm-gly--mut{color:var(--t3)}

/* --- expanded node-shape vocabulary (role silhouette; elevation ladder unchanged) -
   card (default) = services/panels · token = a hub/anchor disc · pill = ephemeral key.
   All keep the same depth so only the SHAPE read changes, never the elevation. */
.dgm-node--token{border-radius:50%;width:44px;height:44px;padding:0;justify-content:center}
.dgm-node--pill{border-radius:999px;padding:8px 16px}

/* --- in-node label typography: sans title + caption (de-monospaced) --------- */
.dgm-label{font-family:var(--sans);font-size:13.5px;font-weight:600;color:#0b1220;
  letter-spacing:-0.006em;line-height:1.2}
.dgm-sub{display:block;font-family:var(--sans);font-size:12px;font-weight:400;color:#5b6478;
  margin-top:2px;line-height:1.25}
.dgm-tech{font-family:var(--mono);font-size:11px;color:var(--t3);letter-spacing:0}/* did:ocss:…, key ids, JWKS */

/* --- on-line edge label: small white plate so text sits cleanly ON the stroke - */
.dgm-edge-label{display:inline-block;font-family:var(--sans);font-size:11px;font-weight:500;color:var(--t2);
  background:#fff;border:1px solid var(--dgm-node-border);border-radius:4px;padding:2px 7px;
  box-shadow:0 1px 1px rgba(16,24,40,0.04);white-space:nowrap}
.dgm-edge-label--tech{font-family:var(--mono);font-size:10.5px}

/* --- SVG element classes (inline <rect>/<path>/<circle>/<text>) ------------- */
/* node rect: reference the gradient + shadow filter from the shared <defs> */
.dgm-rect{fill:url(#dgmNodeGrad);stroke:var(--dgm-node-border);stroke-width:1;filter:url(#dgmShadow)}
.dgm-rect--accent{fill:url(#dgmAccentGrad);stroke:var(--dgm-core);stroke-width:1.5}
.dgm-rect--ghost{fill:#FCFDFF;stroke:var(--line-2);stroke-width:1;stroke-dasharray:4 4;filter:none}
/* edges: one weight system, round caps, shared arrow marker via inline marker-end */
.dgm-edge{fill:none;stroke:var(--dgm-mid-300);stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}
.dgm-edge--accent{stroke:var(--dgm-core);stroke-width:1.75}
.dgm-edge--grad{stroke:url(#dgmFlow);stroke-width:1.75;fill:none;stroke-linecap:round}/* light→full = felt direction */
.dgm-edge--legacy{stroke:#9AA4B2;stroke-width:1.1;opacity:0.55}/* the messy "TODAY" tangle */
/* casing: draw this path FIRST (under the real edge) for clean over/under crossings */
.dgm-edge-casing{fill:none;stroke:#EEF2FB;stroke-width:5.5;stroke-linecap:round;stroke-linejoin:round}
/* thinner casing for DENSE tangles — gives the over/under read without fat halos */
.dgm-edge-casing--thin{fill:none;stroke:#EFF2FA;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
/* socket: 3px filled dot where a line docks into a node port */
.dgm-socket{fill:var(--dgm-core);stroke:#fff;stroke-width:1}
/* SVG text */
.dgm-svg-title{fill:#0b1220;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:-0.006em}
.dgm-svg-sub{fill:#5b6478;font-family:var(--sans);font-size:11.5px}
.dgm-svg-tech{fill:var(--t3);font-family:var(--mono);font-size:11px}

/* --- bespoke inline-SVG icon glyphs (one owned family) ---------------------- */
/* Authored as a single inline <symbol> sprite (viewBox 0 0 24 24, 1.7 stroke,
   round caps/joins, stroke=currentColor) referenced via <use href="#ic-…"> inside
   the tinted chip rect — the chip role color keeps driving the glyph color and the
   whole set reads as ONE designed family. geometricPrecision keeps small chips crisp. */
.dgm-glyph{shape-rendering:geometricPrecision}
/* the hidden inline sprite host + per-instance color drivers: symbol paths use
   stroke=currentColor, so these classes (and the chip role tints) drive the glyph. */
.ocss-sprite{position:absolute;width:0;height:0;overflow:hidden}
.ocss-sprite [stroke]{shape-rendering:geometricPrecision}
.dgm-ico-svg{color:var(--dgm-core)}            /* default accent glyph             */
.dgm-ico-svg--inv{color:#fff}                  /* inverts on the focal accent chip */
.dgm-ico-svg--deep{color:var(--accent-deep)}   /* seal / signed motif on light tint*/
.dgm-ico-svg{shape-rendering:geometricPrecision}
/* role silhouettes: expand the node SHAPE vocabulary, depth ladder unchanged.
   token = circular medallion (offline root / key-custody anchor); pill = ephemeral key. */
.dgm-node--token{border-radius:50%;width:44px;height:44px;padding:0;gap:0;justify-content:center}
.dgm-node--pill{border-radius:999px}

/* --- data-flow animation: marching dashes on "a signal travels" edges ------- */
.dgm-edge--flow{stroke:var(--dgm-core);stroke-width:1.75;fill:none;stroke-linecap:round;
  stroke-dasharray:3 11;opacity:.55}
@media (prefers-reduced-motion: no-preference){
  .dgm-edge--flow{animation:dgm-dash 1.4s linear infinite}
}
@keyframes dgm-dash{to{stroke-dashoffset:-14}}

/* --- registry / data plate (zeros board, "forming" count) ------------------- */
.dgm-plate{display:inline-grid;justify-items:center;gap:8px;padding:18px 26px;border-radius:14px;
  border:1px solid var(--dgm-node-border);
  background:radial-gradient(120% 120% at 50% 0%,var(--dgm-tint-50),#FFFFFF 70%);
  box-shadow:var(--dgm-node-shadow),var(--dgm-node-hi)}
.dgm-plate b{font-family:var(--mono);font-size:48px;font-weight:600;line-height:1;color:var(--dgm-ink);
  font-variant-numeric:tabular-nums}
.dgm-plate span{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--t4)}

/* craft: subtle blueprint dot-grid behind the hero (institutional, very faint) */
.hero{position:relative}
.hero>*{position:relative;z-index:1}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(20,30,60,0.055) 1px,transparent 1px);background-size:22px 22px;
  -webkit-mask-image:radial-gradient(78% 62% at 50% 24%,#000 0%,transparent 74%);
  mask-image:radial-gradient(78% 62% at 50% 24%,#000 0%,transparent 74%)}
.hero::after{content:"";position:absolute;left:50%;bottom:-28px;width:min(760px,88%);height:230px;z-index:0;
  transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(58% 100% at 50% 100%,var(--accent-soft),transparent 72%);filter:blur(6px)}

/* craft: refined monochrome stroke-icon token for feature rows */
.ico{width:18px;height:18px;display:inline-block;flex:none;stroke:var(--t3);stroke-width:1.6;fill:none;
  stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}
.ico--accent{stroke:var(--accent)}
.card .ico{margin-bottom:14px}

/* craft: tonal section rhythm — visible blue wash to break the monotone white */
.section--tint{background:linear-gradient(180deg,rgba(36,86,230,0.06) 0%,rgba(36,86,230,0.012) 58%,transparent 100%)}
.section--panel{background:var(--surface-2);box-shadow:inset 0 1px 0 var(--line),inset 0 -1px 0 var(--line);border-top-color:transparent}

/* craft: blue-tinted emphasis lift for a feature/highlight card */
.card--feature{padding:32px;box-shadow:var(--shadow-3),0 18px 44px -18px rgba(36,86,230,0.24),var(--edge-hi),var(--edge-lo);border-color:var(--accent-line)}

/* ============================================================================
   SHARED MOBILE PRIMITIVES (used by the @media blocks below)
   - .nav__toggle: the hamburger button (markup hook; hidden on desktop)
   - .scroll-x: reusable horizontal-scroll wrapper for wide tables
   These live OUTSIDE the media query so the markup hooks exist at all widths,
   but the toggle only becomes visible inside @media(max-width:760px).
   ========================================================================== */
.nav__toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;flex:none;
  margin-left:auto;border:1px solid var(--line-2);border-radius:10px;background:var(--surface);
  color:var(--t1);cursor:pointer;padding:0;box-shadow:0 1px 2px rgba(22,33,46,0.05);
  -webkit-tap-highlight-color:transparent}
.nav__toggle:hover{border-color:var(--accent-line);color:var(--accent)}
.nav__toggle .nav__toggle-bars{position:relative;display:block;width:18px;height:12px}
.nav__toggle .nav__toggle-bars::before,
.nav__toggle .nav__toggle-bars::after,
.nav__toggle .nav__toggle-bars span{content:"";position:absolute;left:0;width:100%;height:1.8px;border-radius:2px;
  background:currentColor;transition:transform .2s ease,opacity .15s ease,top .2s ease}
.nav__toggle .nav__toggle-bars::before{top:0}
.nav__toggle .nav__toggle-bars span{top:5px}
.nav__toggle .nav__toggle-bars::after{top:10px}
/* animate to an X when the nav is open (JS flips .is-open on .nav) */
.nav.is-open .nav__toggle .nav__toggle-bars span{opacity:0}
.nav.is-open .nav__toggle .nav__toggle-bars::before{top:5px;transform:rotate(45deg)}
.nav.is-open .nav__toggle .nav__toggle-bars::after{top:5px;transform:rotate(-45deg)}

/* reusable horizontal-scroll wrapper for wide tables (page agents wrap <table.tbl>) */
.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}
.scroll-x>.tbl{min-width:520px}

/* baseline overflow guard — a single wide child can never widen the document */
img,svg,video{max-width:100%}

@media(max-width:760px){
  /* clamp() owns .h-xl / .h-l fluidly — no hard step here */
  .metrics,.seats{grid-template-columns:repeat(2,1fr)}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .grid>*,.metrics>*,.section>.wrap>*{min-width:0}/*min0*/

  /* ── MOBILE NAV — premium single-row bar (Stripe/Cloudflare pattern) ──────
     CLOSED bar = brand (left) + hamburger (right) ONLY — one tidy nowrap row.
     The links AND the .nav__right cluster (Sign in + Join) collapse INTO the
     open sheet: links stacked, then Sign-in link + a full-width Join button at
     the bottom of the sheet. The existing toggle JS (.is-open) drives it all.
     If a page ships no .nav__toggle / no JS, the fallback rule (further down)
     keeps the links reachable as a scrollable row instead of vanishing. */
  .nav__in{flex-wrap:wrap;row-gap:0;gap:12px;padding-top:11px;padding-bottom:11px;
    align-items:center}
  .brand{order:1;margin-right:auto;min-width:0}
  .nav__toggle{display:inline-flex;order:2;margin-left:0}
  /* hide the brand sub-label so the lockup is just the OCSS wordmark on the bar */
  .nav .brand__sub,.nav .brand small{display:none}

  /* the links collapse into a sheet below the bar, full-width, revealed by JS */
  .nav:has(.nav__toggle) .nav__links{order:4;display:none;flex-direction:column;width:100%;gap:0;
    margin:0;padding:6px 0 4px;border-top:1px solid var(--line)}
  .nav.is-open .nav__links{display:flex}
  .nav__links a{font-size:15px;padding:13px 4px;min-height:44px;display:flex;align-items:center;
    border-bottom:1px solid var(--line);width:100%}
  .nav__links a:last-child{border-bottom:none}

  /* ── .nav__right (Sign in + Join) — OUT of the closed bar, INTO the sheet ──
     Closed: hidden (the bar stays brand + hamburger only).
     Open  : full-width column pinned to the bottom of the sheet — Join is a
             full-width primary action, Sign in a centered link below it. */
  .nav:has(.nav__toggle) .nav__right{order:5;display:none}
  .nav.is-open .nav__right{display:flex;flex-direction:column;align-items:stretch;
    width:100%;margin-left:0;gap:12px;padding:14px 4px 4px}
  .nav.is-open .nav__right .btn--sm{order:1;width:100%;justify-content:center;
    padding:13px 16px;min-height:48px;font-size:14px;white-space:nowrap}
  .nav.is-open .nav__signin{order:2;display:inline-flex;align-items:center;justify-content:center;
    min-height:44px;padding:0 8px;white-space:nowrap}

  /* ── 44px TAP TARGETS / no-wrap for nav controls (also covers the fallback) ─ */
  .nav__signin{white-space:nowrap}
  .nav .btn--sm{white-space:nowrap}

  /* ── WIDE TABLES: sensible mobile cell sizing (wrapper adds scroll) ──────── */
  .tbl{font-size:13px}
  .tbl th{padding:9px 10px}
  .tbl td{padding:9px 10px}
  .tbl .mono,.tbl code{overflow-wrap:anywhere;word-break:break-word}

  /* ── FOOTER tap targets ─────────────────────────────────────────────────── */
  .footer__in{gap:28px}
  .footer__links{gap:6px 18px}
  .footer__links a{display:inline-flex;align-items:center;min-height:44px;padding:6px 0}
}

/* ── NO-JS / NO-TOGGLE NAV FALLBACK ───────────────────────────────────────
   If a page's nav has NO .nav__toggle hook, the links must still be reachable.
   Render them as a horizontally-scrollable single row beneath the bar rather
   than hiding them. (When .nav__toggle IS present, the :has() rules above win.) */
@media(max-width:760px){
  .nav:not(:has(.nav__toggle)) .nav__links{display:flex;order:4;width:100%;margin:0;gap:0;
    overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;
    border-top:1px solid var(--line);padding:4px 0;scrollbar-width:none}
  .nav:not(:has(.nav__toggle)) .nav__links::-webkit-scrollbar{display:none}
  .nav:not(:has(.nav__toggle)) .nav__links a{flex:none;padding:12px 14px;min-height:44px;
    display:inline-flex;align-items:center;border-bottom:none}
}

/* ── WIDE DIAGRAMS — global legibility (≤560px) ───────────────────────────
   Inline-SVG figures scale linearly with column width, so their fixed-unit
   labels turn to noise at phone width. Let .fig/.dgm scroll horizontally and
   hold the SVG at a legible minimum width so a 960-unit canvas renders at a
   readable scale and the user pans, instead of shrinking everything to ~0.29x.
   This is GLOBAL — page agents do NOT need to touch their diagrams. */
@media(max-width:560px){
  .fig{padding:14px;position:relative}
  .hero .fig{padding:14px}
  .dgm{padding:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}
  /* Lay the SVG out at an EXPLICIT pixel width (not just min-width) so the inline
     SVG's intrinsic width:100% / width attr can't beat the legibility floor — the
     figure overflows its card and the user pans, instead of shrinking to ~0.3x. */
  .fig svg,.dgm svg{width:100%;min-width:0;max-width:100%;height:auto}
  /* Wide / twin-panel / ultra-wide-timeline figures need a larger hold so dense
     dual-panel and 980-unit canvases stay legible when panned. Opt-in via a
     .fig--wide / .dgm--wide class on the figure markup; falls back gracefully. */
  .fig--wide svg,.dgm--wide svg{width:880px;min-width:880px}
  /* OPT-OUT for genuinely-narrow figures (e.g. a ~460-unit roadmap) — let them
     shrink-to-fit so they don't pan for no reason. Tag the figure .fig--fit. */
  .fig--fit svg,.dgm--fit svg{width:100%;min-width:0;max-width:100%}
  /* faint right-edge fade cue so the pan affordance is discoverable */
  .fig,.dgm{background-attachment:local}
  .figcap{margin-top:12px}
  /* keep registration corners sensible inside the tighter .dgm padding */
  .dgm-corner--tl,.dgm-corner--tr{top:8px}
  .dgm-corner--bl,.dgm-corner--br{bottom:8px}
  .dgm-corner--tl,.dgm-corner--bl{left:8px}
  .dgm-corner--tr,.dgm-corner--br{right:8px}

  /* ── SECTION VERTICAL RHYTHM — tighten so phones aren't over-padded ─────── */
  :root{--section-py:clamp(52px,12vw,104px)}
  .section--tight{padding:clamp(48px,12vw,72px) 0}
  .shead{margin-bottom:clamp(28px,8vw,40px)}
  .shead h2{line-height:1.15;letter-spacing:-0.01em}
  /* trim the common manual 54px inter-block gap pattern */
  .section .grid{margin-top:clamp(28px,8vw,40px)}

  /* ── TABLES — generic scroll wrapper at this width too (defensive) ──────── */
  .scroll-x>.tbl{min-width:480px}
}

/* ── PHONE (≤480px) — final polish for 360–390px devices ──────────────────── */
@media(max-width:480px){
  /* tighten the page gutter one notch — ~12px more usable content width at 360px */
  .wrap{padding:0 18px}

  /* section rhythm: one notch tighter again so stacked sections sit intentionally */
  :root{--section-py:clamp(48px,11vw,104px)}

  /* hero headline: lower the clamp FLOOR only (desktop cap at 70px untouched) */
  .h-xl{font-size:clamp(34px,8.5vw,70px)}
  .hero{padding:clamp(64px,11vh,96px) 0 clamp(48px,7vh,72px)}
  .hero .lead{margin-top:22px}

  /* bottom CTA rows (hero + every page footer-CTA): stack full-width, clean pills
     instead of ragged half-width wrapped buttons */
  .cta-row{margin-top:32px;flex-direction:column;align-items:stretch;gap:10px}
  .cta-row .btn{width:100%;justify-content:center}

  /* seats: relax aspect + tighten gap so 2-col tiles breathe + logo has padding */
  .seats{grid-template-columns:repeat(2,1fr);gap:12px}
  .seat{aspect-ratio:1.9}

  /* metrics 2-up: trim padding + numeral so cells aren't crowded at 360px */
  .metric{padding:24px 14px}
  .metric b{font-size:34px}

  /* tables: smaller min-width / tighter cells for the densest matrices */
  .tbl{font-size:12.5px}
  .tbl th{padding:8px;font-size:9.5px}
  .tbl td{padding:8px}
  .scroll-x>.tbl{min-width:460px}
  /* keep the densest benefit/label first column on one line so the table pans
     cleanly inside .scroll-x instead of wrapping into tall ragged rows */
  .scroll-x>.tbl td:first-child,.scroll-x>.tbl th:first-child{white-space:nowrap}
  /* small right gutter so scrolled-in mono values aren't flush to the edge */
  .scroll-x>.tbl td:last-child,.scroll-x>.tbl th:last-child{padding-right:14px}

  /* cards: reclaim inner width for forms / two-column content blocks */
  .card{padding:20px}
  .card--feature{padding:22px}

  /* diagrams: explicit width (beats width:100%) so the floor actually bites and
     the figure pans. Wide/twin-panel figures keep their larger hold. */
  .fig svg,.dgm svg{width:100%;min-width:0;max-width:100%;height:auto}
  .fig--wide svg,.dgm--wide svg{width:880px;min-width:880px}
  .fig--fit svg,.dgm--fit svg{width:100%;min-width:0;max-width:100%}
  .s-label-sm{font-size:11px}

  /* chips: tidy wrapping so 4-chip rows read as clean rows, not ragged */
  .chip-row{gap:6px}
  .chip{font-size:11px}

  /* protect the brand lockup width on the narrowest phones */
  .brand__sub,.brand small{display:none}
  .nav__in{gap:10px}
}

/* ── Join modal ─────────────────────────────────────────────────────────── */
.jm-overlay{position:fixed;inset:0;z-index:100;background:rgba(16,24,40,0.45);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;animation:jmFade .15s ease}
.jm-overlay[hidden]{display:none}
@keyframes jmFade{from{opacity:0}to{opacity:1}}
.jm{position:relative;width:100%;max-width:444px;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-4);padding:28px}
.jm__x{position:absolute;top:14px;right:14px;width:30px;height:30px;border:none;background:transparent;border-radius:8px;font-size:20px;color:var(--t3);cursor:pointer;line-height:1}
.jm__x:hover{background:var(--surface-2);color:var(--t1)}
.jm__form{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.jm__f{display:flex;flex-direction:column;gap:5px}
.jm__f span{font-family:var(--mono);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)}
.jm__f input,.jm__f select{font-family:var(--sans);font-size:14px;padding:10px 12px;border:1px solid var(--line-2);border-radius:10px;background:var(--surface);color:var(--t1);outline:none}
.jm__f input:focus,.jm__f select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.jm__done{text-align:center;padding:10px 0 4px}
.jm__check{width:46px;height:46px;border-radius:50%;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-size:22px;margin:0 auto 14px}
/* ── nav sign-in link ───────────────────────────────────────────────────── */
.nav__signin{font-size:13.5px;color:var(--t2);font-weight:500}
.nav__signin:hover{color:var(--accent)}
/* ── login page ─────────────────────────────────────────────────────────── */
.login-wrap{max-width:444px;margin:0 auto;padding:76px 24px 110px}
.login-field{margin-top:24px}
.login-field label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3);margin-bottom:7px}
.login-field input{width:100%;font-size:15px;padding:12px 14px;border:1px solid var(--line-2);border-radius:11px;outline:none;background:var(--surface);color:var(--t1)}
.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.login-or{display:flex;align-items:center;gap:12px;margin:24px 0 4px;color:var(--t3);font-family:var(--mono);font-size:11px;letter-spacing:0.1em}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--line)}
.sso{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;border:1px solid var(--line-2);border-radius:11px;background:var(--surface);font-weight:600;font-size:14px;color:var(--t1);cursor:pointer;margin-top:10px}
.sso:hover{border-color:var(--accent-line);box-shadow:var(--shadow-1)}

/* ============================================================================
   MOBILE STACKED-DIAGRAM VOCABULARY (.dgm-desk / .dgm-mob swap + .mdg-* cards)
   ────────────────────────────────────────────────────────────────────────────
   PURPOSE: re-express a dense inline-SVG figure as a clean VERTICAL stack of
   HTML cards on phones (≤760px) — every label & the diagram MEANING preserved,
   fully legible, in the OCSS neutral-light brand. DESKTOP IS UNTOUCHED: the
   .mdg-* card styles exist globally but only render because .dgm-mob is hidden
   on desktop (display:none) and only flips to block at ≤760px. Nothing here
   alters any desktop layout.

   MARKUP PATTERN (page agents tag each figure):
     <figure class="fig dgm-desk"> …existing desktop <svg>… </figure>
     <div class="dgm-mob"> …stacked .mdg cards mirroring the same nodes… </div>

   Reuses the SAME icon sprite as the SVG diagrams: <svg class="mdg-ico"><use
   href="#ic-rules"/></svg> (ids #ic-rules #ic-dns #ic-router #ic-device
   #ic-browser #ic-apps #ic-ocss #ic-seal #ic-envelope #ic-app …).
   ========================================================================== */

/* --- (1) THE SWAP MECHANISM ------------------------------------------------- */
.dgm-desk{}                       /* desktop figure: normal flow */
.dgm-mob{display:none}            /* mobile stack: hidden on desktop */
@media(max-width:760px){
  .dgm-desk{display:none}         /* drop the dense SVG on phones */
  .dgm-mob{display:block}         /* show the stacked HTML cards */
}

/* --- (2) STACKED-DIAGRAM PRIMITIVES (.mdg-*) ──────────────────────────────
   Global card styles (safe at all widths — only revealed via .dgm-mob).
   Same elevation ladder / hairline / tint tokens as the SVG diagram nodes. */

/* container: full-width vertical flow */
.mdg{display:flex;flex-direction:column;gap:12px;width:100%;margin:0}

/* a node = crafted card (white→faint-tint, hairline, soft shadow), row layout:
   icon tile + text column. Matches .dgm-node depth, sized for a phone row. */
.mdg-node{display:flex;align-items:center;gap:13px;width:100%;
  padding:13px 14px;border-radius:13px;border:1px solid var(--dgm-node-border);
  background:linear-gradient(180deg,#FFFFFF 0%,#F6F8FE 100%);
  box-shadow:var(--dgm-node-shadow),var(--dgm-node-hi)}
.mdg-node>.mdg-body{flex:1;min-width:0}

/* the ONE accent/authority node per figure (OCSS / root / hub): blue gradient
   fill, white text + inverted icon. Single focal — mirrors .dgm-node--accent. */
.mdg-hub{border:1px solid var(--accent-deep);
  background:linear-gradient(165deg,var(--accent-bright) 0%,var(--accent) 52%,var(--accent-deep) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.22),0 1px 2px rgba(22,33,46,0.16),
    0 12px 30px -10px rgba(36,86,230,0.42)}
.mdg-hub .mdg-title{color:#fff}
.mdg-hub .mdg-sub{color:rgba(255,255,255,0.82)}
.mdg-hub .mdg-tech{color:rgba(255,255,255,0.9)}
.mdg-hub .mdg-ico{background:rgba(255,255,255,0.16);color:#fff}

/* icon tile: ~30px rounded square, 8% blue tint, holds an <svg><use/></svg> glyph */
.mdg-ico{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent)}
.mdg-ico svg,.mdg-ico .ico{width:18px;height:18px;display:block;stroke:currentColor;stroke-width:1.6;
  fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke;
  shape-rendering:geometricPrecision}
.mdg-ico--ok{background:var(--green-soft);color:var(--green)}
.mdg-ico--off{background:rgba(118,131,154,0.14);color:var(--dgm-state-off)}

/* in-node typography */
.mdg-title{font-family:var(--sans);font-size:14.5px;font-weight:600;color:var(--t1);
  letter-spacing:-0.006em;line-height:1.22}
.mdg-sub{display:block;font-family:var(--sans);font-size:12.5px;font-weight:400;color:var(--t2);
  margin-top:2px;line-height:1.3}
.mdg-tech{display:block;font-family:var(--mono);font-size:11px;color:var(--accent);
  margin-top:3px;letter-spacing:0;overflow-wrap:anywhere}

/* a labeled SECTION card: mono eyebrow ("LAYER 1 · VOCABULARY") + body content */
.mdg-panel{width:100%;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(180deg,#FFFFFF 0%,var(--surface-2) 100%);
  box-shadow:var(--shadow-1),var(--edge-hi),var(--edge-lo);padding:15px 15px 16px}
.mdg-panel>.mdg-eyebrow{margin-bottom:11px}
.mdg-panel .mdg{gap:10px}

/* category chip list inside a panel */
.mdg-chips{display:flex;flex-wrap:wrap;gap:7px}
.mdg-chip{display:inline-flex;align-items:center;font-family:var(--mono);font-size:11px;font-weight:500;
  padding:4px 10px;border-radius:999px;border:1px solid var(--accent-line);
  color:var(--accent-deep);background:var(--accent-soft);white-space:nowrap}
.mdg-chip--mut{border-color:var(--line-2);color:var(--t3);background:var(--surface-2)}
.mdg-chip--ok{border-color:var(--green-line);color:var(--green);background:var(--green-soft)}

/* vertical connector / down-chevron between stacked nodes (subtle blue) */
.mdg-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:22px;margin:-3px 0;position:relative;color:var(--accent)}
.mdg-arrow::before{content:"";width:1.5px;height:14px;
  background:linear-gradient(180deg,var(--accent-line),var(--accent))}
.mdg-arrow::after{content:"";position:absolute;bottom:1px;width:8px;height:8px;
  border-right:1.6px solid var(--accent);border-bottom:1.6px solid var(--accent);
  transform:rotate(45deg)}
.mdg-arrow--label{height:auto;margin:4px 0;gap:5px}
/* labelled variant stacks line -> pill -> chevron in normal flow (the base
   ::after chevron is absolutely-positioned at the bottom, which would overlap
   the pill); make it a flow item below the pill so nothing overlaps */
.mdg-arrow--label::after{position:static;bottom:auto;margin-top:1px}
.mdg-arrow--label .mdg-arrow-tag{font-family:var(--mono);font-size:10.5px;font-weight:500;
  color:var(--t2);background:#fff;border:1px solid var(--dgm-node-border);border-radius:5px;
  padding:2px 8px;box-shadow:0 1px 1px rgba(16,24,40,0.04);white-space:nowrap}

/* optional 2-up mini-grid for tight pairs that still fit on a phone */
.mdg-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mdg-grid2>.mdg-node{padding:11px;gap:10px}
.mdg-grid2 .mdg-ico{width:26px;height:26px;border-radius:8px}
.mdg-grid2 .mdg-title{font-size:13px}

/* centered caption line under a stack */
.mdg-cap{text-align:center;font-family:var(--mono);font-size:11px;color:var(--t3);
  line-height:1.5;margin-top:4px}

/* the small mono FIGURE label (eyebrow) above a stack or on a panel */
.mdg-eyebrow{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--t4)}
.mdg-eyebrow .g{color:var(--accent)}

/* interior pages whose first block is a left-aligned .section--tight head get a
   generous, consistent top on mobile (scoped to :first-child so mid-page
   .section--tight spacing is unchanged; hero pages use .hero, unaffected) */
@media(max-width:760px){
  main > .section--tight:first-child{padding-top:clamp(64px,9vh,84px)}
}
