/* ══════════════════════════════════════════════════════════════
   InkBytes — marketing site (inkbytes.news) design layer
   Built ON the InkBytes Design System tokens. Register: blend —
   DS foundations (type, spacing, components, factuality semantics)
   with the marketing brand's coral accent + navy editorial bands.
   ══════════════════════════════════════════════════════════════ */

:root{
  /* Re-point the runtime accent to the marketing coral. DS components
     (Button, Kicker, Tag, Chip, focus rings) read var(--accent). */
  --accent:        #e05c5c;
  --accent-press:  #c94a4a;
  --accent-soft:   #f0e0dc;

  /* Editorial midnight used for bands / masthead / footer
     (between the DS masthead #0f1326 and the marketing navy #1a1a2e) */
  --navy:          #11142a;
  --navy-2:        #1a1e3a;   /* cards on navy            */
  --navy-line:     #2b3052;   /* hairlines on navy        */
  --navy-ink:      #eceef6;   /* text on navy             */
  --navy-muted:    #a3a7c4;   /* muted text on navy       */
  --navy-faint:    #797ea4;   /* faint meta on navy       */

  /* marketing layout */
  --maxw-site:     1120px;
  --maxw-read:     720px;
  --header-h:      64px;

  --selection:     color-mix(in oklab, var(--accent) 22%, transparent);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
::selection{background:var(--selection)}

body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  font-size:16px;
}

a{color:inherit;text-decoration:none}
img,svg{display:block}

.wrap{max-width:var(--maxw-site);margin:0 auto;padding:0 28px}
.serif{font-family:var(--font-serif)}
.mono{font-family:var(--font-mono)}
.accent{color:var(--accent)}

/* ── Typographic roles ─────────────────────────────────────── */
.kicker{
  font-family:var(--font-mono);
  font-size:12px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:9px;
}
.kicker--muted{color:var(--muted)}
.dateline{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);
}

h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;letter-spacing:-.012em;color:var(--ink)}

/* Big editorial display */
.display{
  font-family:var(--font-serif);font-weight:500;
  font-size:clamp(40px,6.2vw,72px);line-height:1.02;letter-spacing:-.02em;
}
.h-sec{
  font-family:var(--font-serif);font-weight:500;
  font-size:clamp(30px,4.3vw,46px);line-height:1.08;letter-spacing:-.015em;
}
.lead{
  font-size:clamp(17px,2.1vw,20px);line-height:1.55;color:var(--ink-2);
  max-width:60ch;text-wrap:pretty;
}
.eyebrow-pill{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:11.5px;font-weight:600;
  letter-spacing:.09em;text-transform:uppercase;color:var(--ink-2);
  background:var(--surface);border:1px solid var(--line);
  padding:7px 16px;border-radius:999px;white-space:nowrap;
}
@media(max-width:520px){.eyebrow-pill{white-space:normal;text-align:center}}

/* live pulse */
.pulse{width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 var(--accent);animation:ibpulse 2.1s infinite}
@keyframes ibpulse{
  0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--accent) 55%,transparent)}
  70%{box-shadow:0 0 0 9px transparent}
  100%{box-shadow:0 0 0 0 transparent}
}
@media (prefers-reduced-motion: reduce){.pulse{animation:none}}

