/* ============================================================
   KELSUS — Design System  ·  "Regulated Restraint"
   Light, near-monochrome, one disciplined accent.
   Space Grotesk (headings) · Inter (body) · JetBrains Mono (data)
   ============================================================ */

:root{
  /* palette */
  --bg:#ffffff;
  --surface:#f6f7f8;
  --surface-2:#eef1f5;
  --text:#16181a;
  --muted:#5b6166;
  --faint:#8a9197;
  --line:#e3e6e8;
  --line-strong:#d3d8dd;
  --accent:#2342a8;
  --accent-hover:#1b3690;
  --accent-soft:#eaeef8;
  --accent-ink:#142a6e;
  --ok:#1f7a4d;
  --warn:#b3261e;
  --code-bg:#0e1726;
  --code-text:#e6ecf5;

  /* type */
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --display:'Space Grotesk','Inter',-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,Consolas,monospace;

  --maxw:1120px;
  --radius:11px;
  --radius-sm:8px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:16.5px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
hr{border:0;border-top:1px solid var(--line);margin:0}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--display);color:var(--text);margin:0;line-height:1.12;letter-spacing:-.018em;font-weight:600}
h1{font-size:clamp(33px,4.6vw,52px);font-weight:700}
h2{font-size:clamp(25px,3vw,33px)}
h3{font-size:20px}
h4{font-size:16px}
p{margin:0 0 16px}
.lede{font-size:clamp(17px,1.6vw,20px);color:var(--muted);line-height:1.55;max-width:60ch}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.mono{font-family:var(--mono)}
strong{font-weight:600;color:var(--text)}

.eyebrow{
  font-family:var(--mono);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);margin:0 0 14px;font-weight:500;
}
.eyebrow.faint{color:var(--faint)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:24px}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:.02em}
.brand:hover{text-decoration:none}
.brand-logo{height:24px;width:auto;display:block}
.footer-brand .brand-logo{height:20px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a:not(.btn){color:var(--muted);font-size:15px;font-weight:500}
.nav-links a:not(.btn):hover{color:var(--text);text-decoration:none}
.nav-links a.active{color:var(--text)}
.nav-toggle{display:none}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:15px;
  padding:11px 18px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:.13s;white-space:nowrap}
