/* ============================================================
   spektra — design system
   premium dark-tech · near-black canvas · emerald as light
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

/* ---------- tokens ---------- */
:root {
  /* canvas — near-black, faintly cool-green so emerald sits native */
  --bg:        #07090A;
  --bg-2:      #0A0D0E;
  --raised:    #0E1213;
  --surface:   #121819;
  --surface-2: #18201F;

  /* hairlines */
  --line:      rgba(255,255,255,0.07);
  --line-2:    rgba(255,255,255,0.12);
  --line-em:   rgba(34,211,238,0.30);

  /* text */
  --ink:       #ECEFEE;
  --ink-2:     #AEB5B3;
  --ink-3:     #7B827F;
  --meta:      #9AA19E;            /* small mono captions / timestamps — site-wide, tweakable */
  --ink-4:     var(--meta);        /* smallest mono micro-labels follow --meta so they stay legible */

  /* signal — cyan #22D3EE (tuned via Tweaks panel), light not fill */
  --em:        color-mix(in srgb, #22D3EE 80%, #021410);
  --em-bright: #22D3EE;
  --em-soft:   color-mix(in srgb, #22D3EE 14%, transparent);
  --em-glow:   color-mix(in srgb, #22D3EE 55%, transparent);

  /* type */
  --sans: 'Geist', -apple-system, system-ui, sans-serif;
  --mono: 'Geist Mono', ui-monospace, monospace;

  /* spacing rhythm */
  --gut: clamp(20px, 5vw, 96px);
  --maxw: 1240px;

  /* motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);

  --radius: 14px;
  --radius-lg: 20px;

  /* signature “probe” intensity (overridable per body class) */
  --probe-reach: 360px;
  --probe-grid: 280px;
  --probe-headblur: 60px;
  --probe-headpct: 12;
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv01','ss01';
  overflow-x: hidden;
  position: relative;
}

/* baked grain over the whole canvas */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background-image: url('grain.png');
  background-size: 160px 160px;
  opacity: 0.5;
  mix-blend-mode: soft-light;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
::selection { background: var(--em); color: #04110C; }

/* focus */
:focus-visible {
  outline: 2px solid var(--em-bright);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ---------- layout primitives ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding-block: clamp(72px, 11vw, 160px); position: relative; }
.section--tight { padding-block: clamp(56px, 8vw, 104px); }

.eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--em-bright);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--em-bright);
  border-radius: 50%;
  box-shadow: 0 0 10px var(--em-glow);
  transform: translateY(-1px);
}
.eyebrow--muted { color: var(--meta); }
.eyebrow--muted::before { background: var(--meta); box-shadow: none; }

/* ---------- type ---------- */
.display {
  font-weight: 600;
  font-size: clamp(2.6rem, 6.4vw, 5.4rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.h2 {
  font-weight: 600;
  font-size: clamp(1.9rem, 3.8vw, 3.1rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
  text-wrap: balance;
}
.h3 {
  font-weight: 600;
  font-size: clamp(1.2rem, 1.9vw, 1.55rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
}
.lead {
  font-size: clamp(1.05rem, 1.55vw, 1.32rem);
  line-height: 1.55;
  color: var(--ink-2);
  font-weight: 400;
  text-wrap: pretty;
  max-width: 58ch;
}
.body { color: var(--ink-2); text-wrap: pretty; }
.muted { color: var(--ink-3); }
.em-text { color: var(--em-bright); }
.mono { font-family: var(--mono); }

.kicker {
  font-family: var(--mono);
  font-size: 12.5px;
  color: var(--meta);
  letter-spacing: 0.04em;
}

/* ---------- buttons ---------- */
.btn {
  --pad-y: 13px; --pad-x: 22px;
  display: inline-flex; align-items: center; gap: 9px;
  padding: var(--pad-y) var(--pad-x);
  font-family: var(--sans);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  border-radius: 11px;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
  white-space: nowrap;
  border: 1px solid transparent;
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--em);
  color: #03130C;
  font-weight: 600;
  box-shadow: 0 0 0 0 var(--em-glow), 0 1px 0 rgba(255,255,255,0.18) inset;
}
.btn--primary:hover {
  background: var(--em-bright);
  box-shadow: 0 8px 30px -8px var(--em-glow);
  transform: translateY(-1px);
}
.btn--ghost {
  background: rgba(255,255,255,0.025);
  border-color: var(--line-2);
  color: var(--ink);
}
.btn--ghost:hover { border-color: var(--ink-3); background: rgba(255,255,255,0.05); transform: translateY(-1px); }

.btn--msg {
  background: transparent;
  border-color: var(--line-em);
  color: var(--em-bright);
}
.btn--msg:hover { background: var(--em-soft); border-color: var(--em); transform: translateY(-1px); }

.btn--lg { --pad-y: 16px; --pad-x: 28px; font-size: 1rem; border-radius: 12px; }
.btn .arr { transition: transform .3s var(--ease); }
.btn:hover .arr { transform: translateX(3px); }

.txtlink {
  display: inline-flex; align-items: center; gap: 7px;
  color: var(--ink); font-weight: 500;
  border-bottom: 1px solid var(--line-2);
  padding-bottom: 2px;
  transition: color .2s var(--ease), border-color .2s var(--ease);
}
.txtlink:hover { color: var(--em-bright); border-color: var(--em); }
.txtlink .arr { transition: transform .3s var(--ease); }
.txtlink:hover .arr { transform: translateX(3px); }

/* ---------- nav (injected) ---------- */
.nav {
  position: sticky; top: 0; z-index: 200;
  border-bottom: 1px solid transparent;
  transition: background .3s var(--ease), border-color .3s var(--ease), backdrop-filter .3s var(--ease);
}
.nav.is-stuck {
  background: rgba(7,9,10,0.72);
  backdrop-filter: blur(14px) saturate(1.2);
  border-bottom-color: var(--line);
}
.nav__in {
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.wordmark {
  font-weight: 600; font-size: 1.18rem; letter-spacing: -0.04em;
  color: var(--ink); display: inline-flex; align-items: baseline;
}
.wordmark b { font-weight: 600; }
.wordmark .dot { color: var(--em-bright); margin-left: 0.08em; }
.nav__links { display: flex; align-items: center; gap: 4px; }
.nav__links a {
  padding: 8px 14px; font-size: 0.92rem; color: var(--ink-2); font-weight: 450;
  border-radius: 9px; transition: color .2s var(--ease), background .2s var(--ease);
}
.nav__links a:hover { color: var(--ink); background: rgba(255,255,255,0.04); }
.nav__links a.is-active { color: var(--ink); }
.nav__links a.is-active::after {
  content:''; display:block; height:2px; width: 16px; margin: 3px auto 0;
  background: var(--em-bright); border-radius: 2px; box-shadow: 0 0 8px var(--em-glow);
}
.nav__right { display: flex; align-items: center; gap: 12px; }
.nav__burger { display: none; width: 42px; height: 42px; align-items: center; justify-content: center; border-radius: 9px; border: 1px solid var(--line-2); }
.nav__burger span { display:block; width:17px; height:1.5px; background: var(--ink); position: relative; transition: .3s var(--ease); }
.nav__burger span::before, .nav__burger span::after { content:''; position:absolute; left:0; width:17px; height:1.5px; background: var(--ink); transition:.3s var(--ease); }
.nav__burger span::before { top:-5px; } .nav__burger span::after { top:5px; }

@media (max-width: 880px) {
  .nav__links, .nav__right .btn { display: none; }
  .nav__burger { display: flex; }
  body.menu-open .nav__burger span { background: transparent; }
  body.menu-open .nav__burger span::before { top:0; transform: rotate(45deg); }
  body.menu-open .nav__burger span::after { top:0; transform: rotate(-45deg); }
}

/* mobile menu */
.mobmenu {
  position: fixed; inset: 68px 0 0; z-index: 190;
  background: rgba(7,9,10,0.97); backdrop-filter: blur(16px);
  padding: 24px var(--gut) 48px;
  display: flex; flex-direction: column; gap: 4px;
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .3s var(--ease), transform .3s var(--ease), visibility .3s;
}
body.menu-open .mobmenu { opacity: 1; visibility: visible; transform: none; }
.mobmenu a { padding: 16px 4px; font-size: 1.4rem; font-weight: 500; letter-spacing: -0.02em; border-bottom: 1px solid var(--line); color: var(--ink); }
.mobmenu a .mono { font-size: 12px; color: var(--meta); margin-right: 14px; }
.mobmenu .btn { margin-top: 22px; justify-content: center; }

/* ---------- cards / surfaces ---------- */
.card {
  background: linear-gradient(180deg, var(--raised), var(--bg-2));
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  position: relative;
  transition: border-color .35s var(--ease), transform .35s var(--ease);
}
.card--hover:hover { border-color: var(--line-2); transform: translateY(-3px); }
.panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

/* hairline that lights emerald near top edge */
.lit-top { position: relative; }
.lit-top::before {
  content:''; position:absolute; top:-1px; left:24px; right:24px; height:1px;
  background: linear-gradient(90deg, transparent, var(--line-em), transparent);
}

/* ---------- bento ---------- */
.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
.bento .cell { grid-column: span 2; min-height: 200px; }
.cell--lg { grid-column: span 3; }
.cell--wide { grid-column: span 4; }
.cell--full { grid-column: span 6; }
@media (max-width: 860px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento .cell, .cell--lg, .cell--wide, .cell--full { grid-column: span 2; min-height: 0; }
}

.svc {
  padding: 26px;
  display: flex; flex-direction: column; gap: 14px;
  overflow: hidden;
}
.svc__num { font-family: var(--mono); font-size: 12px; color: var(--meta); }
.svc__title { font-weight: 600; font-size: 1.18rem; letter-spacing: -0.02em; }
.svc__desc { color: var(--ink-2); font-size: 0.96rem; line-height: 1.55; }
.svc__tag {
  margin-top: auto; align-self: flex-start;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--em-bright); padding: 5px 10px; border: 1px solid var(--line-em);
  border-radius: 999px; background: var(--em-soft);
}

/* ---------- glyphs (simple line marks, one weight) ---------- */
.glyph { width: 30px; height: 30px; stroke: var(--em-bright); stroke-width: 1.4; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.glyph--ink { stroke: var(--ink-2); }

/* ---------- reveal ---------- */
.rv { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.rv.in { opacity: 1; transform: none; }
.rv-d1 { transition-delay: .06s; } .rv-d2 { transition-delay: .12s; }
.rv-d3 { transition-delay: .18s; } .rv-d4 { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; transition: none; }
}

/* ---------- footer ---------- */
.foot { border-top: 1px solid var(--line); padding-block: clamp(56px, 8vw, 96px) 40px; position: relative; }
.foot__cta { display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between; gap: 48px; padding-block: clamp(40px,6vw,88px) clamp(64px,9vw,120px); border-bottom: 1px solid var(--line); }
.foot__cta > div:first-child { flex: 1 1 480px; }
.foot__cta h2 { font-size: clamp(2.9rem, 6.4vw, 5rem); line-height: 0.99; letter-spacing: -0.04em; }
.foot__cta .foot__cta-sub { color: var(--ink-2); font-size: 1.1rem; line-height: 1.55; margin-top: 26px; max-width: 50ch; text-wrap: pretty; }
.foot__grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; padding-top: 56px; }
.foot__col h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--meta); margin-bottom: 16px; font-weight: 500; }
.foot__col a { display: block; color: var(--ink-2); padding: 6px 0; font-size: 0.95rem; transition: color .2s var(--ease); }
.foot__col a:hover { color: var(--em-bright); }
.foot__bottom { display:flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; align-items: center; padding-top: 40px; color: var(--meta); font-size: 0.85rem; }
.foot__bottom .mono { font-size: 12px; }
@media (max-width: 760px) { .foot__grid { grid-template-columns: 1fr 1fr; gap: 32px; } .foot__col--brand { grid-column: span 2; } }

/* ---------- inner page hero ---------- */
.phero { position: relative; border-bottom: 1px solid var(--line); overflow: hidden; }
.phero__in { position: relative; z-index: 2; padding-block: clamp(76px, 13vh, 150px) clamp(48px, 7vh, 88px); }
.phero h1 { font-weight: 600; font-size: clamp(2.4rem, 5.4vw, 4.4rem); line-height: 1.0; letter-spacing: -0.04em; max-width: 18ch; text-wrap: balance; }
.phero h1 em { font-style: normal; color: var(--em-bright); text-shadow: 0 0 36px var(--em-glow); }
.phero .lead { margin-top: 26px; }
.phero__meta { margin-top: 36px; display:flex; gap: 22px; flex-wrap: wrap; align-items:center; color: var(--meta); }
.phero__meta .mono { font-size: 12px; }
.phero__meta .sep { width:4px;height:4px;border-radius:50%;background:var(--ink-4); }
.phero .lf-grid--base { opacity: 0.35; }

/* shared section header helper (also used on home) */
.sec-head { display:flex; align-items: end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 44px; }
.sec-head__l { max-width: 64ch; }
.sec-head .eyebrow { margin-bottom: 18px; }

/* ---------- divider / flow rails ---------- */
.rail { height: 1px; background: var(--line); border: 0; }
.dotline { display:flex; align-items:center; gap: 8px; color: var(--meta); font-family: var(--mono); font-size: 12px; }

/* ---------- light-point signature ---------- */
.lightfield {
  position: absolute; inset: 0; overflow: hidden; z-index: 0;
  --mx: 50%; --my: 42%;
  background:
    radial-gradient(120% 90% at 50% -10%, color-mix(in srgb, var(--em-bright) 5%, transparent), transparent 55%),
    radial-gradient(100% 120% at 50% 120%, color-mix(in srgb, var(--em) 5%, transparent), transparent 60%);
}
/* faint engineering grid, only revealed where the light falls */
.lf-grid {
  position: absolute; inset: -2px;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(var(--probe-grid) var(--probe-grid) at var(--mx) var(--my), #000 0%, rgba(0,0,0,0.35) 38%, transparent 72%);
  mask-image: radial-gradient(var(--probe-grid) var(--probe-grid) at var(--mx) var(--my), #000 0%, rgba(0,0,0,0.35) 38%, transparent 72%);
  transition: opacity .4s var(--ease);
}
.lf-grid--base {
  -webkit-mask-image: radial-gradient(900px 700px at 50% 30%, rgba(0,0,0,0.5), transparent 75%);
  mask-image: radial-gradient(900px 700px at 50% 30%, rgba(0,0,0,0.5), transparent 75%);
  opacity: 0.5;
}
/* the probe — dense emerald glow following the pointer */
.lf-glow {
  position: absolute; inset: 0;
  background: radial-gradient(var(--probe-reach) var(--probe-reach) at var(--mx) var(--my),
    color-mix(in srgb, var(--em-bright) 20%, transparent),
    color-mix(in srgb, var(--em-bright) 7%, transparent) 30%, transparent 62%);
  mix-blend-mode: screen;
}
.lf-core {
  position: absolute; left: var(--mx); top: var(--my);
  width: 5px; height: 5px; margin: -2.5px 0 0 -2.5px;
  border-radius: 50%; background: var(--em-bright);
  box-shadow: 0 0 14px 4px var(--em-glow), 0 0 40px 10px color-mix(in srgb, var(--em-bright) 25%, transparent);
  opacity: 0; transition: opacity .4s var(--ease);
}
.lightfield.lf-live .lf-core { opacity: 1; }
.lightfield.lf-static .lf-core { opacity: 0; }
/* faint scan node markers on the grid */
.lf-nodes {
  position: absolute; inset: 0;
  -webkit-mask-image: radial-gradient(320px 320px at var(--mx) var(--my), #000, transparent 70%);
  mask-image: radial-gradient(320px 320px at var(--mx) var(--my), #000, transparent 70%);
}

/* ---------- mock interface windows (graphics, not real screens) ---------- */
.mockwin {
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  border: 1px solid var(--line-2);
  border-radius: 13px;
  overflow: hidden;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.8), 0 0 0 1px rgba(0,0,0,0.4);
}
.mockwin__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 14px; border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.015);
}
.mockwin__dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,0.14); }
.mockwin__title { margin-left: 8px; font-family: var(--mono); font-size: 11px; color: var(--meta); letter-spacing: 0.02em; }
.mockwin__body { padding: 16px; }

/* chat bubbles */
.chat { display: flex; flex-direction: column; gap: 10px; }
.bub { max-width: 80%; padding: 10px 13px; border-radius: 13px; font-size: 0.86rem; line-height: 1.45; }
.bub--in { align-self: flex-start; background: var(--surface-2); border: 1px solid var(--line); border-bottom-left-radius: 4px; color: var(--ink); }
.bub--out { align-self: flex-end; background: var(--em-soft); border: 1px solid var(--line-em); border-bottom-right-radius: 4px; color: var(--ink); }
.bub__meta { font-family: var(--mono); font-size: 10.5px; color: var(--meta); margin-top: 5px; letter-spacing: 0.02em; }
.bub--bot-label { display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; color:var(--em-bright); margin-bottom:4px; }
.bub--bot-label::before{ content:''; width:5px;height:5px;border-radius:50%;background:var(--em-bright);box-shadow:0 0 8px var(--em-glow);}

/* crm pipeline card */
.crm__row { display:flex; align-items:center; justify-content:space-between; padding: 11px 0; border-bottom: 1px solid var(--line); }
.crm__row:last-child{border-bottom:0;}
.crm__name { font-size: 0.9rem; font-weight: 500; }
.crm__sub { font-family: var(--mono); font-size: 11px; color: var(--meta); }
.stage { font-family: var(--mono); font-size: 10.5px; padding: 4px 9px; border-radius: 999px; border: 1px solid var(--line-2); color: var(--ink-2); }
.stage--won { color: var(--em-bright); border-color: var(--line-em); background: var(--em-soft); }
.stage--new { color: var(--ink); }

/* dashboard meters */
.meter { height: 6px; border-radius: 999px; background: rgba(255,255,255,0.06); overflow: hidden; }
.meter > i { display:block; height:100%; background: linear-gradient(90deg, var(--em), var(--em-bright)); border-radius: 999px; box-shadow: 0 0 12px var(--em-glow); }

/* ============================================================
   modern fx layer — life without noise
   ============================================================ */

/* scroll progress (injected) */
.scrollprog { position: fixed; top: 0; left: 0; height: 2px; width: 0%; z-index: 300;
  background: linear-gradient(90deg, var(--em), var(--em-bright));
  box-shadow: 0 0 12px var(--em-glow); transition: width .08s linear; }

/* card pointer-spotlight — ties every surface to the “light” concept */
.card { isolation: isolate; }
.card::before {
  content: ''; position: absolute; inset: 0; z-index: -1; border-radius: inherit;
  background: radial-gradient(240px 240px at var(--cx, 50%) var(--cy, 50%),
    color-mix(in srgb, var(--em-bright) 13%, transparent), transparent 62%);
  opacity: 0; transition: opacity .4s var(--ease); pointer-events: none;
}
.card:hover::before { opacity: 1; }
@media (hover: none) { .card::before { display: none; } }

/* tech-stack marquee */
.marquee { position: relative; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee__track { display: flex; width: max-content; animation: marq 42s linear infinite; will-change: transform; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marq__item { display: inline-flex; align-items: center; gap: 10px; margin-right: 14px; padding: 12px 20px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg-2); white-space: nowrap; color: var(--ink-2); font-size: 0.95rem; }
.marq__item .mono { font-family: var(--mono); font-size: 11px; color: var(--meta); letter-spacing: 0.04em; }
.marq__item b { font-weight: 500; color: var(--ink); }
.marq__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--em-bright); box-shadow: 0 0 8px var(--em-glow); flex: none; }
.stackband__lead .marq__dot { transform: translateY(-1px); }
@keyframes marq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee__track { animation-duration: 90s; } }

