/* ============================================================
   Oktsec — security visual system
   White / deep-navy / restrained blue. Mono as the "evidence voice."
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&family=Newsreader:ital,opsz,wght@0,18..72,400;0,18..72,500;0,18..72,600;1,18..72,400&display=swap');

:root{
  /* ink */
  --ink:        #16171B;
  --ink-soft:   #3C3F47;
  --muted:      #6B6E77;
  --muted-2:    #90949C;

  /* surfaces */
  --bg:         #FFFFFF;
  --bg-alt:     #F4F5F7;
  --bg-tint:    #FAFAFB;
  --navy:       #16171A;
  --navy-2:     #1F2024;

  /* lines */
  --line:       rgba(17,18,22,0.10);
  --line-soft:  rgba(17,18,22,0.06);
  --line-strong:rgba(17,18,22,0.16);
  --line-on-navy: rgba(255,255,255,0.12);

  /* accent — deep indigo-violet (intentional, premium; not generic SaaS blue) */
  --accent:     #4327C4;
  --accent-ink: #311B96;
  --accent-2:   #9A86F2;
  --accent-soft:#EFEBFB;
  --accent-line:rgba(67,39,196,0.22);

  /* evidence states */
  --ok:         #157A52;
  --ok-soft:    #E7F4EE;
  --warn:       #A86810;
  --warn-soft:  #FBF1DE;
  --danger:     #B42318;
  --danger-soft:#FBEBE9;
  --neutral-chip:#EEF0F4;

  /* fonts */
  --serif: 'Newsreader', Georgia, 'Times New Roman', serif;
  --grid:  rgba(17,18,22,0.045);
  --grid-navy: rgba(255,255,255,0.05);

  /* shadow */
  --shadow-sm: 0 1px 2px rgba(17,18,22,0.05), 0 1px 1px rgba(17,18,22,0.03);
  --shadow-md: 0 1px 0 rgba(17,18,22,0.03), 0 10px 30px rgba(17,18,22,0.07);
  --shadow-lg: 0 1px 0 rgba(17,18,22,0.04), 0 30px 60px rgba(17,18,22,0.11);

  --maxw: 1180px;
  --radius: 7px;
  --radius-sm: 5px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Geist', system-ui, sans-serif;
  color:var(--ink);
  background:var(--bg);
  font-size:17px;
  line-height:1.6;
  letter-spacing:-0.011em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--accent); color:#fff; }