.btn:hover{text-decoration:none}
.btn-sm{padding:8px 14px;font-size:14px}
.btn-lg{padding:13px 22px;font-size:16px}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-dark{background:var(--text);color:#fff;border-color:var(--text)}
.btn-dark:hover{background:#000}

/* ---------- hero ---------- */
.hero{padding:74px 0 56px;border-bottom:1px solid var(--line)}
.hero h1{max-width:17ch}
.hero .lede{margin:20px 0 28px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.hero-note{font-family:var(--mono);font-size:12.5px;color:var(--faint);letter-spacing:.03em;margin-top:26px;padding-top:18px;border-top:1px solid var(--line)}
.hero-note b{color:var(--muted);font-weight:600}

/* ---------- sections ---------- */
section{padding:62px 0}
.section-head{max-width:62ch;margin-bottom:34px}
.section-head h2{margin-bottom:12px}
.section-tight{padding:42px 0}
.bg-surface{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- cards ---------- */
.cards{display:grid;gap:18px}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;transition:.14s;display:flex;flex-direction:column}
a.card:hover{text-decoration:none;border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 8px 26px rgba(20,30,55,.07)}
.card .knum{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.08em;margin-bottom:14px}
.card h3{margin-bottom:9px}
.card p{color:var(--muted);font-size:15px;margin-bottom:16px}
.card .card-foot{margin-top:auto;font-family:var(--mono);font-size:12.5px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:10px}
.card .arrow{color:var(--accent);font-weight:600}
.card.on-surface{background:var(--surface)}

/* ---------- stat blocks ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 20px}
.stat .v{font-family:var(--mono);font-size:30px;font-weight:600;letter-spacing:-.02em;color:var(--text)}
.stat .v span{color:var(--accent)}
.stat .k{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-top:9px}

/* spec strip (SKU) */
.spec{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.spec > div{padding:20px 22px;border-right:1px solid var(--line)}
.spec > div:last-child{border-right:0}
.spec .sk{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);margin-bottom:8px}
.spec .sv{font-family:var(--display);font-size:21px;font-weight:600;color:var(--text)}
.spec .sv small{font-family:var(--mono);font-size:12px;color:var(--muted);font-weight:400;display:block;margin-top:4px;letter-spacing:0}

/* ---------- compliance strip ---------- */
.compliance{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;font-family:var(--mono);font-size:13px;color:var(--muted);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px}
.compliance b{color:var(--text);font-weight:600}
.compliance .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block}

/* ---------- feature rows ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.feature.rev .ftext{order:2}
.kv{list-style:none;padding:0;margin:0}
.kv li{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.kv li:last-child{border-bottom:0}
.kv .mk{font-family:var(--mono);color:var(--accent);font-size:13px;flex:none;margin-top:2px}

/* for / not-for */
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.panel{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--bg)}
.panel.for{border-top:3px solid var(--ok)}
.panel.not{border-top:3px solid var(--line-strong);background:var(--surface)}
.panel h4{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}
.panel.for h4{color:var(--ok)}
.panel.not h4{color:var(--muted)}
.panel ul{margin:0;padding-left:0;list-style:none}
.panel li{position:relative;padding:7px 0 7px 26px;font-size:14.5px;color:var(--muted)}
.panel li:before{position:absolute;left:0;top:7px;font-family:var(--mono);font-size:13px}
.panel.for li:before{content:'+';color:var(--ok)}
.panel.not li:before{content:'\2013';color:var(--faint)}

/* ---------- list of differentiators ---------- */
.diff{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.diff .d{padding:22px;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius);background:var(--bg)}
.diff .d .n{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:10px}
.diff .d h4{font-size:17px;margin-bottom:8px;font-family:var(--display)}
.diff .d p{font-size:14.5px;color:var(--muted);margin:0}

/* ---------- bars chart ---------- */
.chart{background:var(--code-bg);border-radius:var(--radius);padding:24px 26px;color:var(--code-text)}
.chart .clabel{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#7f93b8;margin-bottom:18px}
.bars{display:flex;flex-direction:column;gap:11px}
.barrow{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:12.5px}
.barrow .bn{width:130px;color:#aab8d4;flex:none}
.barrow .bt{flex:1;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.barrow .bf{display:block;height:14px;background:linear-gradient(90deg,#3a64d6,#6f93ec);border-radius:4px}
.barrow .bv{width:78px;text-align:right;color:#e6ecf5;flex:none}
.chart .cnote{font-family:var(--mono);font-size:11px;color:#6c7fa3;margin-top:16px}

/* ---------- code / terminal ---------- */
.term{background:var(--code-bg);border-radius:var(--radius);padding:18px 20px;font-family:var(--mono);font-size:13.5px;color:var(--code-text);line-height:1.7;overflow-x:auto}
.term .cm{color:#6c7fa3}
.term .pr{color:#6f93ec}
.term .ac{color:#79c0ff}

/* ---------- architecture diagram ---------- */
.arch{border:1px solid var(--line-strong);border-radius:var(--radius);padding:20px;background:var(--surface)}
.arch .vpc-label{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.arch .vpc-label .perim{color:var(--accent)}
.flow{display:flex;align-items:stretch;gap:0;flex-wrap:wrap}
.node{flex:1;min-width:120px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 12px;text-align:center;position:relative}
.node .nt{font-family:var(--display);font-weight:600;font-size:13.5px;line-height:1.2}
.node .ns{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:5px;letter-spacing:.02em}
.node.key{border-color:var(--accent);background:var(--accent-soft)}
.node.key .nt{color:var(--accent-ink)}
.flow .conn{display:flex;align-items:center;color:var(--line-strong);font-size:18px;padding:0 4px;flex:none}
.arch .base{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}
.arch .base .b{flex:1;min-width:150px;background:var(--bg);border:1px dashed var(--line-strong);border-radius:var(--radius-sm);padding:11px 13px;font-family:var(--mono);font-size:11.5px;color:var(--muted);text-align:center}
.arch .base .b b{color:var(--text);font-weight:600}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:18px 0;font-family:var(--display);font-weight:600;font-size:17px;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:'+';font-family:var(--mono);color:var(--accent);font-size:20px;flex:none}
.faq details[open] summary:after{content:'\2013'}
.faq .ans{padding:0 0 20px;color:var(--muted);font-size:15px;max-width:72ch}

/* ---------- CTA band ---------- */
.cta-band{background:var(--text);color:#fff;border-radius:16px;padding:46px 44px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-band h2{color:#fff;max-width:20ch}
.cta-band p{color:#b9c0c8;margin:10px 0 0;max-width:46ch}
.cta-band .actions{display:flex;gap:12px;flex-wrap:wrap}
.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.28)}
.cta-band .btn-ghost:hover{border-color:#fff;color:#fff}

/* email capture */
.capture{display:flex;gap:10px;max-width:440px;flex-wrap:wrap}
.capture input{flex:1;min-width:220px;padding:12px 14px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);font-family:var(--sans);font-size:15px;background:#fff}
.capture input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}

/* partner strip */
.partners{display:flex;flex-wrap:wrap;gap:14px 30px;align-items:center}
.partners .pn{font-family:var(--display);font-weight:600;font-size:18px;color:var(--faint);letter-spacing:.01em}

/* homepage credibility logo strip (real logos swap into .logostrip img) */
.logostrip{display:flex;flex-wrap:wrap;gap:18px 0;align-items:center;margin-top:14px}
.logostrip img{height:22px;width:auto;display:block}
.logostrip .logo-ph{display:inline-flex;align-items:center;height:30px;padding:0 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--faint);font-family:var(--display);font-weight:600;font-size:13.5px;letter-spacing:.01em}

/* ---------- team ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.member{border:1px solid var(--line);border-radius:var(--radius);padding:20px;background:var(--bg)}
.member .ph{width:48px;height:48px;border-radius:10px;background:var(--accent-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--mono);color:var(--accent);font-weight:600;margin-bottom:14px}
.member h4{font-family:var(--display);font-size:16px;margin-bottom:3px}
.member .role{font-family:var(--mono);font-size:11.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.member p{font-size:14px;color:var(--muted);margin:0}

/* contact options */
.contact-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.copt{border:1px solid var(--line);border-radius:var(--radius);padding:24px;background:var(--bg);display:flex;flex-direction:column}
.copt .ci{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.06em;margin-bottom:12px}
.copt h3{font-size:18px;margin-bottom:8px}
.copt p{font-size:14.5px;color:var(--muted);margin-bottom:18px}
.copt .copt-foot{margin-top:auto}

/* prose */
.prose{max-width:68ch}
.prose p{margin-bottom:18px;color:#23282d}
.prose h2{margin:36px 0 14px}
.prose h3{margin:26px 0 10px}

/* ---------- footer ---------- */
.footer{background:var(--surface);border-top:1px solid var(--line);padding:52px 0 30px;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.footer-brand .brand{margin-bottom:14px}
.footer-brand p{font-size:14px;color:var(--muted);max-width:34ch;margin-bottom:14px}
.footer-brand .seal{font-family:var(--mono);font-size:11.5px;color:var(--faint);display:flex;align-items:center;gap:8px}
.footer-col h5{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin:0 0 14px;font-weight:500}
.footer-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:10px}
.footer-col a:hover{color:var(--text);text-decoration:none}
.footer-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:40px;padding-top:22px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:11.5px;color:var(--faint)}

/* ---------- utilities ---------- */
.center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.stack-lg > * + *{margin-top:20px}
.tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);
  background:var(--accent-soft);border:1px solid #d3ddf2;padding:4px 9px;border-radius:6px}

/* ---------- article / insights ---------- */
.article-head{padding:60px 0 34px;border-bottom:1px solid var(--line)}
.article-head h1{max-width:20ch;margin-top:8px}
.article-head .lede{margin-top:18px}
.article-meta{display:flex;flex-wrap:wrap;gap:7px 14px;align-items:center;font-family:var(--mono);font-size:12.5px;color:var(--faint);margin-top:24px}
.article-meta .who{color:var(--muted);font-weight:500}
.article-meta .sep{color:var(--line-strong)}
.article-body{padding:46px 0}
.article-body .prose p{font-size:17px;line-height:1.75}
.pull{border-left:3px solid var(--accent);background:var(--surface);border-radius:0 var(--radius) var(--radius) 0;
  padding:22px 26px;margin:30px 0;font-family:var(--display);font-weight:500;font-size:clamp(19px,2.2vw,23px);line-height:1.4;color:var(--text)}
.checklist{list-style:none;padding:0;margin:20px 0}
.checklist li{position:relative;padding:11px 0 11px 28px;border-bottom:1px solid var(--line);font-size:16px;color:var(--muted)}
.checklist li:last-child{border-bottom:0}
.checklist li:before{content:'\2192';position:absolute;left:0;top:11px;color:var(--accent);font-family:var(--mono)}
.post{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.post-feature{display:block;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius);
  padding:28px 30px;background:var(--bg);transition:.14s}
a.post-feature:hover{text-decoration:none;border-color:var(--line-strong);border-left-color:var(--accent);box-shadow:0 8px 26px rgba(20,30,55,.07)}
.post-feature h3{font-size:25px;margin:14px 0 10px;max-width:24ch}
.post-feature p{color:var(--muted);max-width:62ch;margin-bottom:16px;font-size:16px}
.post-soon{opacity:.78}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .cards.c3,.diff,.stats,.team,.contact-opts{grid-template-columns:1fr 1fr}
  .feature,.split,.footer-grid{grid-template-columns:1fr}
  .feature{gap:20px}
  .feature.rev .ftext{order:0}
  .footer-grid{gap:28px}
}
@media(max-width:620px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;background:transparent;border:1px solid var(--line-strong);border-radius:10px;color:var(--text);cursor:pointer}
  .nav-links{position:absolute;top:64px;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:6px 20px 14px;box-shadow:0 10px 28px rgba(20,30,55,.10)}
  .nav.nav-open .nav-links{display:flex}
  .nav-links a:not(.btn){display:block;padding:13px 2px;font-size:16px;border-top:1px solid var(--line)}
  .nav-links a:not(.btn):first-child{border-top:0}
  .nav-links a.btn{margin-top:12px;text-align:center;justify-content:center}
  .cards.c3,.cards.c2,.diff,.stats,.team,.contact-opts,.spec{grid-template-columns:1fr}
  .spec > div{border-right:0;border-bottom:1px solid var(--line)}
  .spec > div:last-child{border-bottom:0}
  .cta-band{padding:32px 26px}
  .flow .conn{transform:rotate(90deg)}
  .node{min-width:100%}
}