/* ── Sections / bands ──────────────────────────────────────── */
.section{padding:84px 0}
.section--tight{padding:60px 0}
.band{background:var(--navy);color:var(--navy-ink)}
.band h1,.band h2,.band h3,.band h4{color:#fff}
.band .lead{color:var(--navy-muted)}
.band .kicker{color:#fff}
.band .kicker .pulse{background:var(--accent)}
.sec-head{max-width:none;margin-bottom:48px}
.sec-head.center{text-align:center;display:flex;flex-direction:column;align-items:center}
.sec-head.center .lead{margin-left:auto;margin-right:auto}
.sec-head .kicker{margin-bottom:16px}
.sec-head .h-sec{max-width:18ch;margin-bottom:16px}
.sec-head.center .h-sec{max-width:22ch}

/* ── Buttons — verbatim from the DS Button component (.ib-btn) ─
   so raw-HTML CTAs render identically to <Button> islands.       */
.ib-btn{
  --_bg:var(--ink);--_fg:#fff;--_bd:var(--ink);
  appearance:none;cursor:pointer;border:1px solid var(--_bd);
  background:var(--_bg);color:var(--_fg);
  font-family:var(--font-sans);font-weight:600;letter-spacing:-.005em;
  border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .08s var(--ease,ease),filter .15s,background .15s,color .15s,border-color .15s;
  white-space:nowrap;text-decoration:none;line-height:1;
}
.ib-btn:hover{filter:brightness(1.06)}
.ib-btn:active{transform:translateY(.5px) scale(.99)}
.ib-btn.sz-sm{font-size:13px;padding:8px 14px}
.ib-btn.sz-md{font-size:14.5px;padding:11px 20px}
.ib-btn.sz-lg{font-size:16px;padding:15px 28px}
.ib-btn.v-primary{--_bg:var(--accent);--_fg:#fff;--_bd:var(--accent)}
.ib-btn.v-primary:hover{filter:none;background:var(--accent-press);border-color:var(--accent-press)}
.ib-btn.v-solid{--_bg:var(--ink);--_fg:#fff;--_bd:var(--ink)}
.ib-btn.v-ghost{--_bg:transparent;--_fg:var(--ink);--_bd:var(--line)}
.ib-btn.v-ghost:hover{filter:none;border-color:var(--ink-3);background:var(--surface)}
.ib-btn.block{width:100%}
/* ghost on navy bands */
.band .ib-btn.v-ghost{--_fg:#fff;--_bd:var(--navy-line)}
.band .ib-btn.v-ghost:hover{background:rgba(255,255,255,.06);border-color:var(--navy-muted)}

/* ── Cards ─────────────────────────────────────────────────── */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:30px;transition:box-shadow .2s var(--ease),transform .2s var(--ease),border-color .2s;
}
.card--hover:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}
.band .card{background:var(--navy-2);border-color:var(--navy-line)}
.band .card p{color:var(--navy-muted)}
.card .ill{width:46px;height:46px;margin-bottom:18px;color:var(--ink)}
.band .card .ill{color:#fff}
.card h3{font-family:var(--font-sans);font-weight:700;font-size:18px;letter-spacing:-.01em;margin-bottom:9px}
.card p{font-size:15px;color:var(--ink-2);text-wrap:pretty}

/* grids */
.grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid .cell{background:var(--surface);padding:30px}
.band .grid{background:var(--navy-line);border-color:var(--navy-line)}
.band .grid .cell{background:var(--navy)}
.cards-row{display:grid;gap:22px}
.cards-row.c3{grid-template-columns:repeat(3,1fr)}
.cards-row.c2{grid-template-columns:repeat(2,1fr)}

@media(max-width:880px){
  .grid--3,.cards-row.c3{grid-template-columns:1fr}
  .grid--2,.cards-row.c2{grid-template-columns:1fr}
}

/* illustration well */
.ill-well{
  display:grid;place-items:center;background:var(--paper-2);
  border:1px solid var(--line);border-radius:14px;color:var(--ink);
}
.band .ill-well{background:var(--navy-2);border-color:var(--navy-line);color:#fff}

/* footer */
.site-footer{background:var(--navy);color:var(--navy-muted);font-size:14px}

/* ── Header / nav ──────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:60;
  background:color-mix(in oklab,var(--paper) 82%,transparent);
  backdrop-filter:saturate(1.1) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.brand-mark{width:24px;height:24px;color:var(--ink)}
.brand-word{font-family:var(--font-sans);font-weight:800;font-size:19px;letter-spacing:-.03em}
.brand-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);align-self:flex-end;margin-bottom:5px;margin-left:-4px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-link{font-family:var(--font-sans);font-size:14.5px;font-weight:500;color:var(--ink-3);transition:color .15s;white-space:nowrap}
.nav-link:hover{color:var(--ink)}
.nav-link.is-active{color:var(--ink);font-weight:600}
.nav-cta{margin-left:6px}
@media(max-width:840px){.nav-link{display:none}.nav-links{gap:0}}

/* ── Footer ────────────────────────────────────────────────── */
.site-footer{padding:64px 0 0}
.band .brand--footer,.site-footer .brand{color:#fff}
.site-footer .brand-mark{color:#fff}
.foot-inner{
  display:grid;grid-template-columns:1.5fr 2.4fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid var(--navy-line);
}
.foot-tag{color:var(--navy-muted);font-size:15px;max-width:34ch;margin:18px 0 14px;text-wrap:pretty}
.foot-lang{font-size:11.5px;letter-spacing:.08em;color:var(--navy-faint)}
.foot-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.foot-col-title{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy-faint);margin-bottom:16px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:11px}
.foot-link{color:var(--navy-muted);font-size:14.5px;transition:color .15s}
.foot-link:hover{color:#fff}
.foot-reader-note{color:var(--navy-muted);font-size:13.5px;margin-bottom:16px;text-wrap:pretty}
.foot-bar{padding:22px 0 30px}
.foot-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;color:var(--navy-faint);font-size:13px}
.foot-values{font-size:11.5px;letter-spacing:.08em}
@media(max-width:840px){
  .foot-inner{grid-template-columns:1fr;gap:34px}
  .foot-cols{grid-template-columns:repeat(2,1fr)}
}

/* utilities */
.center{text-align:center}

/* ── Hero ──────────────────────────────────────────────────── */
.hero{padding:78px 0 56px;text-align:center;position:relative;overflow:hidden}
.hero .eyebrow-pill{margin-bottom:26px}
.hero .display{max-width:15ch;margin:0 auto 22px}
.hero .lead{margin:0 auto 32px}
.cta-row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.micro{margin-top:16px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}
.hero-mock{margin-top:56px}

/* faint paper texture behind hero — DS dot-grid, very subtle */
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:radial-gradient(var(--line) 1px,transparent 1px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 30%,#000 0%,transparent 70%);
          mask-image:radial-gradient(ellipse 70% 60% at 50% 30%,#000 0%,transparent 70%);
  opacity:.55;
}

/* ── Event mock (DS-composed reader card) ──────────────────── */
.evt{
  max-width:720px;margin:0 auto;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 30px 70px -34px rgba(17,20,42,.4);overflow:hidden;
}
.evt-top{display:flex;align-items:center;gap:7px;padding:13px 18px;border-bottom:1px solid var(--line);background:var(--paper-2)}
.evt-dot{width:10px;height:10px;border-radius:50%;background:#d7d5cd;flex:none}
.evt-url{margin-left:8px;font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.evt-syn{margin-left:auto;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-soft);padding:3px 9px;border-radius:999px;flex:none}
.evt-body{padding:26px 28px}
.evt-kick{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}
.evt-date{font-size:11.5px;color:var(--muted)}
.evt-h{font-size:clamp(22px,3.2vw,28px);line-height:1.16;letter-spacing:-.01em;margin-bottom:18px;color:var(--ink)}
.evt-meta{display:flex;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:18px}
.evt-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.evt-p{font-size:16.5px;line-height:1.62;color:var(--ink-2);margin-bottom:20px;text-wrap:pretty}
.cited{border-bottom:1.5px solid color-mix(in oklab,var(--accent) 55%,transparent)}
.cited sup{color:var(--accent);font-weight:700;font-family:var(--font-sans);font-size:.62em;margin-left:1px}
.evt-rail{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px dashed var(--line);flex-wrap:wrap}
.evt-rail-label{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.evt-rail-logos{display:inline-flex;align-items:center}
.evt-rail-logos>span+span{margin-left:-6px}
.evt-rail-cite{font-size:12.5px;color:var(--muted)}
.evt-rail-cite b{color:var(--accent);font-weight:600}

/* ── Factuality spectrum / proof widgets ───────────────────── */
.fact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fact-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:24px}
.fact-card-top{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:16px}
.fact-card p{font-size:14.5px;color:var(--ink-2);text-wrap:pretty}
.twosrc{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
@media(max-width:880px){.fact-grid{grid-template-columns:1fr}}

/* ── Pipeline steps ────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.step{background:var(--surface);padding:26px 22px;position:relative}
.step-n{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--accent);margin-bottom:16px}
.step h3{font-family:var(--font-sans);font-weight:700;font-size:16px;letter-spacing:-.01em;margin-bottom:8px}
.step p{font-size:13.5px;color:var(--ink-2);line-height:1.5;text-wrap:pretty}
.rule-callout{display:flex;align-items:center;gap:14px;justify-content:center;margin-top:26px;font-size:14.5px;color:var(--ink-2)}
.rule-callout b{color:var(--ink)}
.rule-chip{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--accent);background:var(--surface);border:1px solid var(--accent-soft);padding:6px 13px;border-radius:999px;white-space:nowrap}
@media(max-width:920px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* ── Inline UI micro-icons (Lucide-style, 2px round) ───────── */
.uicon{width:22px;height:22px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;flex:none}
.icon-badge{width:46px;height:46px;border-radius:12px;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);flex:none}
.band .icon-badge{background:var(--navy-2);border-color:var(--navy-line);color:#fff}

/* ── Comparison table ──────────────────────────────────────── */
.ctable-wrap{overflow-x:auto;border:1px solid var(--navy-line);border-radius:14px}
.band .ctable-wrap{border-color:var(--navy-line)}
.ctable{width:100%;border-collapse:collapse;font-size:14.5px;min-width:640px}
.ctable th,.ctable td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--navy-line)}
.ctable thead th{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-faint);background:rgba(255,255,255,.02)}
.ctable tbody td{color:var(--navy-muted)}
.ctable tbody td:first-child{color:#fff;font-weight:600;font-family:var(--font-sans)}
.ctable tr:last-child td{border-bottom:none}
.ctable .row-ink td{background:rgba(224,92,92,.08)}
.ctable .row-ink td:first-child{color:#fff}
.ctable .yes{color:#fff;font-weight:600;display:inline-flex;align-items:center;gap:7px}
.ctable .yes::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--fact-high);flex:none}
.ctable .no{color:var(--navy-faint)}
.ctable .partial{color:var(--fact-mixed)}

/* ── Features ──────────────────────────────────────────────── */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 44px}
.feat{display:flex;gap:18px;align-items:flex-start}
.feat .icon-badge{margin-top:2px}
.feat h3{font-family:var(--font-sans);font-weight:700;font-size:17px;letter-spacing:-.01em;margin-bottom:6px}
.feat p{font-size:14.5px;color:var(--ink-2);text-wrap:pretty}
@media(max-width:760px){.features{grid-template-columns:1fr;gap:26px}}

/* ── Pricing ───────────────────────────────────────────────── */
.price-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px;margin:0 auto}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:34px 30px;color:var(--ink)}
.band .plan{background:var(--navy-2);border-color:var(--navy-line);color:#fff}
.plan-pro{border-color:var(--accent);box-shadow:0 24px 60px -30px rgba(224,92,92,.6);position:relative}
.band .plan-pro{border-color:var(--accent)}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:999px;white-space:nowrap}
.plan h3{font-family:var(--font-sans);font-weight:700;font-size:17px;margin-bottom:6px}
.plan-amt{font-family:var(--font-serif);font-size:48px;line-height:1;margin:8px 0 4px;letter-spacing:-.02em}
.plan-amt small{font-family:var(--font-sans);font-size:15px;font-weight:500;color:var(--muted)}
.band .plan-amt small{color:var(--navy-muted)}
.plan ul{list-style:none;margin:22px 0 26px}
.plan li{font-size:14.5px;padding:9px 0 9px 28px;position:relative;color:var(--ink-2);border-top:1px solid var(--line)}
.band .plan li{color:var(--navy-muted);border-color:var(--navy-line)}
.plan li:first-child{border-top:none}
.plan li::before{content:"";position:absolute;left:0;top:15px;width:13px;height:9px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
.plan li.off{color:var(--muted)}
.band .plan li.off{color:var(--navy-faint)}
.plan li.off::before{content:"";left:1px;top:18px;width:11px;height:0;border:none;border-top:2px solid var(--muted);transform:none}
.plan .ib-btn{width:100%;margin-top:4px}
@media(max-width:680px){.price-wrap{grid-template-columns:1fr}}

/* ── Audience pills ────────────────────────────────────────── */
.aud{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;max-width:780px;margin:0 auto}
.aud span{font-size:14.5px;font-weight:500;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:10px 20px;color:var(--ink-2)}

/* ── Page hero (interior pages) ────────────────────────────── */
.page-hero{padding:72px 0 8px;text-align:center}
.page-hero .kicker{margin-bottom:18px;white-space:nowrap}
.page-hero h1{font-family:var(--font-serif);font-weight:500;font-size:clamp(36px,5vw,58px);line-height:1.04;letter-spacing:-.02em;max-width:18ch;margin:0 auto 20px}
.page-hero .lead{margin:0 auto}
.page-hero--accent .kicker .accent{color:var(--accent)}

/* ── Long-form prose ───────────────────────────────────────── */
.prose{font-family:var(--font-serif);font-size:19px;line-height:1.66;color:var(--ink-2)}
.prose p{margin-bottom:22px;text-wrap:pretty}
.prose p strong,.prose strong{color:var(--ink);font-weight:600}
.prose.dropcap>p:first-of-type::first-letter{
  font-family:var(--font-serif);font-weight:500;float:left;font-size:62px;line-height:.82;
  padding:6px 12px 0 0;color:var(--ink);
}
.prose h2{font-family:var(--font-serif);font-size:30px;line-height:1.12;letter-spacing:-.01em;margin:14px 0 14px}
.pullquote{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:clamp(24px,3.4vw,34px);line-height:1.3;letter-spacing:-.01em;
  max-width:24ch;margin:0 auto;text-align:center;color:#fff;text-wrap:balance;
}
.pullquote-cite{display:block;font-family:var(--font-mono);font-style:normal;font-weight:500;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--navy-muted);margin-top:24px}

/* ── Trust list (methodology) ──────────────────────────────── */
.trust-list{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.trust-row{background:var(--surface);display:grid;grid-template-columns:230px 1fr;gap:32px;padding:30px 32px}
.trust-row-label{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.trust-row-label .num{color:var(--muted);margin-right:10px}
.trust-row h3{font-family:var(--font-sans);font-weight:700;font-size:18px;letter-spacing:-.01em;margin-bottom:9px;color:var(--ink)}
.trust-row p{font-size:15px;color:var(--ink-2);line-height:1.6;text-wrap:pretty}
.trust-row p+p{margin-top:10px}
@media(max-width:760px){.trust-row{grid-template-columns:1fr;gap:14px;padding:26px 24px}}

.callout{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;padding:24px 26px}
.callout h3{font-family:var(--font-sans);font-weight:700;font-size:17px;margin-bottom:6px}
.callout p{font-size:14.5px;color:var(--ink-2);text-wrap:pretty}

/* ── Lineage / founder (about) ─────────────────────────────── */
.lineage{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:22px;max-width:760px;margin:0 auto}
.lineage-node{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:24px;text-align:center}
.lineage-node .yr{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.lineage-node .nm{font-family:var(--font-serif);font-size:26px;color:var(--ink)}
.lineage-node.now{border-color:var(--accent)}
.lineage-arrow{font-family:var(--font-sans);color:var(--accent);font-size:24px}
.founder{display:flex;gap:26px;align-items:center;justify-content:center;flex-wrap:wrap;text-align:left}
.founder-portrait{width:96px;height:96px;border-radius:50%;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);flex:none}
.founder-portrait svg{width:48px;height:48px}
.founder-name{font-family:var(--font-serif);font-size:22px;color:var(--ink);margin-bottom:4px}
.founder-role{font-size:14.5px;color:var(--muted)}
@media(max-width:680px){.lineage{grid-template-columns:1fr}.lineage-arrow{transform:rotate(90deg)}}

/* ── Pricing full table (light) ────────────────────────────── */
.ptable{width:100%;border-collapse:collapse;font-size:15px;background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ptable th,.ptable td{padding:15px 22px;text-align:left;border-bottom:1px solid var(--line)}
.ptable thead th{font-family:var(--font-sans);font-weight:700;font-size:15px;color:var(--ink)}
.ptable thead th:first-child{font-family:var(--font-mono);font-weight:600;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.ptable thead .col-pro{color:var(--accent)}
.ptable thead .priceline{display:block;font-family:var(--font-serif);font-size:24px;font-weight:500;margin-top:2px;color:var(--ink)}
.ptable td:first-child{color:var(--ink-2)}
.ptable tbody tr:last-child td{border-bottom:none}
.ptable .ck{color:var(--accent);font-weight:700}
.ptable .dash{color:var(--muted-2)}
.ptable .none{font-size:13.5px;color:var(--fact-high);font-weight:600}
.ptable th:nth-child(2),.ptable td:nth-child(2),.ptable th:nth-child(3),.ptable td:nth-child(3){text-align:center;width:160px}
.ptable .col-pro-bg{background:color-mix(in oklab,var(--accent) 5%,var(--surface))}
.price-table-wrap{overflow-x:auto}
@media(max-width:680px){.ptable{font-size:13.5px;min-width:520px}.ptable th,.ptable td{padding:12px 14px}}

/* ── Contact ───────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.contact-card h3{font-family:var(--font-sans);font-weight:700;font-size:17px;margin:14px 0 7px}
.contact-card p{font-size:14.5px;color:var(--ink-2);text-wrap:pretty;margin-bottom:12px}
.contact-card a.email{font-family:var(--font-mono);font-size:14px;color:var(--accent);border-bottom:1px solid var(--accent-soft)}
.contact-form{max-width:640px;margin:0 auto;display:grid;gap:16px}
.field{display:grid;gap:7px}
.field label{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea,.field select{
  font-family:var(--font-sans);font-size:15px;color:var(--ink);background:var(--surface);
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;width:100%;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ── Illustration marks (solid ink on light wells) ─────────── */
.mark-tile{width:54px;height:54px;display:grid;place-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;flex:none}
.mark-tile img{width:32px;height:32px;opacity:.88}
.band .mark-tile{background:rgba(255,255,255,.06);border-color:var(--navy-line)}
.band .mark-tile img{filter:invert(1);opacity:.92}
.mark-ghost{position:absolute;pointer-events:none;opacity:.07}
.mark-ghost img{width:100%;height:100%}

/* ── The Desk — index ──────────────────────────────────────── */
.theme-bar{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-bottom:44px}
.theme-chip{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);font-family:var(--font-sans);font-size:13.5px;font-weight:500;padding:8px 16px;border-radius:999px;cursor:pointer;transition:.15s}
.theme-chip:hover{border-color:var(--ink-3)}
.theme-chip.is-active{background:var(--ink);border-color:var(--ink);color:#fff}

.desk-feature{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface);margin-bottom:30px}
.desk-feature-art{background:var(--paper-2);position:relative;display:grid;place-items:center;min-height:280px;overflow:hidden}
.desk-feature-art img{width:120px;height:120px;opacity:.16}
.desk-feature-body{padding:38px 40px;display:flex;flex-direction:column;justify-content:center}
.desk-feature-body .post-kick{margin-bottom:16px}
.desk-feature-body h2{font-family:var(--font-serif);font-weight:500;font-size:clamp(26px,3vw,34px);line-height:1.12;letter-spacing:-.015em;margin-bottom:14px;text-wrap:balance}
.desk-feature-body .dek{font-family:var(--font-serif);font-style:italic;font-size:18px;line-height:1.5;color:var(--ink-2);margin-bottom:20px;text-wrap:pretty}
@media(max-width:760px){.desk-feature{grid-template-columns:1fr}.desk-feature-art{min-height:160px}.desk-feature-art img{width:80px;height:80px}}

.desk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:24px;transition:box-shadow .2s var(--ease),transform .2s var(--ease)}
.post-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}
.post-card .mark-tile{margin-bottom:18px}
.post-kick{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.post-kick .sep{color:var(--muted-2);margin:0 7px}
.post-kick .date{color:var(--muted)}
.post-card h3{font-family:var(--font-serif);font-weight:500;font-size:21px;line-height:1.2;letter-spacing:-.01em;margin:12px 0 10px;color:var(--ink)}
.post-card .dek{font-size:14.5px;color:var(--ink-2);line-height:1.55;margin-bottom:16px;text-wrap:pretty}
.post-meta{margin-top:auto;display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--muted);padding-top:14px;border-top:1px solid var(--line)}
.post-meta .by{color:var(--ink-2);font-weight:500}
.post-cited{display:inline-flex;align-items:center;gap:6px;color:var(--fact-high);font-weight:600;font-size:12px}
.post-cited::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--fact-high)}
@media(max-width:900px){.desk-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.desk-grid{grid-template-columns:1fr}}

.typecard{display:flex;gap:18px;align-items:flex-start}
.typecard h3{font-family:var(--font-sans);font-weight:700;font-size:17px;margin-bottom:6px}
.typecard p{font-size:14.5px;color:var(--ink-2);text-wrap:pretty}

/* ── Article (Desk post) ───────────────────────────────────── */
.article{max-width:var(--maxw-read);margin:0 auto;padding:0 28px}
.article-head{text-align:center;padding:64px 0 0}
.article-head .post-kick{margin-bottom:18px}
.article-head h1{font-family:var(--font-serif);font-weight:500;font-size:clamp(32px,4.6vw,50px);line-height:1.08;letter-spacing:-.02em;margin:0 auto 20px;max-width:20ch}
.article-dek{font-family:var(--font-serif);font-style:italic;font-size:clamp(18px,2.2vw,22px);line-height:1.45;color:var(--ink-2);max-width:50ch;margin:0 auto 28px;text-wrap:pretty}
.byline{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;font-size:13.5px;color:var(--muted)}
.byline .by{color:var(--ink);font-weight:600;font-family:var(--font-sans)}
.byline .sep{color:var(--muted-2)}
.article-hero-well{margin:40px 0;height:240px;border-radius:16px;background:var(--paper-2);border:1px solid var(--line);position:relative;display:grid;place-items:center;overflow:hidden}
.article-hero-well img{width:96px;height:96px;opacity:.14}
.article-hero-well figcaption{position:absolute;bottom:14px;left:18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.article .prose{font-size:19px}
.article .prose h2{font-size:25px;margin:34px 0 14px}
.article .prose ul{list-style:none;margin:8px 0 22px;padding:0}
.article .prose li{position:relative;padding:7px 0 7px 24px;font-size:18px;line-height:1.5}
.article .prose li::before{content:"";position:absolute;left:2px;top:16px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.article .prose a.cite{color:var(--accent);border-bottom:1px solid var(--accent-soft);font-style:normal}
.source-label{display:inline-block;font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--ink-2);background:var(--paper-2);border:1px solid var(--line);border-radius:5px;padding:2px 8px;font-style:normal}
.correction-note{margin:36px 0;padding:20px 24px;border:1px solid var(--line);border-left:3px solid var(--fact-high);border-radius:12px;background:var(--surface)}
.correction-note .lbl{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fact-high);display:block;margin-bottom:6px}
.correction-note p{font-family:var(--font-sans);font-size:14px;color:var(--ink-2);font-style:normal}
.signoff{text-align:center;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:44px 0;font-style:normal}
.article-back{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-top:8px}

/* ── Language toggle ───────────────────────────────────────── */
.lang-toggle{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.03em;border:1px solid var(--line);border-radius:999px;padding:6px 11px;transition:.15s;color:var(--muted)}
.lang-toggle:hover{border-color:var(--ink-3)}
.lang-cur{color:var(--ink)}
.lang-sep{color:var(--muted-2)}
.lang-alt{color:var(--muted)}

/* ── Cookie banner (privacy-first) ─────────────────────────── */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:80;max-width:580px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-pop);padding:15px 18px;display:flex;align-items:center;gap:18px}
.cookie-text{font-size:13.5px;color:var(--ink-2);line-height:1.45;text-wrap:pretty}
.cookie-link{color:var(--accent);border-bottom:1px solid var(--accent-soft);white-space:nowrap}
.cookie-banner .ib-btn{flex:none}
@media(max-width:560px){.cookie-banner{flex-direction:column;align-items:stretch;text-align:left}.cookie-banner .ib-btn{width:100%}}

/* ── Legal pages ───────────────────────────────────────────── */
.legal{max-width:var(--maxw-read);margin:0 auto}
.legal .updated{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:28px}
.legal h2{font-family:var(--font-sans);font-weight:700;font-size:20px;letter-spacing:-.01em;margin:38px 0 12px;color:var(--ink)}
.legal h2:first-of-type{margin-top:0}
.legal p{font-size:15.5px;color:var(--ink-2);line-height:1.66;margin-bottom:14px;text-wrap:pretty}
.legal ul{margin:0 0 16px;padding-left:0;list-style:none}
.legal li{position:relative;font-size:15.5px;color:var(--ink-2);line-height:1.6;padding:6px 0 6px 22px}
.legal li::before{content:"";position:absolute;left:2px;top:14px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.legal strong{color:var(--ink);font-weight:600}
.legal-note{margin-top:34px;padding:18px 22px;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;background:var(--paper-2);font-size:14px;color:var(--ink-2)}

/* ── 404 ───────────────────────────────────────────────────── */
.error-wrap{min-height:62vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 0}
.error-num{font-family:var(--font-serif);font-size:clamp(80px,16vw,150px);line-height:.9;letter-spacing:-.03em;color:var(--ink);margin-bottom:8px}
.error-num .accent{color:var(--accent)}
.measure{max-width:var(--maxw-read);margin-left:auto;margin-right:auto}
.divider{height:1px;background:var(--line);border:0;margin:0}
.band .divider{background:var(--navy-line)}
.stack-sm>*+*{margin-top:10px}
.muted{color:var(--muted)}