/* honest stat band */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 760px) { .stats { grid-template-columns: 1fr 1fr; } }
.stat { padding: 30px 26px; }
.stat__v { font-weight: 600; font-size: clamp(2.4rem, 4.5vw, 3.6rem); letter-spacing: -0.04em; line-height: 1; font-variant-numeric: tabular-nums; }
.stat__v .u { color: var(--em-bright); }
.stat__l { color: var(--ink-3); font-size: 0.95rem; margin-top: 14px; text-wrap: pretty; }
.stat__k { font-family: var(--mono); font-size: 11px; color: var(--meta); letter-spacing: 0.06em; margin-bottom: 16px; }

/* chat typing indicator */
.typing { display: inline-flex; gap: 5px; align-items: center; padding: 12px 14px; }
.typing i { width: 7px; height: 7px; border-radius: 50%; background: var(--em-bright); opacity: 0.4; animation: typing 1.3s var(--ease) infinite; }
.typing i:nth-child(2) { animation-delay: 0.18s; }
.typing i:nth-child(3) { animation-delay: 0.36s; }
@keyframes typing { 0%, 60%, 100% { opacity: 0.3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }
@media (prefers-reduced-motion: reduce) { .typing i { animation: none; opacity: 0.6; } }

/* flowing dashes on the leak rail */
.flow__arr.is-gap {
  background-image: repeating-linear-gradient(90deg, var(--em) 0 4px, transparent 4px 8px);
  background-size: 16px 100%;
  animation: flowdash 0.7s linear infinite;
}
@keyframes flowdash { to { background-position: 16px 0; } }
@media (prefers-reduced-motion: reduce) { .flow__arr.is-gap { animation: none; } }
.flow__node.is-gap b { animation: gappulse 1.8s var(--ease) infinite; }
@keyframes gappulse { 0%, 100% { box-shadow: 0 0 8px var(--em-glow); } 50% { box-shadow: 0 0 16px 2px var(--em-glow); } }
@media (prefers-reduced-motion: reduce) { .flow__node.is-gap b { animation: none; } }

/* reveal: optional clip-rise for headlines */
.rv-line { clip-path: inset(0 0 -20% 0); }

/* ---------- utility ---------- */
.stack { display: flex; flex-direction: column; }
.row { display: flex; align-items: center; }
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}
.wrap-flex{flex-wrap:wrap}
.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}.mt-56{margin-top:56px}
.center{text-align:center}
.maxw-xs{max-width:46ch}.maxw-sm{max-width:54ch}.maxw-md{max-width:64ch}
.hide-mob{display:initial}
@media(max-width:680px){ .hide-mob{display:none} }
