/* ============================================================
   GeneWorks — Reimagined shared stylesheet
   Built from the homepage design tokens for visual consistency.
   ============================================================ */
:root{
  --bg:#fafbfc;
  --paper:#ffffff;
  --ink:#0f1e2e;
  --body:#46586a;
  --muted:#64748b;
  --faint:#94a3b8;
  --line:#e8ecf1;
  --line-strong:#d6dce4;
  --accent:#0891b2;
  --sans:'Outfit',sans-serif;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --text:'Manrope',sans-serif;
  --mono:'JetBrains Mono',monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--text);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.65;}
h1,h2,h3,h4{color:var(--ink);}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
::selection{background:rgba(8,145,178,.16);color:var(--ink);}

.serif{font-family:var(--serif);}
.mono{font-family:var(--mono);}
em{font-style:italic;font-family:var(--serif);color:var(--faint);font-weight:400;}

/* ---------- layout ---------- */
.container{max-width:1180px;margin:0 auto;padding:0 32px;}
.sec{padding:120px 0;position:relative;z-index:2;}
.sec.bg{background:var(--bg);}
.sec.paper{background:var(--paper);}
@media(max-width:760px){.sec{padding:72px 0;}}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:all .4s;}
nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line);}
.nav-in{max-width:1180px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--sans);font-weight:700;font-size:20px;letter-spacing:-.01em;}
.brand .gc{color:var(--accent);}
.nav-links{display:flex;align-items:center;gap:32px;}
.nav-links a{font-size:14px;font-weight:500;color:var(--muted);transition:color .2s;}
.nav-links a:hover,.nav-links a.active{color:var(--ink);}
.nav-cta{display:flex;align-items:center;gap:22px;}
.nav-cta .signin{font-size:14px;font-weight:500;color:var(--muted);transition:color .2s;}
.nav-cta .signin:hover{color:var(--ink);}
.nav-wait{padding:10px 20px;background:var(--ink);color:#fff;border-radius:2px;font-family:var(--sans);font-weight:600;font-size:13.5px;transition:background .25s;}
.nav-wait:hover{background:var(--accent);}
@media(max-width:960px){.nav-links,.nav-cta{display:none;}}

/* ---------- shared section heads ---------- */
.eyebrow{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:26px;}
.eyebrow .ix{color:var(--faint);}
.eyebrow .bar{width:26px;height:1px;background:var(--accent);}
.head{max-width:840px;margin-bottom:56px;}
.head .lede{margin-top:24px;}
.title{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4.4vw,50px);line-height:1.1;letter-spacing:-.015em;}
.title em{display:inline;}
.lede{font-family:var(--text);font-size:clamp(16px,1.5vw,19px);line-height:1.72;color:var(--body);font-weight:400;max-width:700px;}

/* ---------- reveal animation (IntersectionObserver adds .in) ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}}

/* ============================================================
   ABOUT PAGE COMPONENTS
   ============================================================ */
.phero{padding:170px 0 92px;background:var(--paper);border-bottom:1px solid var(--line);}
.phero h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5vw,62px);line-height:1.05;letter-spacing:-.02em;margin:0 0 28px;max-width:940px;}
.phero h1 em{color:var(--faint);}
.phero .lede{max-width:780px;margin-bottom:22px;}
.phero-line{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,24px);color:var(--accent);font-weight:500;margin-bottom:8px;}

.stats{display:flex;flex-wrap:wrap;gap:56px;margin-top:54px;padding-top:42px;border-top:1px solid var(--line);}
.stat .v{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4vw,48px);color:var(--accent);line-height:1;}
.stat .l{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:12px;}

.prose{max-width:760px;}
.prose p{font-size:clamp(16px,1.4vw,18px);line-height:1.78;color:var(--body);margin-bottom:22px;}
.prose p:last-child{margin-bottom:0;}
.prose strong{color:var(--ink);font-weight:600;}
.em-line{font-family:var(--serif);font-style:italic;color:var(--accent);font-weight:500;}

/* objectives */
.olist{display:flex;flex-direction:column;gap:30px;max-width:880px;}
.oitem{display:flex;gap:26px;align-items:flex-start;}
.oitem .on{flex-shrink:0;width:46px;height:46px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:20px;font-weight:500;color:var(--accent);}
.oitem h3{font-family:var(--sans);font-size:18px;font-weight:600;margin-bottom:8px;}
.oitem p{font-size:15px;line-height:1.66;color:var(--body);}