.mono{ font-family:'Geist Mono', ui-monospace, 'SF Mono', Menlo, monospace; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:104px 0; position:relative; }
.section--tight{ padding:76px 0; }
.section--alt{ background:var(--bg-alt); }
.section--tint{ background:var(--bg-tint); }
.section--navy{ background:var(--navy); color:#fff; }
.hairline{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- type ----------
   serif = narrative statements (h1/h2) · sans = component titles (h3/h4) · mono = evidence */
h1,h2{ margin:0; font-family:var(--serif); font-weight:500; letter-spacing:-0.012em; line-height:1.08; }
h3,h4{ margin:0; font-family:'Geist', sans-serif; font-weight:600; letter-spacing:-0.015em; line-height:1.22; }
.kicker{
  font-family:'Geist Mono', monospace;
  font-size:11px; font-weight:500;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--accent);
  display:inline-flex; align-items:center; gap:10px;
  white-space:nowrap;
}
.kicker::before{
  content:none;
}
.section--navy .kicker{ color:var(--accent-2); }
.section--navy .kicker::before{ background:var(--accent-2); }

.h-display{ font-size:clamp(2.7rem, 5.8vw, 4.6rem); letter-spacing:-0.018em; line-height:1.02; }
.h-2{ font-size:clamp(2.05rem, 3.7vw, 3.05rem); letter-spacing:-0.014em; line-height:1.06; }
.h-3{ font-size:clamp(1.35rem,2vw,1.65rem); }
.lead{ font-size:clamp(1.08rem,1.5vw,1.32rem); color:var(--ink-soft); line-height:1.5; font-weight:400; letter-spacing:-0.013em; }
.section--navy .lead{ color:rgba(255,255,255,0.74); }
.muted{ color:var(--muted); }
.balance{ text-wrap:balance; }
.pretty{ text-wrap:pretty; }

.sec-head{ max-width:780px; }
.sec-head .h-2{ margin:18px 0 0; }
.sec-head .lead{ margin:22px 0 0; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:'Geist', sans-serif;
  font-size:15px; font-weight:500; letter-spacing:-0.01em;
  padding:13px 22px; border-radius:8px;
  border:1px solid transparent; cursor:pointer;
  transition:transform .15s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
  white-space:nowrap;
}
.btn svg{ width:16px; height:16px; }
.btn--primary{ background:var(--accent); color:#fff; box-shadow:0 1px 2px rgba(0,0,0,.18), 0 6px 18px rgba(0,0,0,.14); }
.btn--primary:hover{ background:var(--accent-ink); transform:translateY(-1px); }
.btn--ghost{ background:#fff; color:var(--ink); border-color:var(--line-strong); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-1px); }
.btn--dark{ background:var(--ink); color:#fff; }
.btn--dark:hover{ background:#2A2B30; transform:translateY(-1px); }
.section--navy .btn--ghost{ background:transparent; color:#fff; border-color:var(--line-on-navy); }
.section--navy .btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.06); }
.btn--lg{ padding:15px 26px; font-size:16px; }
.link-arrow{
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap;
  font-size:15px; font-weight:500; color:var(--accent);
}
.link-arrow svg{ width:15px; height:15px; transition:transform .18s ease; }
.link-arrow:hover svg{ transform:translateX(3px); }

/* ---------- chips / status ---------- */
.chip{
  font-family:'Geist Mono', monospace;
  font-size:11.5px; font-weight:500; letter-spacing:0.02em;
  padding:4px 9px; border-radius:6px;
  display:inline-flex; align-items:center; gap:6px;
  background:var(--neutral-chip); color:var(--ink-soft);
  white-space:nowrap;
}
.chip i{ width:6px; height:6px; border-radius:50%; background:currentColor; display:inline-block; }
.chip--ok{ background:var(--ok-soft); color:var(--ok); }
.chip--warn{ background:var(--warn-soft); color:var(--warn); }
.chip--danger{ background:var(--danger-soft); color:var(--danger); }
.chip--accent{ background:var(--accent-soft); color:var(--accent-ink); }

/* ---------- cards ---------- */
.card{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:28px;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.card--hover:hover{ border-color:var(--line-strong); box-shadow:var(--shadow-md); transform:translateY(-3px); }
/* corner-tick: a small registration mark for a forensic/technical feel */
.tick{ position:relative; }
.tick::before, .tick::after{
  content:""; position:absolute; width:9px; height:9px; pointer-events:none;
  border-color:var(--line-strong); border-style:solid; border-width:0;
}
.tick::before{ top:-1px; left:-1px; border-top-width:1.5px; border-left-width:1.5px; }
.tick::after{ bottom:-1px; right:-1px; border-bottom-width:1.5px; border-right-width:1.5px; }
.surf--hero.tick::before, .surf--hero.tick::after, .section--navy .tick::before, .section--navy .tick::after{ border-color:rgba(255,255,255,0.28); }

/* technical grid texture (hero + navy bands) */
.section--navy{ position:relative; overflow:hidden; }
.section--navy::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--grid-navy) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-navy) 1px, transparent 1px);
  background-size:58px 58px;
  -webkit-mask-image:radial-gradient(130% 100% at 50% 0%, #000 0%, transparent 68%);
  mask-image:radial-gradient(130% 100% at 50% 0%, #000 0%, transparent 68%);
}
.section--navy > .wrap{ position:relative; z-index:1; }

/* ---------- reveal animation ----------
   Hidden state only applies once JS arms it (document visible + motion ok).
   If unarmed (hidden tab, no JS, reduced motion) content stays fully visible. */
.reveal{ transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal-armed .reveal{ opacity:0; transform:translateY(18px); }
.reveal-armed .reveal.in{ opacity:1; transform:none; }
.reveal-armed .reveal[data-d="1"]{ transition-delay:.06s; }
.reveal-armed .reveal[data-d="2"]{ transition-delay:.12s; }
.reveal-armed .reveal[data-d="3"]{ transition-delay:.18s; }
.reveal-armed .reveal[data-d="4"]{ transition-delay:.24s; }

/* staggered children: parent carries .reveal.stagger; children cascade in */
.stagger > *{ transition:opacity .65s cubic-bezier(.2,.7,.2,1), transform .65s cubic-bezier(.2,.7,.2,1); }
.reveal-armed .reveal.stagger{ opacity:1; transform:none; }
.reveal-armed .reveal.stagger > *{ opacity:0; transform:translateY(16px); }
.reveal-armed .reveal.stagger.in > *{ opacity:1; transform:none; }
.reveal-armed .reveal.stagger.in > *:nth-child(1){ transition-delay:.0s; }
.reveal-armed .reveal.stagger.in > *:nth-child(2){ transition-delay:.09s; }
.reveal-armed .reveal.stagger.in > *:nth-child(3){ transition-delay:.18s; }
.reveal-armed .reveal.stagger.in > *:nth-child(4){ transition-delay:.27s; }
.reveal-armed .reveal.stagger.in > *:nth-child(5){ transition-delay:.36s; }
.reveal-armed .reveal.stagger.in > *:nth-child(6){ transition-delay:.45s; }
.reveal-armed .reveal.stagger.in > *:nth-child(7){ transition-delay:.52s; }
.reveal-armed .reveal.stagger.in > *:nth-child(8){ transition-delay:.59s; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.82);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav__in{ height:64px; display:flex; align-items:center; gap:30px; }
.brand{ display:inline-flex; align-items:center; font-weight:600; font-size:19.5px; line-height:1; letter-spacing:-0.04em; color:var(--ink); transform:translateY(-2px); }
.brand b{ font-weight:600; color:var(--accent); }
.nav__links{ display:flex; align-items:center; gap:26px; margin-left:8px; }
.nav__links a{ font-size:14.5px; color:var(--ink-soft); font-weight:450; transition:color .15s ease; position:relative; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-5px; width:100%; height:1px; background:var(--ink); transform:scaleX(0); transform-origin:left; transition:transform .22s cubic-bezier(.2,.7,.2,1); }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav__ghost{ font-size:14.5px; font-weight:500; color:var(--ink); white-space:nowrap; }
.nav__burger{ display:none; }
@media(max-width:920px){
  .nav__links{ display:none; }
  .nav__ghost{ display:none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding:80px 0 60px; position:relative; overflow:hidden; }
.hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:58px 58px;
  -webkit-mask-image:radial-gradient(115% 95% at 72% 22%, #000 0%, transparent 70%);
  mask-image:radial-gradient(115% 95% at 72% 22%, #000 0%, transparent 70%);
}
.hero > .wrap{ position:relative; z-index:1; }
.hero__grid{ display:grid; grid-template-columns:1.04fr 1fr; gap:56px; align-items:center; }
.hero h1{ font-size:clamp(2.6rem,5.2vw,4.15rem); letter-spacing:-0.012em; line-height:1.03; margin:24px 0 0; }
.hero .lead{ margin:24px 0 0; max-width:540px; }
.hero__proof{
  margin:26px 0 0; display:flex; align-items:stretch; gap:0; width:fit-content; max-width:100%;
  font-family:'Geist Mono', monospace; font-size:13.5px; font-weight:500;
  border:1px solid var(--line); border-radius:9px; overflow:hidden;
}
.hero__proof span{ padding:9px 14px; color:var(--ink-soft); white-space:nowrap; }
.hero__proof span+span{ border-left:1px solid var(--line); }
.hero__proof b{ color:var(--accent); font-weight:600; }
.hero__cta{ margin:30px 0 0; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero__tert{ margin:18px 0 0; }
@media(max-width:920px){
  .hero__grid{ grid-template-columns:1fr; gap:40px; }
  .hero__grid > *{ min-width:0; }
  .hero__proof{ flex-wrap:wrap; }
}
@media(max-width:520px){
  .hero h1{ font-size:2.0rem; }
}

/* ---------- control-loop diagram ---------- */
.loop{
  position:relative; background:#fff;
  border:1px solid var(--line-strong); border-radius:10px;
  padding:20px; box-shadow:var(--shadow-lg);
}
.loop__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; padding:2px 4px 12px; border-bottom:1px solid var(--line-soft); }
.loop__title{ font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.loop__live{ display:flex; align-items:center; gap:7px; font-family:'Geist Mono',monospace; font-size:11.5px; color:var(--ok); }
.loop__live i{ width:7px; height:7px; border-radius:50%; background:var(--ok); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }

.loop__rail{ position:relative; display:flex; flex-direction:column; gap:10px; }
.lnode{
  position:relative; display:flex; align-items:center; gap:13px;
  border:1px solid var(--line-strong); border-radius:7px; padding:12px 14px;
  background:#fff; transition:border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.lnode.active{ border-color:var(--accent-line); box-shadow:0 0 0 3px var(--accent-soft); background:#fff; }
.lnode__ico{
  width:38px; height:38px; flex:none; border-radius:6px;
  background:var(--bg-alt); border:1px solid var(--line-strong); display:grid; place-items:center; color:var(--ink);
  transition:background .3s ease, color .3s ease, border-color .3s ease;
}
.lnode.active .lnode__ico{ background:var(--accent); color:#fff; border-color:var(--accent); }
.lnode__ico svg{ width:19px; height:19px; }
.lnode__txt{ flex:1; min-width:0; }
.lnode__t{ font-size:14px; font-weight:550; letter-spacing:-0.01em; }
.lnode__s{ font-family:'Geist Mono',monospace; font-size:11px; color:var(--muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lnode__tag{ font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.04em; padding:3px 7px; border-radius:5px; background:var(--neutral-chip); color:var(--muted); flex:none; transition:background .3s, color .3s; }
.lnode.active .lnode__tag{ background:var(--accent-soft); color:var(--accent-ink); }

.loop__connector{ position:absolute; left:33px; width:2px; background:var(--line); z-index:0; }
.loop__packet{
  position:absolute; left:28px; width:12px; height:12px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 4px var(--accent-soft), 0 0 12px rgba(27,69,217,.5);
  z-index:5; opacity:0; transition:opacity .2s;
}
.loop__packet::after{
  content:""; position:absolute; left:50%; top:50%; width:4px; height:26px;
  transform:translate(-50%,-100%); border-radius:3px;
  background:linear-gradient(to top, rgba(27,69,217,.35), transparent);
}
.loop__packet--ok{
  background:var(--ok); box-shadow:0 0 0 4px var(--ok-soft), 0 0 12px rgba(21,122,82,.5);
}
.loop__packet--ok::after{
  transform:translate(-50%,0); background:linear-gradient(to bottom, rgba(21,122,82,.35), transparent);
}
.lnode.active--ok{ border-color:rgba(21,122,82,.35); box-shadow:0 0 0 3px var(--ok-soft); }
.lnode.active--ok .lnode__ico{ background:var(--ok); color:#fff; border-color:var(--ok); }
.lnode.active--ok .lnode__tag{ background:var(--ok-soft); color:var(--ok); }

.loop__queue{ margin-top:14px; border-top:1px solid var(--line-soft); padding-top:14px; }
.loop__queue-h{ display:flex; align-items:center; justify-content:space-between; font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; padding:0 2px; white-space:nowrap; }
.qrow{ display:flex; align-items:center; gap:10px; padding:7px 8px; border-radius:8px; font-family:'Geist Mono',monospace; font-size:12px; transition:background .3s; }
.qrow:hover{ background:var(--bg-tint); }
.qrow__id{ color:var(--ink-soft); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.qrow__hash{ color:var(--muted-2); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ============================================================
   PROBLEM cards
   ============================================================ */
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media(max-width:980px){ .grid-4{ grid-template-columns:repeat(2,1fr);} .grid-3{ grid-template-columns:1fr;} }
@media(max-width:680px){ .grid-4{ grid-template-columns:1fr;} .grid-2{ grid-template-columns:1fr;} }

.pcard{ display:flex; flex-direction:column; align-items:flex-start; }
.pcard__ico{ width:40px; height:40px; border-radius:6px; background:#fff; border:1px solid var(--line-strong); color:var(--accent); display:grid; place-items:center; margin-bottom:20px; }
.pcard__ico svg{ width:20px; height:20px; }
.pcard h3{ font-size:18px; font-weight:600; text-wrap:balance; }
.pcard p{ margin:10px 0 0; font-size:14.5px; color:var(--muted); line-height:1.5; }
.closing-line{ margin-top:34px; font-size:clamp(1.05rem,1.6vw,1.28rem); font-weight:500; color:var(--ink); letter-spacing:-0.018em; }
.closing-line b{ color:var(--accent); font-weight:600; }

/* ============================================================
   WHY NOW — metrics
   ============================================================ */
.metric{ padding:34px 30px; border:1px solid var(--line); border-radius:var(--radius); background:#fff; }
.metric__n{ font-size:clamp(2.8rem,4.6vw,3.7rem); font-weight:600; letter-spacing:-0.04em; line-height:1; color:var(--ink); }
.metric__n b{ color:var(--accent); font-weight:600; }
.metric__d{ margin:14px 0 0; font-size:15px; color:var(--ink-soft); line-height:1.45; }
.metric__src{ margin:12px 0 0; font-family:'Geist Mono',monospace; font-size:11px; color:var(--muted-2); }

/* ============================================================
   CONTROL LOOP steps (numbered)
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.step{ padding:30px 26px; border-right:1px solid var(--line-soft); position:relative; }
.step:last-child{ border-right:0; }
.step__n{ font-family:'Geist Mono',monospace; font-size:13px; font-weight:600; color:var(--accent); letter-spacing:.04em; }
.step h3{ margin:16px 0 0; font-size:17px; font-weight:600; }
.step p{ margin:10px 0 0; font-size:14px; color:var(--muted); line-height:1.5; }
.step__arrow{ position:absolute; right:-9px; top:38px; width:18px; height:18px; background:#fff; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; z-index:2; color:var(--muted); }
.step__arrow svg{ width:11px; height:11px; }
@media(max-width:980px){ .steps{ grid-template-columns:1fr 1fr;} .step__arrow{ display:none; } .step{ border-bottom:1px solid var(--line-soft);} }
@media(max-width:680px){ .steps{ grid-template-columns:1fr;} }
.proofline{
  margin-top:26px; display:flex; align-items:stretch; gap:0; flex-wrap:wrap; width:fit-content; max-width:100%;
  font-family:'Geist Mono',monospace; font-size:14px;
  border:1px solid var(--accent-line); background:var(--accent-soft); border-radius:var(--radius); overflow:hidden;
}
.proofline span{ padding:11px 17px; color:var(--accent-ink); font-weight:500; white-space:nowrap; }
.proofline span+span{ border-left:1px solid var(--accent-line); }

/* ============================================================
   PRODUCT SURFACES
   ============================================================ */
.surfaces{ display:grid; grid-template-columns:1.5fr 1fr; grid-template-rows:auto auto; gap:18px; }
.surf{ border:1px solid var(--line); border-radius:var(--radius); padding:28px; background:#fff; transition:border-color .2s, box-shadow .2s, transform .2s; }
.surf--hero{ grid-row:span 2; background:var(--navy); color:#fff; border-color:transparent; display:flex; flex-direction:column; }
.surf:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px); }
.surf--hero:hover{ box-shadow:var(--shadow-lg); }
.surf__tag{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.surf--hero .surf__tag{ color:var(--accent-2); }
.surf h3{ font-size:22px; margin:14px 0 0; font-weight:600; letter-spacing:-0.008em; }
.surf--hero h3{ font-size:31px; letter-spacing:-0.012em; font-family:var(--serif); font-weight:500; line-height:1.1; }
.surf:not(.surf--hero) h3{ font-family:var(--serif); font-weight:500; letter-spacing:-0.006em; line-height:1.12; }
.surf__lede{ margin:10px 0 0; font-size:15px; font-weight:500; color:var(--ink-soft); }
.surf--hero .surf__lede{ color:#fff; }
.surf p{ margin:12px 0 0; font-size:14.5px; color:var(--muted); line-height:1.5; }
.surf--hero p{ color:rgba(255,255,255,0.66); }
.surf__spacer{ flex:1; }
.surf__list{ margin:20px 0 0; display:flex; flex-direction:column; gap:9px; }
.surf__list div{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:rgba(255,255,255,0.82); font-family:'Geist Mono',monospace; }
.surf__list svg{ width:14px; height:14px; color:var(--accent-2); flex:none; }
.surf__cta{ margin-top:24px; }
@media(max-width:880px){ .surfaces{ grid-template-columns:1fr; } .surf--hero{ grid-row:auto; } }

/* ============================================================
   PRODUCT PROOF
   ============================================================ */
.proof__grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.proofbul{ display:flex; gap:16px; padding:20px 0; border-top:1px solid var(--line-soft); }
.proofbul:first-child{ border-top:0; }
.proofbul__n{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--accent); font-weight:600; padding-top:3px; }
.proofbul h4{ font-size:15.5px; font-weight:600; }
.proofbul p{ margin:6px 0 0; font-size:14px; color:var(--muted); line-height:1.5; }
.boundary{ margin-top:26px; padding:16px 18px; border:1px dashed var(--line-strong); border-radius:var(--radius); font-size:13.5px; color:var(--muted); background:var(--bg-tint); }
.boundary b{ color:var(--ink-soft); font-weight:600; }
@media(max-width:880px){ .proof__grid{ grid-template-columns:1fr; gap:30px; } }

/* console mock */
.console{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; box-shadow:var(--shadow-md); }
.console__bar{ height:42px; display:flex; align-items:center; gap:8px; padding:0 16px; border-bottom:1px solid var(--line-soft); background:var(--bg-tint); }
.console__dot{ width:10px; height:10px; border-radius:50%; background:var(--line-strong); }
.console__title{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted); margin-left:8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.console__body{ padding:6px; }
.crow{ display:grid; grid-template-columns:1.1fr 1fr auto; gap:12px; align-items:center; padding:13px 14px; border-radius:6px; font-family:'Geist Mono',monospace; font-size:12.5px; }
.crow+.crow{ border-top:1px solid var(--line-soft); }
.crow__id{ color:var(--ink); }
.crow__meta{ color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.console__body .crow{ grid-template-columns:1.1fr 1fr 116px; }
.console__body .crow__id, .console__body .crow__meta{ justify-self:start; text-align:left; }
.console__body .crow .chip{ justify-self:end; }

/* ============================================================
   SECURITY ARCHITECTURE pillars
   ============================================================ */
.pillar{ padding:26px; border:1px solid var(--line-on-navy); border-radius:var(--radius); background:rgba(255,255,255,0.02); }
.pillar__ico{ width:38px; height:38px; border-radius:6px; background:rgba(79,116,240,.10); border:1px solid rgba(79,116,240,.34); color:var(--accent-2); display:grid; place-items:center; margin-bottom:16px; }
.pillar__ico svg{ width:20px; height:20px; }
.pillar h3{ font-size:16px; font-weight:600; color:#fff; }
.pillar p{ margin:9px 0 0; font-size:14px; color:rgba(255,255,255,0.62); line-height:1.5; }

/* ============================================================
   FEATURE GROUPS
   ============================================================ */
.fgroup{ border:1px solid var(--line); border-radius:var(--radius); padding:22px; background:#fff; }
.fgroup__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.fgroup h4{ margin:12px 0 0; font-size:16px; font-weight:600; }
.fgroup p{ margin:8px 0 0; font-size:14px; color:var(--muted); line-height:1.5; }

/* ============================================================
   AUDIT
   ============================================================ */
.audit__big{ font-size:clamp(2.6rem,4.4vw,3.5rem); font-weight:600; letter-spacing:-0.04em; color:var(--ink); line-height:1; }
.taglist{ display:flex; flex-wrap:wrap; gap:9px; margin-top:22px; }
.taglist span{ font-family:'Geist Mono',monospace; font-size:12.5px; padding:7px 12px; border:1px solid var(--line); border-radius:8px; color:var(--ink-soft); background:#fff; white-space:nowrap; }

/* ============================================================
   CATEGORY
   ============================================================ */
.qa{ border-top:1px solid var(--line); padding:18px 0; display:flex; gap:16px; align-items:baseline; }
.qa__q{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--accent); flex:none; width:30px; }
.qa__t{ font-size:17px; font-weight:500; color:var(--ink); letter-spacing:-0.015em; }
.tam{ text-align:center; padding:40px; border:1px solid var(--accent-line); background:var(--accent-soft); border-radius:var(--radius); }
.tam__n{ font-size:clamp(3rem,6vw,4.6rem); font-weight:600; letter-spacing:-0.04em; color:var(--accent-ink); line-height:1; }
.tam__d{ margin:14px auto 0; max-width:460px; font-size:15px; color:var(--accent-ink); }
.tam__fn{ margin:18px auto 0; max-width:620px; font-family:'Geist Mono',monospace; font-size:11px; color:var(--muted); line-height:1.6; }

/* ============================================================
   FOUNDER
   ============================================================ */
.founder{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.founder__media{ aspect-ratio:4/3.4; border-radius:var(--radius); border:1px solid var(--line-on-navy); background:linear-gradient(160deg,#26272C,#16171A); position:relative; overflow:hidden; display:grid; place-items:center; }
.proofpoints{ margin:24px 0 0; display:flex; flex-direction:column; gap:0; }
.proofpoints div{ display:flex; gap:13px; padding:13px 0; border-top:1px solid var(--line-on-navy); font-size:14.5px; color:rgba(255,255,255,0.82); align-items:flex-start; }
.proofpoints div:first-child{ border-top:0; }
.proofpoints svg{ width:16px; height:16px; color:var(--accent-2); flex:none; margin-top:3px; }
@media(max-width:880px){ .founder{ grid-template-columns:1fr; gap:34px; } }

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{ text-align:center; }
.finalcta h2{ font-size:clamp(2.2rem,4.4vw,3.4rem); letter-spacing:-0.03em; }
.finalcta .lead{ margin:22px auto 0; max-width:620px; }
.finalcta__btns{ margin:34px 0 0; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy); color:#fff; padding:64px 0 40px; }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.footer__brand .brand{ color:#fff; }
.footer__brand p{ margin:16px 0 0; font-size:14px; color:rgba(255,255,255,0.56); max-width:280px; line-height:1.55; }
.footer__col h5{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,0.5); margin:0 0 16px; font-weight:500; }
.footer__col a{ display:block; font-size:14px; color:rgba(255,255,255,0.74); padding:6px 0; transition:color .15s; }
.footer__col a:hover{ color:#fff; }
.footer__bottom{ margin-top:48px; padding-top:24px; border-top:1px solid var(--line-on-navy); display:flex; justify-content:space-between; align-items:center; font-size:13px; color:rgba(255,255,255,0.5); }
@media(max-width:820px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:30px; } }
@media(max-width:520px){ .footer__grid{ grid-template-columns:1fr; } .footer__bottom{ flex-direction:column; gap:12px; } }

/* eyebrow tag for sections on navy */
.section--navy .surf__tag{ color:var(--accent-2); }

/* generic divider label */
.divlabel{ font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }

/* mobile drawer */
.nav__burger{ width:40px; height:40px; border:1px solid var(--line); border-radius:9px; background:#fff; display:none; place-items:center; cursor:pointer; }
.nav__burger svg{ width:19px; height:19px; color:var(--ink); }
.drawer{ display:none; border-top:1px solid var(--line-soft); background:#fff; }
.drawer[data-open]{ display:block; }
.drawer__in{ padding:14px 28px 22px; display:flex; flex-direction:column; gap:4px; }
.drawer a{ padding:11px 0; font-size:16px; color:var(--ink-soft); border-bottom:1px solid var(--line-soft); }
.drawer .btn{ margin-top:14px; justify-content:center; }
@media(max-width:920px){ .nav__burger{ display:grid; } .nav__right .nav__ghost{ display:none; } }

/* ============================================================
   INTERNAL PAGES
   ============================================================ */
.phero{ padding:72px 0 56px; border-bottom:1px solid var(--line-soft); }
.phero--navy{ background:linear-gradient(180deg,#1C1D21 0%,#16171A 70%,#0E0E10 100%); color:#fff; border-bottom:0; }
.phero--navy .lead{ color:rgba(255,255,255,0.78); }
.phero--navy .kicker{ color:var(--accent-2); }
.phero--navy .crumbs, .phero--navy .crumbs a{ color:rgba(255,255,255,0.55); }
.phero--navy .crumbs span{ color:rgba(255,255,255,0.25); }
.phero--navy .crumbs a:hover{ color:#fff; }
.phero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:54px; align-items:center; }
.phero h1{ font-size:clamp(2.2rem,4.4vw,3.4rem); letter-spacing:-0.03em; line-height:1.04; margin:20px 0 0; }
.phero .lead{ margin:22px 0 0; }
.phero__cta{ margin:30px 0 0; display:flex; gap:14px; flex-wrap:wrap; }
.crumbs{ display:flex; align-items:center; gap:9px; font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted); }
.crumbs a{ color:var(--muted); }
.crumbs a:hover{ color:var(--accent); }
.crumbs span{ color:var(--line-strong); }
@media(max-width:880px){ .phero__grid{ grid-template-columns:1fr; gap:36px; } }

/* row block: text left / visual right, alternating */
.rowblock{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; padding:64px 0; border-top:1px solid var(--line-soft); }
.rowblock:first-of-type{ border-top:0; }
.rowblock--flip .rowblock__media{ order:-1; }
.rowblock h2{ font-size:clamp(1.6rem,2.6vw,2.1rem); letter-spacing:-0.025em; }
.rowblock h2+p{ margin:16px 0 0; }
.rowblock .kicker{ margin-bottom:14px; }
.featrow{ margin-top:20px; display:flex; flex-direction:column; gap:12px; }
.featrow div{ display:flex; gap:11px; font-size:15px; color:var(--ink-soft); align-items:flex-start; }
.featrow svg{ width:18px; height:18px; color:var(--accent); flex:none; margin-top:3px; }
@media(max-width:880px){ .rowblock{ grid-template-columns:1fr; gap:30px; padding:48px 0; } .rowblock--flip .rowblock__media{ order:0; } }

/* workflow stepper */
.flow{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.flowstep{ border:1px solid var(--line); border-radius:12px; padding:22px; background:#fff; position:relative; }
.flowstep__n{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--accent); font-weight:600; }
.flowstep h4{ margin:12px 0 0; font-size:15.5px; font-weight:600; }
.flowstep p{ margin:8px 0 0; font-size:13.5px; color:var(--muted); line-height:1.5; }
@media(max-width:880px){ .flow{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .flow{ grid-template-columns:1fr; } }

/* roadmap */
.roadmap{ display:flex; flex-direction:column; }
.rmrow{ display:grid; grid-template-columns:140px 1fr auto; gap:20px; align-items:center; padding:18px 0; border-top:1px solid var(--line); }
.rmrow:first-child{ border-top:0; }
.rmrow__ph{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted); }
.rmrow__t{ font-size:15.5px; font-weight:500; color:var(--ink); }
@media(max-width:620px){ .rmrow{ grid-template-columns:1fr auto; } .rmrow__ph{ grid-column:1/-1; } }

/* deliverable list */
.delist{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.delist div{ display:flex; gap:12px; align-items:flex-start; padding:16px 18px; border:1px solid var(--line); border-radius:11px; background:#fff; font-size:14.5px; color:var(--ink-soft); }
.delist svg{ width:18px; height:18px; color:var(--accent); flex:none; margin-top:2px; }
@media(max-width:680px){ .delist{ grid-template-columns:1fr; } }

/* media card (illustrative product surface) */
.mediacard{ border:1px solid var(--line); border-radius:var(--radius); background:#fff; box-shadow:var(--shadow-md); overflow:hidden; }
.mediacard--navy{ background:var(--navy); border-color:transparent; box-shadow:var(--shadow-lg); }

/* ============================================================
   CRAFT v2 — editorial / spec-sheet system
   ============================================================ */

/* Monochrome ink system — premium/editorial, decisively non-blue.
   The ONLY hues on the page are the green/amber/red evidence states,
   which ties all color to the product's forensic vocabulary. */
:root{
  /* warm near-black for dark bands (no blue cast) */
  --navy:#191917;
  --navy-2:#22231F;

  /* accent = ink. Primary CTAs go solid black; links/marks read by weight + underline. */
  --accent:#1A1A18;
  --accent-ink:#000000;
  --accent-2:#C7C5BE;                    /* light warm grey for eyebrows on dark */
  --accent-soft:#F1F0EC;                 /* warm grey for chip/active backgrounds */
  --accent-line:rgba(26,26,24,0.18);

  /* warm the neutrals a touch */
  --bg-alt:#F5F4F1;
  --bg-tint:#FAF9F6;
  --line:rgba(25,25,23,0.11);
  --line-soft:rgba(25,25,23,0.06);
  --line-strong:rgba(25,25,23,0.17);
  --grid:rgba(25,25,23,0.045);
}
.section--navy{ background:linear-gradient(180deg,#1F201C 0%,#191917 60%,#101010 100%); }

/* link affordance now that links aren't a separate hue */
.link-arrow{ text-decoration:none; }
.link-arrow:hover{ text-decoration:underline; text-underline-offset:3px; }
/* keep the accent-soft chip readable in monochrome */
.chip--accent{ color:var(--ink); }
.toc a.active{ color:var(--ink); border-left-color:var(--ink); }

/* CTAs on dark bands must invert to white — a near-black button on near-black is invisible */
.section--navy .btn--primary,
.section--navy .btn--dark,
.phero--navy .btn--primary,
.phero--navy .btn--dark,
.surf--hero .btn--primary,
.surf--hero .btn--dark,
.art-cta .btn--primary,
.art-cta .btn--dark,
.tier--feature .btn--primary{
  background:#fff; color:#111; box-shadow:0 1px 2px rgba(0,0,0,.28), 0 8px 22px rgba(0,0,0,.30);
}
.section--navy .btn--primary:hover,
.section--navy .btn--dark:hover,
.phero--navy .btn--primary:hover,
.phero--navy .btn--dark:hover,
.surf--hero .btn--primary:hover,
.surf--hero .btn--dark:hover,
.art-cta .btn--primary:hover,
.art-cta .btn--dark:hover,
.tier--feature .btn--primary:hover{
  background:#ECEBE6; color:#111; transform:translateY(-1px);
}
/* ghost on dark: clearer white outline */
.phero--navy .btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,0.30); }
.phero--navy .btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.07); }
.section--navy .btn--ghost{ border-color:rgba(255,255,255,0.30); }

/* bolder display type */
.hero h1{ font-size:clamp(2.7rem,5.4vw,4.5rem); letter-spacing:-0.02em; line-height:1.0; }
.h-2{ font-size:clamp(2.15rem,3.9vw,3.25rem); letter-spacing:-0.018em; line-height:1.04; }
.lead{ font-size:clamp(1.1rem,1.55vw,1.36rem); }

/* numbered section eyebrow: §01 THE GAP */
.kicker[data-n]::before{
  content:"\00a7" attr(data-n);
  width:auto; height:auto; background:none; border-radius:0;
  font-weight:600; letter-spacing:.06em;
}

/* de-box ALL feature icons — kill the "icon in a tile" slop tell */
.pcard__ico{
  width:auto; height:auto; border:0; background:none; border-radius:0;
  color:var(--accent); display:block; margin-bottom:18px;
}
.pcard__ico svg{ width:26px; height:26px; }
.pillar__ico{
  width:auto; height:auto; border:0; background:none; border-radius:0;
  color:var(--accent-2); display:block; margin-bottom:16px;
}
.pillar__ico svg{ width:26px; height:26px; }

/* editorial ledger: numbered cells under a heavy top rule (no cards, no icons) */
.ledger{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1.5px solid var(--ink); }
.lcell{ padding:26px 26px 30px; border-right:1px solid var(--line); position:relative; }
.lcell:last-child{ border-right:0; }
.lcell__n{ font-family:'Geist Mono',monospace; font-size:12px; font-weight:600; letter-spacing:.14em; color:var(--accent); }
.lcell h3{ margin:48px 0 0; font-family:var(--serif); font-weight:500; font-size:1.32rem; letter-spacing:-0.01em; line-height:1.12; color:var(--ink); }
.lcell p{ margin:12px 0 0; font-size:14px; color:var(--muted); line-height:1.55; }
.lcell::after{ content:""; position:absolute; left:0; top:-1.5px; width:34px; height:1.5px; background:var(--accent); }
@media(max-width:900px){ .ledger{ grid-template-columns:1fr 1fr; } .lcell{ border-bottom:1px solid var(--line); } .lcell:nth-child(2n){ border-right:0; } }
@media(max-width:560px){ .ledger{ grid-template-columns:1fr; } .lcell{ border-right:0; } .lcell h3{ margin-top:18px; } .lcell__n{ position:absolute; right:26px; top:26px; } }

/* credibility strip */
.cred{ display:flex; align-items:center; gap:38px; flex-wrap:wrap; padding:22px 0; }
.cred__label{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); white-space:nowrap; }
.cred__items{ display:flex; align-items:center; gap:30px; flex-wrap:wrap; }
.cred__item{ display:flex; align-items:center; gap:10px; font-size:15px; font-weight:500; color:var(--ink-soft); letter-spacing:-0.01em; }
.cred__item svg{ width:17px; height:17px; color:var(--accent); flex:none; }
.cred__sep{ width:1px; height:18px; background:var(--line); }
@media(max-width:760px){ .cred{ gap:18px; } .cred__sep{ display:none; } }

/* ---- proof band (replaces the checkmark cred strip) ---- */
.proofband{ display:grid; grid-template-columns:auto 1px 1fr; gap:54px; align-items:center; padding:8px 0; }
.proofband__stat{ display:flex; align-items:center; gap:18px; }
.proofband__n{ font-size:clamp(3.1rem,5vw,4.3rem); font-weight:600; letter-spacing:-0.045em; line-height:.86; color:var(--ink); }
.proofband__cap{ font-size:13.5px; line-height:1.4; color:var(--muted); max-width:30ch; }
.proofband__rule{ align-self:stretch; width:1px; background:var(--line); }
.proofband__vlabel{ font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); margin-bottom:16px; }
.vendmarks{ display:flex; align-items:center; gap:0 34px; flex-wrap:wrap; }
.vendmark{ font-size:18px; font-weight:500; letter-spacing:-0.012em; color:var(--muted); transition:color .18s ease; white-space:nowrap; }
.vendmark:hover{ color:var(--ink); }

/* structured logo-wall: ledger grid of vendor wordmarks (no trademarked logomarks) */
.vendwall{ display:grid; grid-template-columns:repeat(6,1fr); border:1px solid var(--line); border-radius:8px; overflow:hidden; background:#fff; }
.vendcell{ display:flex; align-items:center; justify-content:center; gap:9px; padding:19px 8px; text-align:center; border-right:1px solid var(--line); transition:background .16s ease; }
.vendcell:last-child{ border-right:0; }
.vendcell:hover{ background:var(--bg-tint); }
.vendcell__m{ display:none; }
.vendcell__n{ font-size:16.5px; font-weight:600; letter-spacing:-0.018em; color:var(--ink-soft); white-space:nowrap; transition:color .16s ease; }
.vendcell:hover .vendcell__n{ color:var(--ink); }
.vendlogo{ height:24px; width:auto; max-width:120px; display:block; fill:var(--muted); color:var(--muted); transition:fill .16s ease, color .16s ease; }
.vendcell:hover .vendlogo{ fill:var(--ink); color:var(--ink); }
.vendcell__wm{ font-family:'Geist',sans-serif; font-size:18px; font-weight:600; letter-spacing:-0.02em; color:var(--muted); transition:color .16s ease; }
.vendcell:hover .vendcell__wm{ color:var(--ink); }
.vendlogo--img{ height:22px; width:auto; fill:none; opacity:.55; transition:opacity .16s ease; }
.vendcell:hover .vendlogo--img{ opacity:1; }
@media(max-width:820px){ .vendwall{ grid-template-columns:repeat(3,1fr); } .vendcell:nth-child(3n){ border-right:0; } .vendcell:nth-child(-n+3){ border-bottom:1px solid var(--line); } }
@media(max-width:460px){ .vendwall{ grid-template-columns:repeat(2,1fr); } .vendcell:nth-child(odd){ border-right:1px solid var(--line); } .vendcell:nth-child(even){ border-right:0; } .vendcell:nth-child(-n+4){ border-bottom:1px solid var(--line); } .vendcell__n{ font-size:14px; } }
.proofband__foot{ margin-top:14px; font-size:13px; color:var(--muted-2); }
.proofband--center{ justify-items:center; text-align:center; }
.proofband--center .vendmarks{ justify-content:center; }
@media(max-width:820px){
  .proofband{ grid-template-columns:1fr; gap:26px; }
  .proofband__rule{ display:none; }
  .proofband__cap{ max-width:none; }
  .vendmarks{ gap:0 26px; }
}

/* product walkthrough — framed UI panels with editorial captions */
.walk{ display:grid; grid-template-columns:1fr; gap:0; }
.walkrow{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:54px; align-items:center; padding:56px 0; border-top:1px solid var(--line); }
.walkrow:first-child{ border-top:0; }
.walkrow--flip .walkrow__media{ order:-1; }
.walkrow__n{ font-family:'Geist Mono',monospace; font-size:12px; font-weight:600; letter-spacing:.14em; color:var(--accent); }
.walkrow h3{ margin:16px 0 0; font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,2.4vw,2rem); letter-spacing:-0.014em; line-height:1.08; }
.walkrow p{ margin:14px 0 0; font-size:15.5px; color:var(--ink-soft); line-height:1.55; max-width:420px; }
.walkrow__tags{ margin:20px 0 0; display:flex; gap:8px; flex-wrap:wrap; }
@media(max-width:900px){ .walkrow{ grid-template-columns:1fr; gap:28px; padding:44px 0; } .walkrow--flip .walkrow__media{ order:0; } .walkrow p{ max-width:none; } }

/* a richer console with side gutter line-numbers / panel chrome */
.panel{ border:1px solid var(--line-strong); border-radius:9px; background:#fff; box-shadow:var(--shadow-lg); overflow:hidden; }
.panel__bar{ height:40px; display:flex; align-items:center; gap:8px; padding:0 14px; border-bottom:1px solid var(--line-soft); background:var(--bg-tint); }
.panel__seg{ display:flex; gap:5px; }
.panel__seg i{ width:9px; height:9px; border-radius:50%; background:var(--line-strong); display:block; }
.panel__title{ font-family:'Geist Mono',monospace; font-size:11.5px; color:var(--muted); margin-left:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.panel__tab{ margin-left:auto; font-family:'Geist Mono',monospace; font-size:11px; color:var(--accent); background:var(--accent-soft); padding:3px 9px; border-radius:5px; }
.panel__body{ padding:8px; }
.codeln{ display:grid; grid-template-columns:30px 1fr; gap:0; font-family:'Geist Mono',monospace; font-size:12.5px; line-height:2; }
.codeln__g{ color:var(--muted-2); text-align:right; padding-right:14px; border-right:1px solid var(--line-soft); user-select:none; }
.codeln__c{ padding-left:14px; color:var(--ink-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.panel--poc .codeln{ font-size:11.5px; line-height:1.65; align-items:start; }
.panel--poc .codeln__g{ padding-top:1px; }
.panel--poc .codeln__c{ white-space:pre-wrap; overflow-wrap:anywhere; overflow:visible; text-overflow:clip; }
.panel__cite{ font-size:11.5px; line-height:1.5; color:var(--muted); margin-top:8px; text-align:center; letter-spacing:.01em; }
.panel__cite a{ color:var(--accent); font-weight:600; white-space:nowrap; }
.panel__cite a:hover{ text-decoration:underline; }
.tok-k{ color:var(--accent); } .tok-s{ color:var(--ok); } .tok-m{ color:var(--muted); } .tok-w{ color:var(--warn); } .tok-d{ color:var(--danger); }

/* diff rows */
.diffrow{ display:grid; grid-template-columns:18px 1fr; gap:8px; font-family:'Geist Mono',monospace; font-size:12.5px; line-height:1.95; padding:0 12px; }
.diffrow--add{ background:var(--ok-soft); }
.diffrow--del{ background:var(--danger-soft); }
.diffrow__s{ color:var(--muted-2); }
.diffrow--add .diffrow__s{ color:var(--ok); } .diffrow--del .diffrow__s{ color:var(--danger); }

/* integrations ledger */
.intg{ border-top:1px solid var(--line); }
.intgrow{ display:grid; grid-template-columns:34px 200px 1fr auto; gap:18px; align-items:center; padding:17px 4px; border-bottom:1px solid var(--line); transition:background .15s ease; }
.intgrow:hover{ background:var(--bg-tint); }
.intgrow__i{ color:var(--ink-soft); display:flex; }
.intgrow__i svg{ width:20px; height:20px; }
.intgrow__n{ font-weight:550; font-size:15.5px; letter-spacing:-0.01em; color:var(--ink); }
.intgrow__d{ font-size:14px; color:var(--muted); }
@media(max-width:760px){ .intgrow{ grid-template-columns:28px 1fr auto; } .intgrow__d{ display:none; } }

/* use cases */
.uc{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.uccol{ padding:30px 28px; border-right:1px solid var(--line); }
.uccol:last-child{ border-right:0; }
.uccol__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.uccol h3{ margin:14px 0 0; font-family:var(--serif); font-weight:500; font-size:1.42rem; letter-spacing:-0.012em; }
.uccol p{ margin:12px 0 0; font-size:14px; color:var(--muted); line-height:1.55; }
.uclist{ margin:20px 0 0; display:flex; flex-direction:column; gap:11px; }
.uclist div{ display:flex; gap:10px; font-size:13.5px; color:var(--ink-soft); align-items:flex-start; line-height:1.4; }
.uclist svg{ width:15px; height:15px; color:var(--accent); flex:none; margin-top:3px; }
@media(max-width:860px){ .uc{ grid-template-columns:1fr; } .uccol{ border-right:0; border-bottom:1px solid var(--line); } .uccol:last-child{ border-bottom:0; } }

/* writing / research index (SEO content) */
.wr{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1.5px solid var(--ink); }
.wrcard{ padding:28px 26px 30px; border-right:1px solid var(--line); display:flex; flex-direction:column; position:relative; transition:background .18s ease; color:inherit; }
.wrcard::after{ content:""; position:absolute; left:0; top:-1.5px; width:34px; height:1.5px; background:var(--accent); }
.wrcard:hover{ background:var(--bg-tint); }
.wrcard:last-child{ border-right:0; }
.wrcard__meta{ display:flex; gap:12px; align-items:center; font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); white-space:nowrap; }
.wrcard__meta b{ color:var(--accent); font-weight:600; }
.wrcard h3{ margin:34px 0 0; font-family:var(--serif); font-weight:500; font-size:1.42rem; line-height:1.15; letter-spacing:-0.01em; color:var(--ink); }
.wrcard p{ margin:12px 0 0; font-size:14px; color:var(--muted); line-height:1.55; flex:1; }
.wrcard__foot{ margin-top:24px; display:flex; align-items:center; gap:8px; font-size:14px; font-weight:500; color:var(--accent); }
.wrcard__foot svg{ width:14px; height:14px; transition:transform .18s ease; }
.wrcard:hover .wrcard__foot svg{ transform:translateX(3px); }
@media(max-width:860px){ .wr{ grid-template-columns:1fr; } .wrcard{ border-right:0; border-bottom:1px solid var(--line); } .wrcard h3{ margin-top:16px; } }

/* FAQ */
.faq{ border-top:1px solid var(--ink); }
.faqitem{ border-bottom:1px solid var(--line); padding:26px 0; display:grid; grid-template-columns:0.9fr 1.1fr; gap:40px; align-items:start; }
.faqitem__q{ font-family:var(--serif); font-weight:500; font-size:1.28rem; letter-spacing:-0.01em; line-height:1.2; color:var(--ink); }
.faqitem__a{ font-size:15px; color:var(--ink-soft); line-height:1.6; }
@media(max-width:760px){ .faqitem{ grid-template-columns:1fr; gap:12px; } }

/* pricing tiers */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.tier{ padding:34px 30px; border-right:1px solid var(--line); display:flex; flex-direction:column; }
.tier:last-child{ border-right:0; }
.tier--feature{ background:var(--navy); color:#fff; border-right:0; }
.tier__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.tier--feature .tier__k{ color:var(--accent-2); }
.tier h3{ margin:14px 0 0; font-family:var(--serif); font-weight:500; font-size:1.6rem; letter-spacing:-0.014em; }
.tier__price{ margin:18px 0 0; font-size:15px; color:var(--muted); min-height:24px; }
.tier--feature .tier__price{ color:rgba(255,255,255,0.66); }
.tier__line{ height:1px; background:var(--line); margin:22px 0; }
.tier--feature .tier__line{ background:var(--line-on-navy); }
.tier__list{ display:flex; flex-direction:column; gap:12px; flex:1; }
.tier__list div{ display:flex; gap:10px; font-size:14px; color:var(--ink-soft); align-items:flex-start; line-height:1.4; }
.tier--feature .tier__list div{ color:rgba(255,255,255,0.82); }
.tier__list svg{ width:15px; height:15px; color:var(--accent); flex:none; margin-top:3px; }
.tier--feature .tier__list svg{ color:var(--accent-2); }
.tier .btn{ margin-top:26px; justify-content:center; }
@media(max-width:860px){ .tiers{ grid-template-columns:1fr; } .tier{ border-right:0; border-bottom:1px solid var(--line); } .tier:last-child{ border-bottom:0; } }

/* section number rule under big headings (decorative divider) */
.rule-label{ display:flex; align-items:center; gap:16px; margin-bottom:30px; }
.rule-label__t{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); white-space:nowrap; }
.rule-label__line{ height:1px; background:var(--line); flex:1; }

/* ============================================================
   RESEARCH INDEX + ARTICLE (prose)
   ============================================================ */

/* research index hero */
.rindex-hero{ padding:72px 0 40px; border-bottom:1px solid var(--line); }
.rindex-hero h1{ font-size:clamp(2.4rem,4.6vw,3.6rem); letter-spacing:-0.02em; line-height:1.02; margin:18px 0 0; max-width:16ch; }
.rindex-hero .lead{ margin:22px 0 0; max-width:60ch; }

/* featured article row */
.feat{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:54px; align-items:center; padding:56px 0; border-bottom:1px solid var(--line); }
.feat__media{ border:1px solid var(--line-strong); border-radius:9px; overflow:hidden; box-shadow:var(--shadow-lg); }
.feat__meta{ display:flex; gap:12px; align-items:center; font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); }
.feat__meta b{ color:var(--accent); font-weight:600; }
.feat h2{ margin:18px 0 0; font-size:clamp(1.8rem,2.8vw,2.5rem); letter-spacing:-0.016em; line-height:1.06; }
.feat p{ margin:16px 0 0; font-size:16px; color:var(--ink-soft); line-height:1.6; max-width:50ch; }
.feat .link-arrow{ margin-top:22px; }
@media(max-width:860px){ .feat{ grid-template-columns:1fr; gap:28px; } .feat__media{ order:-1; } }

/* article list (index) */
.alist{ border-top:1.5px solid var(--ink); margin-top:8px; }
.arow{ display:grid; grid-template-columns:64px 1fr 150px; gap:28px; align-items:baseline; padding:30px 4px; border-bottom:1px solid var(--line); transition:background .16s ease; color:inherit; }
.arow:hover{ background:var(--bg-tint); }
.arow__n{ font-family:'Geist Mono',monospace; font-size:13px; color:var(--accent); font-weight:600; }
.arow__main h3{ font-family:var(--serif); font-weight:500; font-size:1.5rem; letter-spacing:-0.012em; line-height:1.12; color:var(--ink); }
.arow__main p{ margin:10px 0 0; font-size:14.5px; color:var(--muted); line-height:1.55; max-width:62ch; }
.arow__tags{ margin:14px 0 0; display:flex; gap:8px; flex-wrap:wrap; }
.arow__meta{ text-align:right; font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); line-height:1.7; }
.arow__meta b{ display:block; color:var(--ink-soft); font-weight:600; }
@media(max-width:760px){ .arow{ grid-template-columns:1fr; gap:14px; } .arow__meta{ text-align:left; } }

/* ----- article page ----- */
.art-hero{ padding:64px 0 0; }
.art-hero__wrap{ max-width:760px; margin:0 auto; }
.art-hero .crumbs{ margin-bottom:26px; }
.art-cat{ display:flex; gap:12px; align-items:center; font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.art-cat b{ color:var(--accent); font-weight:600; }
.art-hero h1{ margin:20px 0 0; font-size:clamp(2.3rem,4.2vw,3.3rem); letter-spacing:-0.018em; line-height:1.04; text-wrap:balance; }
.art-standfirst{ margin:24px 0 0; font-size:clamp(1.15rem,1.7vw,1.4rem); line-height:1.5; color:var(--ink-soft); font-weight:400; letter-spacing:-0.012em; }
.art-byline{ margin:30px 0 0; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.art-byline__av{ width:38px; height:38px; border-radius:50%; background:linear-gradient(150deg,#26272C,#16171A); color:#fff; display:grid; place-items:center; font-family:var(--serif); font-size:16px; font-weight:500; flex:none; }
.art-byline__who{ font-size:14.5px; font-weight:550; color:var(--ink); }
.art-byline__role{ font-family:'Geist Mono',monospace; font-size:11.5px; color:var(--muted); }
.art-byline__dot{ width:3px; height:3px; border-radius:50%; background:var(--line-strong); }
.art-byline__meta{ font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted); }

/* prose body — generous reading measure */
.prose{ max-width:680px; margin:0 auto; padding:8px 0 0; font-size:18.5px; line-height:1.72; color:var(--ink-soft); }
.prose > p{ margin:24px 0 0; letter-spacing:-0.003em; }
.prose > p:first-child{ margin-top:0; }
.prose h2{ margin:52px 0 0; font-size:1.62rem; letter-spacing:-0.014em; line-height:1.14; color:var(--ink); }
.prose h3{ margin:38px 0 0; font-family:var(--serif); font-weight:600; font-size:1.28rem; letter-spacing:-0.008em; color:var(--ink); }
.prose h2 + p, .prose h3 + p{ margin-top:14px; }
.prose strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; text-decoration-color:var(--accent-line); transition:text-decoration-color .15s ease; }
.prose a:hover{ text-decoration-color:var(--accent); }
.prose ul, .prose ol{ margin:20px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:12px; }
.prose li{ position:relative; padding-left:26px; }
.prose ul li::before{ content:""; position:absolute; left:4px; top:.7em; width:7px; height:1.5px; background:var(--accent); }
.prose ol{ counter-reset:li; }
.prose ol li{ counter-increment:li; }
.prose ol li::before{ content:counter(li); position:absolute; left:0; top:.02em; font-family:'Geist Mono',monospace; font-size:13px; font-weight:600; color:var(--accent); }
.prose blockquote{ margin:34px 0 0; padding:6px 0 6px 24px; border-left:2px solid var(--accent); font-family:var(--serif); font-style:italic; font-size:1.34rem; line-height:1.4; color:var(--ink); letter-spacing:-0.01em; }
.prose blockquote p{ margin:0; }
.prose figure{ margin:38px 0 0; }
.prose figcaption{ margin-top:10px; font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted-2); text-align:center; }
.prose hr{ border:0; height:1px; background:var(--line); margin:48px 0; }
.prose code{ font-family:'Geist Mono',monospace; font-size:.86em; background:var(--bg-alt); padding:2px 6px; border-radius:5px; color:var(--accent-ink); }
.prose .callout{ margin:36px 0 0; padding:22px 24px; border:1px solid var(--line); border-left:3px solid var(--accent); border-radius:8px; background:var(--bg-tint); font-size:16px; line-height:1.6; color:var(--ink-soft); }
.prose .callout b{ color:var(--ink); }
.prose .lede-key{ margin:36px 0 0; padding:0; border:0; }
.prose .panel{ margin:34px 0 0; }
.prose .panel + figcaption{ margin-top:10px; }
.prose__tldr{ max-width:680px; margin:36px auto 0; padding:24px 26px; border:1px solid var(--line-strong); border-radius:9px; background:var(--bg-alt); }
.prose__tldr h2{ margin:0; font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); font-weight:600; }
.prose__tldr ul{ margin:14px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px; counter-reset:tldr; }
.prose__tldr li{ position:relative; padding-left:26px; font-size:15.5px; line-height:1.5; color:var(--ink-soft); counter-increment:tldr; }
.prose__tldr li::before{ content:counter(tldr); position:absolute; left:0; top:.02em; font-family:'Geist Mono',monospace; font-size:13px; font-weight:600; color:var(--accent); }

/* article footer cta + related */
.art-cta{ max-width:680px; margin:56px auto 0; padding:34px 32px; border:1px solid var(--line-strong); border-radius:11px; background:var(--navy); color:#fff; text-align:center; }
.art-cta h3{ font-family:var(--serif); font-weight:500; font-size:1.5rem; letter-spacing:-0.012em; color:#fff; }
.art-cta p{ margin:12px auto 0; max-width:46ch; color:rgba(255,255,255,0.72); font-size:15px; line-height:1.55; }
.art-cta__btns{ margin:24px 0 0; display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.related{ border-top:1px solid var(--line); margin-top:64px; padding-top:40px; }
.related__h{ font-family:'Geist Mono',monospace; font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); margin-bottom:24px; }
@media(max-width:760px){ .prose{ font-size:17.5px; } }

/* ============================================================
   DEMO / CONTACT PAGE
   ============================================================ */
.demo-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
@media(max-width:920px){ .demo-grid{ grid-template-columns:1fr; gap:44px; } }

.demo-points{ margin:34px 0 0; display:flex; flex-direction:column; }
.demo-point{ display:grid; grid-template-columns:30px 1fr; gap:16px; padding:22px 0; border-top:1px solid var(--line); }
.demo-point:first-child{ border-top:0; padding-top:0; }
.demo-point__n{ font-family:'Geist Mono',monospace; font-size:12px; font-weight:600; letter-spacing:.06em; color:var(--accent); padding-top:3px; }
.demo-point h3{ font-size:16.5px; font-weight:600; }
.demo-point p{ margin:7px 0 0; font-size:14.5px; color:var(--muted); line-height:1.55; }

.demo-aside{ margin-top:36px; padding-top:26px; border-top:1px solid var(--line); }
.demo-aside__label{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); }
.demo-aside p{ margin:12px 0 0; font-size:14.5px; color:var(--ink-soft); line-height:1.6; }
.demo-aside a{ color:var(--accent); font-weight:500; }

/* form card */
.formcard{ border:1px solid var(--line-strong); border-radius:12px; background:#fff; box-shadow:var(--shadow-lg); padding:34px; position:relative; }
.formcard__h{ font-family:var(--serif); font-weight:500; font-size:1.5rem; letter-spacing:-0.012em; color:var(--ink); }
.formcard__sub{ margin:8px 0 0; font-size:14.5px; color:var(--muted); line-height:1.5; }
.form{ margin-top:26px; display:flex; flex-direction:column; gap:18px; }
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:520px){ .frow{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:7px; min-width:0; }
.field > label{ font-size:12.5px; font-weight:550; color:var(--ink-soft); letter-spacing:-0.003em; }
.field .req{ color:var(--accent); }
.input{
  width:100%; font-family:'Geist',sans-serif; font-size:15px; color:var(--ink);
  background:#fff; border:1px solid var(--line-strong); border-radius:8px; padding:12px 13px;
  transition:border-color .15s ease, box-shadow .15s ease; -webkit-appearance:none; appearance:none;
}
.input::placeholder{ color:var(--muted-2); }
.input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }
textarea.input{ resize:vertical; min-height:92px; line-height:1.5; }
select.input{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236A7287' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center; padding-right:36px; cursor:pointer;
}
.field__hint{ font-size:12px; color:var(--muted-2); }

/* chip multiselect */
.chipset{ display:flex; flex-wrap:wrap; gap:8px; }
.chipopt input{ position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
.chipopt span{ display:inline-flex; align-items:center; gap:7px; font-family:'Geist Mono',monospace; font-size:12.5px; color:var(--ink-soft); border:1px solid var(--line-strong); border-radius:7px; padding:8px 12px; cursor:pointer; transition:border-color .15s ease, background .15s ease, color .15s ease; user-select:none; }
.chipopt span::before{ content:""; width:6px; height:6px; border-radius:2px; background:var(--line-strong); transition:background .15s ease; }
.chipopt input:checked + span{ border-color:var(--accent); background:var(--accent-soft); color:var(--accent-ink); }
.chipopt input:checked + span::before{ background:var(--accent); }
.chipopt input:focus-visible + span{ box-shadow:0 0 0 3px var(--accent-soft); }

.form__note{ margin-top:14px; font-size:12.5px; color:var(--muted); line-height:1.5; text-align:center; }
.form__note a{ color:var(--accent); }
.form .btn{ width:100%; justify-content:center; }

/* success state */
.form-done{ display:none; text-align:center; padding:14px 4px 6px; }
.formcard.is-done .form{ display:none; }
.formcard.is-done .form-done{ display:block; }
.form-done__ico{ width:54px; height:54px; margin:0 auto; border-radius:50%; background:var(--ok-soft); color:var(--ok); display:grid; place-items:center; }
.form-done__ico svg{ width:27px; height:27px; }
.form-done h3{ margin:20px 0 0; font-family:var(--serif); font-weight:500; font-size:1.45rem; color:var(--ink); }
.form-done p{ margin:11px auto 0; max-width:40ch; font-size:14.5px; color:var(--muted); line-height:1.6; }
.form-done__meta{ margin-top:22px; padding-top:18px; border-top:1px solid var(--line); font-family:'Geist Mono',monospace; font-size:12px; color:var(--muted-2); }

/* inquiry segmented field (prominent, first in the form) */
.field--inquiry .chipset{ gap:9px; }
.field--inquiry .chipopt span{ font-family:'Geist',sans-serif; font-size:13.5px; padding:9px 14px; letter-spacing:-0.005em; }
.field--inquiry .chipopt span::before{ border-radius:50%; }

/* ============================================================
   LEAD CAPTURE PAGE
   ============================================================ */
.lead-cap{ }
.lead-wrap{ max-width:700px; margin:0 auto; text-align:center; }
.lead-wrap .kicker{ display:inline-flex; }
.lead-wrap h1{ font-size:clamp(2.4rem,4.8vw,3.6rem); letter-spacing:-0.02em; line-height:1.03; margin:18px 0 0; }
.lead-wrap .lead{ margin:20px auto 0; max-width:52ch; }
.lead-form{ display:flex; gap:10px; max-width:520px; margin:34px auto 0; text-align:left; }
.lead-form .input{ flex:1; }
.lead-form .btn{ white-space:nowrap; }
@media(max-width:520px){ .lead-form{ flex-direction:column; } }
.lead-note{ margin:14px auto 0; font-size:12.5px; color:var(--muted-2); max-width:46ch; }
.lead-note a{ color:var(--accent); }

.lead-done{ display:none; }
.lead-cap.is-done .lead-form, .lead-cap.is-done .lead-note{ display:none; }
.lead-cap.is-done .lead-done{ display:flex; align-items:center; justify-content:center; gap:11px; max-width:520px; margin:34px auto 0; padding:15px 20px; border:1px solid var(--ok); background:var(--ok-soft); border-radius:10px; color:var(--ok); font-size:14.5px; font-weight:500; }
.lead-done svg{ width:19px; height:19px; flex:none; }

/* generic success toggle — works for hero (.lead-wrap) and navy CTA (.finalcta) forms */
.is-done > [data-demo-form],
.is-done > .lead-note{ display:none !important; }
.is-done > .lead-done{ display:flex; align-items:center; justify-content:center; gap:11px; max-width:520px; margin:30px auto 0; padding:15px 20px; border:1px solid var(--ok); background:var(--ok-soft); border-radius:10px; color:var(--ok); font-size:14.5px; font-weight:500; }
.section--navy .is-done > .lead-done{ background:rgba(21,122,82,.16); border-color:rgba(21,122,82,.5); color:#7fd4ad; }

.lead-benefits{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; max-width:860px; margin:60px auto 0; text-align:left; }
@media(max-width:680px){ .lead-benefits{ grid-template-columns:1fr; gap:20px; } }
.lead-benefit{ padding-top:18px; border-top:1.5px solid var(--ink); position:relative; }
.lead-benefit::after{ content:""; position:absolute; left:0; top:-1.5px; width:34px; height:1.5px; background:var(--accent); }
.lead-benefit__n{ font-family:'Geist Mono',monospace; font-size:12px; font-weight:600; letter-spacing:.06em; color:var(--accent); }
.lead-benefit h3{ margin:12px 0 0; font-size:16px; font-weight:600; }
.lead-benefit p{ margin:8px 0 0; font-size:14px; color:var(--muted); line-height:1.55; }

/* centered proof on lead page */
.leadproof{ max-width:820px; margin:0 auto; text-align:center; }
.leadproof .proofband__vlabel{ margin:0 0 16px; }
.vendwall--center{ display:flex; flex-wrap:wrap; justify-content:center; border-left:1px solid var(--line); }
.vendwall--center .vendcell{ flex:1 1 0; min-width:96px; }
.leadproof__cap{ margin:18px auto 0; font-family:'Geist Mono',monospace; font-size:12px; letter-spacing:.01em; color:var(--muted-2); max-width:52ch; line-height:1.6; }

/* ============================================================
   SIGNAL — observatory product
   ============================================================ */
/* grade badge A–F */
.grade{ display:inline-grid; place-items:center; width:30px; height:30px; border-radius:7px; font-family:'Geist Mono',monospace; font-weight:600; font-size:14px; flex:none; border:1px solid transparent; }
.grade--a{ background:var(--ok-soft); color:var(--ok); border-color:rgba(21,122,82,.28); }
.grade--b{ background:var(--ok-soft); color:var(--ok); border-color:rgba(21,122,82,.20); }
.grade--c{ background:var(--warn-soft); color:var(--warn); border-color:rgba(168,104,16,.28); }
.grade--d{ background:var(--warn-soft); color:var(--warn); border-color:rgba(168,104,16,.4); }
.grade--f{ background:var(--danger-soft); color:var(--danger); border-color:rgba(180,35,24,.28); }
.grade--lg{ width:42px; height:42px; font-size:19px; border-radius:9px; }

/* directory rows in the hero panel */
.skrow{ display:grid; grid-template-columns:auto 1fr auto; gap:13px; align-items:center; padding:11px 14px; border-radius:7px; }
.skrow + .skrow{ border-top:1px solid var(--line-soft); }
.skrow__path{ font-family:'Geist Mono',monospace; font-size:12.5px; color:var(--ink-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.skrow__meta{ font-family:'Geist Mono',monospace; font-size:11px; color:var(--muted-2); white-space:nowrap; }

/* benchmark scorecards (3-up, Aguara featured dark) */
.bench{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.benchcol{ padding:30px 28px; border-right:1px solid var(--line); display:flex; flex-direction:column; }
.benchcol:last-child{ border-right:0; }
.benchcol--feature{ background:var(--navy); color:#fff; border-right:0; }
.benchcol__n{ font-family:'Geist',sans-serif; font-size:17px; font-weight:600; letter-spacing:-0.015em; color:var(--ink); }
.benchcol--feature .benchcol__n{ color:#fff; }
.benchcol__big{ margin:18px 0 0; font-size:clamp(2.1rem,3.4vw,2.8rem); font-weight:600; letter-spacing:-0.035em; line-height:.95; color:var(--ink); }
.benchcol--feature .benchcol__big{ color:#fff; }
.benchcol__big b{ color:var(--ok); font-weight:600; }
.benchcol--feature .benchcol__big b{ color:#7fd4ad; }
.benchcol__d{ margin:12px 0 0; font-size:13.5px; color:var(--muted); line-height:1.5; flex:1; }
.benchcol--feature .benchcol__d{ color:rgba(255,255,255,0.62); }
.benchcol__tag{ margin-top:18px; }
@media(max-width:780px){ .bench{ grid-template-columns:1fr; } .benchcol{ border-right:0; border-bottom:1px solid var(--line); } .benchcol:last-child{ border-bottom:0; } }

/* coverage matrix — which surfaces each tool actually scans */
.covwrap{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.covmatrix{ width:100%; border-collapse:collapse; }
.covmatrix th, .covmatrix td{ padding:0; }
.covmatrix thead th{ vertical-align:bottom; padding:18px 18px 16px; border-bottom:1.5px solid var(--ink); }
.covmatrix thead .cov-surfaceh{ text-align:left; font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); font-weight:500; }
.cov-toolh{ text-align:center; }
.cov-toolh__n{ font-size:15px; font-weight:600; letter-spacing:-0.012em; color:var(--ink); }
.cov-toolh__s{ margin-top:4px; font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.02em; color:var(--muted); font-weight:400; }
.cov-toolh--feature{ background:var(--ink); }
.cov-toolh--feature .cov-toolh__n{ color:#fff; }
.cov-toolh--feature .cov-toolh__s{ color:rgba(255,255,255,0.6); }
.covmatrix tbody td{ padding:15px 18px; border-bottom:1px solid var(--line-soft); text-align:center; }
.covmatrix tbody tr:last-child td{ border-bottom:0; }
.covmatrix .cov-surface{ text-align:left; font-size:14.5px; font-weight:500; color:var(--ink); }
.covmatrix .cov-surface small{ display:block; font-weight:400; font-size:12.5px; color:var(--muted); margin-top:2px; letter-spacing:0; }
.covmatrix td.cov-feature{ background:var(--bg-tint); }
.covmatrix tbody tr:hover td:not(.cov-feature){ background:var(--bg-tint); }
.cov-yes{ display:inline-grid; place-items:center; width:24px; height:24px; border-radius:50%; background:var(--ink); }
.cov-yes svg{ width:13px; height:13px; color:#fff; stroke-width:2.6; }
.cov-feature .cov-yes{ background:var(--ok); }
.cov-no{ display:inline-block; width:14px; height:1.5px; background:var(--line-strong); vertical-align:middle; }
.cov-part{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.04em; color:var(--warn); }
@media(max-width:680px){
  .covmatrix thead th, .covmatrix tbody td{ padding-left:12px; padding-right:12px; }
  .covmatrix .cov-surface small{ display:none; }
  .cov-toolh__s{ display:none; }
}

/* benchmark: measured headline + per-case findings table */
.benchhead{ margin-top:22px; padding:30px 32px; border:1px solid var(--line-strong); border-radius:var(--radius); background:var(--bg-tint); display:grid; grid-template-columns:auto 1fr; gap:36px; align-items:center; }
.benchhead__fig{ text-align:center; padding-right:36px; border-right:1px solid var(--line); }
.benchhead__n{ font-size:clamp(3rem,5vw,4.2rem); font-weight:600; letter-spacing:-0.04em; line-height:1; color:var(--ink); }
.benchhead__k{ margin-top:8px; font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.benchhead p{ margin:0; font-size:clamp(1rem,1.5vw,1.18rem); line-height:1.5; color:var(--ink-soft); letter-spacing:-0.008em; }
.benchhead p b{ color:var(--ink); font-weight:600; }
@media(max-width:680px){ .benchhead{ grid-template-columns:1fr; gap:20px; } .benchhead__fig{ padding-right:0; border-right:0; padding-bottom:20px; border-bottom:1px solid var(--line); text-align:left; } }
.findtable{ width:100%; border-collapse:collapse; margin-top:20px; font-size:13.5px; }
.findtable th{ text-align:left; font-family:'Geist Mono',monospace; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); font-weight:500; padding:0 16px 11px; border-bottom:1.5px solid var(--ink); }
.findtable td{ padding:14px 16px; border-bottom:1px solid var(--line); vertical-align:top; line-height:1.45; }
.findtable tr:last-child td{ border-bottom:0; }
.findtable .ft-repo{ font-family:'Geist Mono',monospace; font-size:12.5px; color:var(--ink); white-space:nowrap; }
.findtable .ft-risk{ color:var(--ink-soft); }
.findtable .ft-risk code{ font-family:'Geist Mono',monospace; font-size:.88em; color:var(--accent-ink); background:var(--accent-soft); padding:1px 5px; border-radius:4px; white-space:nowrap; }
.findtable .ft-miss{ color:var(--muted); white-space:nowrap; }
.findtable .ft-miss b{ color:var(--danger); font-weight:600; }
.ftwrap{ margin-top:22px; border:1px solid var(--line); border-radius:var(--radius); overflow-x:auto; }
@media(max-width:680px){ .findtable .ft-repo, .findtable .ft-miss{ white-space:normal; } }

/* 4-column pricing variant */
.tiers--4{ grid-template-columns:repeat(4,1fr); }

/* compact proof strip: clean cells, ticks sit on the cell top (no floating).
   Higher specificity so it wins over the base .statgrid defined later in the file. */
.statgrid.statgrid--plain{ border-top:0; }
.statgrid.statgrid--plain .statcell{ padding-top:0; }
.statgrid.statgrid--plain .statcell::after{ display:none; }
@media(max-width:1000px){ .tiers--4{ grid-template-columns:1fr 1fr; } .tiers--4 .tier{ border-right:1px solid var(--line); border-bottom:1px solid var(--line); } .tiers--4 .tier:nth-child(2n){ border-right:0; } }
@media(max-width:560px){ .tiers--4{ grid-template-columns:1fr; } .tiers--4 .tier{ border-right:0; } }

/* checklist contents */
.checkin{ display:grid; grid-template-columns:repeat(2,1fr); gap:0 56px; border-top:1.5px solid var(--ink); }
.checkrow{ display:grid; grid-template-columns:30px 1fr; gap:14px; padding:20px 0; border-bottom:1px solid var(--line); align-items:start; }
.checkrow__n{ font-family:'Geist Mono',monospace; font-size:12px; font-weight:600; color:var(--ink-soft); padding-top:2px; }
.checkrow h4{ font-size:15.5px; font-weight:600; letter-spacing:-0.01em; }
.checkrow p{ margin:5px 0 0; font-size:13.5px; color:var(--muted); line-height:1.5; }
@media(max-width:720px){ .checkin{ grid-template-columns:1fr; gap:0; } }

/* who it's for */
.whofor{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:760px){ .whofor{ grid-template-columns:1fr; } }
.whocard{ padding:22px 24px; border:1px solid var(--line); border-radius:var(--radius); background:#fff; }
.whocard__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); }
.whocard h4{ margin:10px 0 0; font-size:16px; font-weight:600; }
.whocard p{ margin:7px 0 0; font-size:13.5px; color:var(--muted); line-height:1.5; }

/* ============================================================
   ARTICLE — wide two-column layout (reading column + sticky TOC rail)
   ============================================================ */
.art-head{ max-width:860px; margin:0; }              /* left-aligned, lines up with reading column */
.art-grid{ display:grid; grid-template-columns:minmax(0,720px) 236px; justify-content:space-between; gap:56px; align-items:start; }
.art-main{ min-width:0; }
.art-grid .prose,
.art-grid .prose__tldr{ max-width:none; margin-left:0; margin-right:0; }
.art-grid .prose{ margin-top:8px; }
.art-grid .prose__tldr{ margin-top:0; }

.art-rail{ position:sticky; top:88px; }
.toc__label{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); padding-bottom:14px; border-bottom:1px solid var(--line); }
.toc ul{ list-style:none; margin:14px 0 0; padding:0; display:flex; flex-direction:column; }
.toc a{ display:block; padding:7px 0 7px 15px; border-left:2px solid var(--line); font-size:13.5px; line-height:1.38; color:var(--muted); transition:color .15s ease, border-color .15s ease; text-wrap:pretty; }
.toc a:hover{ color:var(--ink); }
.toc a.active{ color:var(--accent); border-left-color:var(--accent); font-weight:500; }
.toc__share{ margin-top:22px; padding-top:18px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:9px; align-items:flex-start; }
.toc__btn{ font-family:'Geist Mono',monospace; font-size:12px; letter-spacing:.02em; color:var(--ink-soft); background:none; border:0; padding:3px 0; cursor:pointer; text-align:left; white-space:nowrap; transition:color .15s ease; }
.toc__btn:hover{ color:var(--accent); }

/* cta + related align under the reading column, not page-centered */
.art-cta{ max-width:720px; margin-left:0; margin-right:0; }
.art-hero__wrap.related{ max-width:720px; margin-left:0; margin-right:0; }

@media(max-width:980px){
  .art-grid{ grid-template-columns:1fr; gap:0; }
  .art-rail{ display:none; }
  .art-grid .prose, .art-grid .prose__tldr{ max-width:720px; }
  .art-head{ max-width:720px; }
}

/* ============================================================
   AUDIT — track record (stat grid, vuln classes, proof points)
   ============================================================ */
.statgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1.5px solid var(--ink); }
.statcell{ padding:30px 26px 30px; border-right:1px solid var(--line); position:relative; }
.statcell:last-child{ border-right:0; }
.statcell::after{ content:""; position:absolute; left:0; top:-1.5px; width:34px; height:1.5px; background:var(--accent); }
.statgrid .metric__n{ font-size:clamp(2.4rem,4vw,3.3rem); }
.statcell__l{ margin:12px 0 0; font-size:14px; color:var(--muted); line-height:1.4; }
@media(max-width:760px){ .statgrid{ grid-template-columns:1fr 1fr; } .statcell{ border-bottom:1px solid var(--line); } .statcell:nth-child(2n){ border-right:0; } }
@media(max-width:440px){ .statgrid{ grid-template-columns:1fr; } .statcell{ border-right:0; } }

/* proof: formal vendor programs (ledger rows) */
.vend{ border-top:1px solid var(--ink); }
.vendrow{ display:grid; grid-template-columns:200px 1fr auto; gap:24px; align-items:baseline; padding:18px 4px; border-bottom:1px solid var(--line); transition:background .15s ease; }
.vendrow:hover{ background:var(--bg-tint); }
.vendrow__co{ display:flex; align-items:center; gap:9px; font-weight:600; font-size:16px; letter-spacing:-0.01em; color:var(--ink); }
.vendrow__logo{ height:18px; width:auto; flex:none; fill:var(--ink-soft); color:var(--ink-soft); }
.vendrow__logo--img{ height:17px; opacity:.7; }
.vendrow__d{ font-size:14.5px; color:var(--muted); line-height:1.5; }
.vendrow__tag{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); white-space:nowrap; }
.vendrow__pr{ font-weight:600; color:var(--accent); white-space:nowrap; transition:opacity .15s ease; }
.vendrow__pr:hover{ text-decoration:underline; }
@media(max-width:680px){ .vendrow{ grid-template-columns:1fr; gap:6px; } .vendrow__tag{ order:-1; } }

/* deep-audit case cards */
.cases{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:880px){ .cases{ grid-template-columns:1fr; } }
.case{ border:1px solid var(--line); border-radius:var(--radius); padding:26px; background:#fff; display:flex; flex-direction:column; }
.case__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.case h3{ margin:12px 0 0; font-family:var(--serif); font-weight:500; font-size:1.3rem; letter-spacing:-0.012em; line-height:1.14; }
.case p{ margin:11px 0 0; font-size:14px; color:var(--muted); line-height:1.55; flex:1; }
.case__tags{ margin:18px 0 0; display:flex; gap:7px; flex-wrap:wrap; }

/* executable-evidence differentiator panel */
.evid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
@media(max-width:880px){ .evid{ grid-template-columns:1fr; gap:34px; } }

/* resource / lead-magnet callout band */
.rescta{ display:flex; align-items:center; justify-content:space-between; gap:32px; padding:34px 34px; border:1px solid var(--line-strong); border-radius:var(--radius); background:var(--bg-tint); }
.rescta__k{ font-family:'Geist Mono',monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); }
.rescta h3{ margin:10px 0 0; font-family:var(--serif); font-weight:500; font-size:clamp(1.4rem,2.2vw,1.85rem); letter-spacing:-0.014em; line-height:1.1; }
.rescta p{ margin:9px 0 0; font-size:15px; color:var(--muted); line-height:1.5; max-width:54ch; }
.rescta__cta{ flex:none; }
@media(max-width:720px){ .rescta{ flex-direction:column; align-items:flex-start; gap:22px; } }