/* outcomes */
.out{display:grid;grid-template-columns:repeat(2,1fr);gap:34px 52px;max-width:1000px;}
.outitem h3{font-family:var(--sans);font-size:17px;font-weight:600;margin-bottom:10px;display:flex;gap:10px;align-items:baseline;line-height:1.3;}
.ar{color:var(--accent);font-family:var(--serif);}
.outitem p{font-size:14.5px;line-height:1.64;color:var(--body);}

/* ideal customers */
.cust{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.custitem{border:1px solid var(--line);border-radius:4px;padding:34px 28px;background:var(--paper);transition:border-color .25s,transform .25s;}
.custitem:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.tag{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;}
.custitem h3{font-family:var(--sans);font-size:19px;font-weight:600;margin-bottom:6px;}
.who{font-family:var(--serif);font-style:italic;color:var(--faint);font-size:14px;margin-bottom:16px;}
.custitem p{font-size:14.5px;line-height:1.64;color:var(--body);margin-bottom:18px;}
.res{font-size:13.5px;color:var(--ink);font-weight:500;display:flex;gap:8px;border-top:1px solid var(--line);padding-top:16px;line-height:1.5;}

/* roadmap timeline */
.tl{display:flex;flex-direction:column;max-width:960px;}
.tlitem{display:grid;grid-template-columns:170px 1fr;gap:36px;padding:34px 0;border-bottom:1px solid var(--line);}
.tlitem:first-child{padding-top:0;}
.tlitem:last-child{border-bottom:none;}
.when{font-family:var(--mono);font-size:12px;color:var(--muted);line-height:2;}
.st{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:2px;}
.st.live{background:rgba(8,145,178,.12);color:var(--accent);}
.st.next{background:var(--line);color:var(--muted);}
.tlitem h3{font-family:var(--sans);font-size:19px;font-weight:600;margin-bottom:10px;}
.tlitem p{font-size:15px;line-height:1.66;color:var(--body);margin-bottom:16px;}
.tlitem.north h3{color:var(--accent);}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:2px;padding:5px 10px;}

/* ---------- footer ---------- */
footer{padding:60px 0;border-top:1px solid var(--line);background:var(--paper);}
.foot-in{display:flex;flex-direction:column;align-items:center;gap:26px;}
.foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:28px;}
.foot-links a{font-size:14px;color:var(--muted);font-weight:500;transition:color .2s;}
.foot-links a:hover{color:var(--ink);}
.foot-copy{color:var(--faint);font-size:13px;}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .out{grid-template-columns:1fr;}
  .cust{grid-template-columns:1fr;}
  .tlitem{grid-template-columns:1fr;gap:14px;}
  .stats{gap:36px;}
}

/* ============================================================
   SHARED: buttons, dark sections, two-col hero, tables
   ============================================================ */
:root{--accent-br:#22d3ee;--ink-deep:#0a1622;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-weight:600;font-size:14.5px;padding:13px 24px;border-radius:2px;cursor:pointer;border:1px solid transparent;transition:all .25s;text-align:center;}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:hover{background:#0e7490;}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--ink);}
.btn-light{background:#fff;color:var(--ink);}
.btn-light:hover{background:var(--accent);color:#fff;}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.3);}
.btn-outline:hover{border-color:#fff;}

.sec.dark{background:var(--ink);color:#cdd8e2;}
.sec.dark .title,.sec.dark h2,.sec.dark h3,.sec.dark h4{color:#fff;}
.sec.dark .lede{color:#9fb2c2;}
.sec.dark .eyebrow{color:var(--accent-br);}
.sec.dark .eyebrow .ix{color:#56708a;}
.sec.dark .eyebrow .bar{background:var(--accent-br);}
.sec.dark .chip{color:#9fb2c2;border-color:rgba(255,255,255,.16);}

.head.center{margin-left:auto;margin-right:auto;text-align:center;}
.head.center .eyebrow{justify-content:center;}
.head.center .lede{margin-left:auto;margin-right:auto;}

.phero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;}
.phero-graphic svg{width:100%;height:auto;}

.rl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;}

.tbl{width:100%;border-collapse:collapse;}
.tbl th{text-align:left;padding:16px 18px 14px 0;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line-strong);}
.tbl th.c,.tbl td.c{text-align:center;}
.tbl td{padding:14px 18px;font-size:14px;color:var(--body);border-bottom:1px solid var(--line);}
.tbl td:first-child{padding-left:0;}
.tbl td.strong{font-family:var(--sans);font-weight:600;color:var(--ink);}
.tbl td.big{font-family:var(--serif);font-weight:500;font-size:20px;color:var(--ink);}
.tbl td.acc{color:var(--accent);font-weight:600;}
.tbl td.dim{color:var(--faint);}

/* ---------- pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.plan{border:1px solid var(--line);border-radius:4px;padding:36px 30px;background:var(--paper);position:relative;display:flex;flex-direction:column;}
.plan.pop{border-color:var(--accent);box-shadow:0 24px 60px -34px rgba(8,145,178,.55);}
.pop-tag{position:absolute;top:-12px;left:30px;background:var(--accent);color:#fff;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:2px;}
.pname{font-family:var(--sans);font-size:22px;font-weight:700;margin-bottom:4px;}
.pfor{font-family:var(--serif);font-style:italic;color:var(--faint);font-size:14px;margin-bottom:16px;}
.pdesc{font-size:14px;line-height:1.6;color:var(--body);margin-bottom:22px;}
.pprice{font-family:var(--serif);font-weight:500;font-size:30px;color:var(--ink);margin-bottom:24px;display:flex;flex-direction:column;gap:4px;}
.pprice small{font-family:var(--text);font-size:12.5px;font-weight:400;color:var(--muted);}
.feat{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px;flex:1;}
.feat li{font-size:14px;color:var(--body);padding-left:24px;position:relative;line-height:1.45;}
.feat li:before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:600;}
.feat li.no{color:var(--faint);}
.feat li.no:before{content:"—";color:var(--faint);}

.faq{display:flex;flex-direction:column;max-width:880px;}
.faqitem{padding:26px 0;border-bottom:1px solid var(--line);}
.faqitem:first-child{border-top:1px solid var(--line);}
.faqitem h3{font-family:var(--sans);font-size:17px;font-weight:600;margin-bottom:10px;}
.faqitem p{font-size:14.5px;line-height:1.66;color:var(--body);}

/* ---------- capabilities ---------- */
.tier{display:grid;grid-template-columns:260px 1fr;gap:44px;padding:38px 0;border-top:1px solid var(--line);}
.tier:last-child{border-bottom:1px solid var(--line);}
.th .lvl{font-family:var(--serif);font-weight:500;font-size:24px;color:var(--ink);margin-bottom:8px;}
.th .pct{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.04em;margin-bottom:14px;}
.th .mode{font-size:14px;color:var(--body);line-height:1.6;}
.tlist{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;margin-bottom:20px;}
.it{font-size:14px;color:var(--body);display:flex;gap:10px;align-items:baseline;line-height:1.5;}
.it .mk{color:var(--accent);font-size:10px;}
.it b{color:var(--ink);font-weight:600;}
.reff{font-size:13.5px;color:var(--muted);font-style:italic;font-family:var(--serif);line-height:1.6;}

.excl{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);}
.exitem{padding:24px 22px 24px 0;border-bottom:1px solid var(--line);}
.exitem h4{font-family:var(--sans);font-size:15px;font-weight:600;margin-bottom:8px;}
.exitem p{font-size:13px;line-height:1.55;color:var(--body);}

.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.col3 .ix{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:600;margin-bottom:14px;display:block;}
.col3 p{font-size:14.5px;line-height:1.66;color:var(--body);}

.mods{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.mod{border:1px solid var(--line);border-radius:4px;padding:30px 28px;background:var(--paper);}
.mod .ml{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.mod h3{font-family:var(--sans);font-size:18px;font-weight:600;margin-bottom:10px;}
.mod p{font-size:14px;line-height:1.62;color:var(--body);margin-bottom:16px;}

.ctaband{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:40px;padding:28px 32px;background:var(--ink);border-radius:4px;}
.ctaband p{color:#cdd8e2;font-family:var(--serif);font-size:17px;font-weight:400;max-width:620px;}

/* ---------- how-it-works ---------- */
.stage{display:grid;grid-template-columns:60px 1fr 280px;gap:32px;padding:38px 0;border-top:1px solid var(--line);align-items:start;}
.stage:last-child{border-bottom:1px solid var(--line);}
.sn{font-family:var(--serif);font-weight:500;font-size:42px;color:var(--line-strong);line-height:1;}
.stage.gate .sn{color:var(--accent);}
.stype{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.stage.gate .stype{color:var(--accent);}
.stage h3{font-family:var(--serif);font-weight:500;font-size:24px;margin-bottom:6px;}
.agent{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:14px;}
.stage p{font-size:14.5px;line-height:1.66;color:var(--body);}
.meta{display:flex;flex-direction:column;gap:14px;border-left:1px solid var(--line);padding-left:24px;}
.meta .k{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:3px;}
.meta .v{display:block;font-size:13px;color:var(--ink);font-weight:500;line-height:1.4;}

.gates{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.gatecol{border:1px solid var(--line);border-radius:4px;padding:34px 30px;background:var(--paper);}
.gl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;}
.gatecol h3{font-family:var(--serif);font-weight:500;font-size:24px;margin-bottom:14px;}
.gatecol p{font-size:14.5px;line-height:1.66;color:var(--body);margin-bottom:18px;}
.gatecol ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.gatecol li{font-size:14px;color:var(--body);padding-left:18px;position:relative;line-height:1.5;}
.gatecol li:before{content:"—";position:absolute;left:0;color:var(--accent);}

.agroup{padding:26px 0;border-top:1px solid var(--line);}
.agroup:last-child{border-bottom:1px solid var(--line);}
.agroup-h{display:flex;align-items:baseline;gap:16px;margin-bottom:16px;}
.gnum{font-family:var(--mono);font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.06em;}
.agroup-h h3{font-family:var(--sans);font-size:17px;font-weight:600;}
.cnt{font-family:var(--serif);font-style:italic;color:var(--faint);font-size:14px;margin-left:auto;}

/* ---------- responsive for new components ---------- */
@media(max-width:880px){
  .phero-grid{grid-template-columns:1fr;}
  .phero-graphic{display:none;}
  .plans{grid-template-columns:1fr;}
  .tier{grid-template-columns:1fr;gap:20px;}
  .tlist{grid-template-columns:1fr;}
  .excl{grid-template-columns:1fr;}
  .cols3{grid-template-columns:1fr;}
  .mods{grid-template-columns:1fr;}
  .gates{grid-template-columns:1fr;}
  .stage{grid-template-columns:1fr;gap:14px;}
  .meta{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:18px;}
  .agroup-h{flex-wrap:wrap;}
  .cnt{margin-left:0;}
}

/* ============================================================
   LEGAL DOCS (privacy / terms / security)
   ============================================================ */
.doc{max-width:840px;}
.toc{display:flex;flex-wrap:wrap;gap:10px 20px;padding:6px 0 30px;border-bottom:1px solid var(--line);margin-bottom:48px;}
.toc a{font-family:var(--mono);font-size:12px;color:var(--muted);transition:color .2s;}
.toc a:hover{color:var(--accent);}
.doc>[id]{margin-bottom:48px;}
.doc>[id]:last-child{margin-bottom:0;}
.updated{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.doc h2{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.6vw,30px);line-height:1.2;letter-spacing:-.01em;margin-bottom:18px;}
.doc p{font-size:15px;line-height:1.78;color:var(--body);margin-bottom:16px;}
.doc p:last-child{margin-bottom:0;}
.doc ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:16px;}
.doc li{font-size:15px;line-height:1.66;color:var(--body);padding-left:22px;position:relative;}
.doc li:before{content:"—";position:absolute;left:0;color:var(--accent);}
.doc strong{color:var(--ink);font-weight:600;}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.csplit{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.vp-stack{display:flex;flex-direction:column;gap:24px;}
.vp h3{font-family:var(--sans);font-size:16px;font-weight:600;margin-bottom:6px;}
.vp p{font-size:14px;line-height:1.6;color:var(--body);}
.vp a{color:var(--accent);}
.formcard{border:1px solid var(--line);border-radius:6px;padding:36px 32px;background:var(--paper);box-shadow:0 24px 60px -40px rgba(15,30,46,.4);}
.formcard h3{font-family:var(--serif);font-weight:500;font-size:24px;margin-bottom:8px;}
.fsub{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:26px;}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field.full{grid-column:1/-1;}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);}
.field input,.field select,.field textarea{font-family:var(--text);font-size:14px;color:var(--ink);padding:11px 13px;border:1px solid var(--line-strong);border-radius:3px;background:var(--paper);transition:border-color .2s;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);}
.field textarea{min-height:112px;resize:vertical;}
.submit{grid-column:1/-1;justify-content:center;}
.formnote{font-size:12px;color:var(--faint);text-align:center;margin-top:2px;}

@media(max-width:880px){
  .csplit{grid-template-columns:1fr;gap:40px;}
  .form{grid-template-columns:1fr;}
}

/* ============================================================
   PRESENTATIONS (doc-layout + slide components)
   ============================================================ */
.docwrap{display:grid;grid-template-columns:248px 1fr;gap:54px;max-width:1180px;margin:0 auto;padding:120px 32px 0;}
.docnav{position:sticky;top:92px;align-self:start;max-height:calc(100vh - 120px);overflow:auto;border-right:1px solid var(--line);padding-right:18px;}
.docnav .grp{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:20px 0 6px;}
.docnav .grp:first-child{margin-top:0;}
.docnav a{display:block;font-size:13px;color:var(--muted);padding:5px 0;line-height:1.35;cursor:pointer;transition:color .2s;}
.docnav a:hover{color:var(--accent);}
.docnav a.active{color:var(--accent);font-weight:600;}
.docmain{min-width:0;padding-bottom:110px;}
.docmain .doc{max-width:none;}
.docmain .grouplabel{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;}
.dsec{display:none;}
.dsec.active{display:block;}

.darkblock{background:var(--ink);border-radius:8px;padding:32px 34px;margin:28px 0;}
.darkblock p{color:#9fb2c2;font-size:14.5px;line-height:1.7;}
.darkblock .grouplabel{color:var(--accent-br);}
.kpirow{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:8px;}
.darkblock .kpirow{margin-top:22px;}
.kpirow .k .kv{font-family:var(--serif);font-weight:500;font-size:30px;color:var(--accent-br);line-height:1;}
.kpirow .k .kl{font-size:12.5px;color:#9fb2c2;line-height:1.5;margin-top:8px;}

.numgrid{display:grid;gap:0;margin-top:8px;}
.numitem .ix{font-family:var(--serif);font-size:30px;color:var(--line-strong);display:block;margin-bottom:12px;}
.numitem h3{font-family:var(--sans);font-size:17px;font-weight:600;margin-bottom:10px;line-height:1.3;}
.numitem p{font-size:14px;line-height:1.62;color:var(--body);}

.cmp{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.cmp .c{border:1px solid var(--line);border-radius:6px;padding:30px 28px;background:var(--paper);}
.cmp .badge{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:rgba(8,145,178,.08);padding:5px 10px;border-radius:2px;margin-bottom:16px;}
.cmp .c h3{font-family:var(--serif);font-weight:500;font-size:26px;margin-bottom:4px;}
.cmp .role{font-family:var(--serif);font-style:italic;color:var(--faint);font-size:14px;margin-bottom:14px;}
.cmp .c p{font-size:14px;line-height:1.62;color:var(--body);margin-bottom:16px;}

.case{padding:36px 0;border-top:1px solid var(--line);}
.lab{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;}
.case h3{font-family:var(--serif);font-weight:500;font-size:26px;margin-bottom:10px;}
.ctx{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:22px;}
.cstats{display:flex;gap:48px;margin-bottom:26px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.cstats .cv{font-family:var(--serif);font-weight:500;font-size:32px;color:var(--accent);line-height:1;}
.cstats .cl{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:8px;}
.case h4{font-family:var(--sans);font-size:13px;font-weight:700;color:var(--ink);margin:18px 0 6px;text-transform:uppercase;letter-spacing:.04em;}
.case p{font-size:14.5px;line-height:1.68;color:var(--body);}

@media(max-width:900px){.docwrap{grid-template-columns:1fr;gap:0;}.docnav{display:none;}}
@media(max-width:880px){.kpirow{grid-template-columns:1fr;gap:18px;}.numgrid{grid-template-columns:1fr!important;}.numitem{border-right:none!important;padding:18px 0!important;}.cmp{grid-template-columns:1fr;}.cstats{flex-wrap:wrap;gap:28px;}}
