:root{
  /* Brand */
  --ink-900:#0E0F12;
  --ink-800:#1A1C21;
  --ink-700:#2A2D33;
  --ink-500:#5A5F69;
  --ink-300:#A6ABB4;
  --ink-200:#D5D7DC;
  --ink-100:#EDEEF1;
  --paper:#FFFFFF;
  --paper-2:#F7F6F3;
  --paper-3:#EFEDE6;
  --rule:rgba(14,15,18,.10);
  --rule-strong:rgba(14,15,18,.20);
  /* Accent */
  --accent:#C96442;
  --accent-600:#B0532F;
  --accent-100:#F8E5DC;
  /* Semantic */
  --ok:#2F8F5C;
  --warn:#B0823A;
  --err:#B83A2E;
  /* Type */
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  /* Spacing 4-pt */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-6:24px; --space-8:32px; --space-12:48px; --space-16:64px; --space-24:96px;
  /* Radii */
  --r-2:2px; --r-3:3px; --r-4:4px; --r-6:6px; --r-8:8px; --r-pill:999px;
  /* Shadows */
  --shadow-1:0 1px 2px rgba(14,15,18,.06);
  --shadow-2:0 2px 8px rgba(14,15,18,.08);
  --shadow-3:0 8px 32px rgba(14,15,18,.10);
}
/* Dark theme tokens — applied either via prefers-color-scheme system pref OR
   via explicit data-theme="dark" on <html> (manual toggle wins, persisted via
   cookie so server-side render matches client-side toggle without flash). */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --paper:#0E0F12;
    --paper-2:#161719;
    --paper-3:#1F2024;
    --ink-900:#F4F1EA;
    --ink-800:#E0DED8;
    --ink-700:#C4C2BC;
    --ink-500:#9B9C9F;
    --ink-300:#6A6C70;
    --ink-200:#3A3C40;
    --ink-100:#26282C;
    --rule:rgba(244,241,234,.10);
    --rule-strong:rgba(244,241,234,.20);
    --accent-100:rgba(201,100,66,.16);
    --shadow-1:0 1px 2px rgba(0,0,0,.4);
    --shadow-2:0 2px 8px rgba(0,0,0,.5);
    --shadow-3:0 8px 32px rgba(0,0,0,.55);
  }
}
:root[data-theme="dark"]{
  --paper:#0E0F12;
  --paper-2:#161719;
  --paper-3:#1F2024;
  --ink-900:#F4F1EA;
  --ink-800:#E0DED8;
  --ink-700:#C4C2BC;
  --ink-500:#9B9C9F;
  --ink-300:#6A6C70;
  --ink-200:#3A3C40;
  --ink-100:#26282C;
  --rule:rgba(244,241,234,.10);
  --rule-strong:rgba(244,241,234,.20);
  --accent-100:rgba(201,100,66,.16);
  --shadow-1:0 1px 2px rgba(0,0,0,.4);
  --shadow-2:0 2px 8px rgba(0,0,0,.5);
  --shadow-3:0 8px 32px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--paper);color:var(--ink-900);font-family:var(--font-body);font-size:14px;line-height:1.5}
h1{font:600 48px/1.05 var(--font-display);letter-spacing:-.035em;margin:0 0 14px;color:var(--ink-900)}
h2{font:600 28px/1.15 var(--font-display);letter-spacing:-.03em;margin:64px 0 20px;padding-top:28px;border-top:1px solid var(--rule);color:var(--ink-900)}
h3{font:600 16px/1.25 var(--font-display);letter-spacing:-.015em;margin:28px 0 12px;color:var(--ink-700)}
p{max-width:64ch;color:var(--ink-700)}
.lede{font:400 18px/1.55 var(--font-body);color:var(--ink-700);max-width:62ch;margin:0 0 8px}
code{font-family:var(--font-mono);font-size:.92em;background:var(--paper-2);padding:1px 5px;border-radius:3px;border:1px solid var(--rule);color:var(--ink-800)}
a{color:var(--ink-900)}
a:hover{color:var(--accent-600)}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-4);font:500 13px/1 var(--font-body);border:1px solid transparent;cursor:pointer;transition:.15s;text-decoration:none}
.btn.primary{background:var(--ink-900);color:var(--paper)}
.btn.primary:hover{background:var(--ink-800)}
.btn.secondary{background:var(--paper);color:var(--ink-900);border-color:var(--rule-strong)}
.btn.secondary:hover{background:var(--paper-2)}
.btn.accent{background:var(--accent);color:#FFFFFF}
.btn.accent:hover{background:var(--accent-600)}
.btn.ghost{background:transparent;color:var(--ink-700)}
.btn.ghost:hover{background:var(--paper-2)}
.btn.sm{padding:7px 12px;font-size:12px}
.btn.lg{padding:14px 22px;font-size:14px}

/* Inputs */
.input{width:100%;padding:10px 12px;border:1px solid var(--rule-strong);border-radius:var(--r-4);background:var(--paper);font:400 13px/1 var(--font-body);color:var(--ink-900);outline:none}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-100)}
.input.mono{font-family:var(--font-mono)}
textarea.input{font-family:var(--font-body);min-height:96px;resize:vertical;line-height:1.5}
select.input{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-500) 50%),linear-gradient(135deg,var(--ink-500) 50%,transparent 50%);background-position:calc(100% - 16px) 50%,calc(100% - 11px) 50%;background-size:5px 5px;background-repeat:no-repeat;padding-right:32px}
.field-label{font:500 10px/1 var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500);margin-bottom:6px;display:block}
.field-help{font:400 11px/1.4 var(--font-body);color:var(--ink-500);margin-top:6px}

/* Card */
.card{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-6);padding:18px}
.card h4{font:600 14px/1.3 var(--font-display);letter-spacing:-.02em;margin:0 0 6px;color:var(--ink-900)}

/* Pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:var(--r-pill);font:500 10px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--rule);color:var(--ink-700)}
.pill.live::before{content:"";width:5px;height:5px;border-radius:var(--r-pill);background:var(--ok);box-shadow:0 0 0 3px rgba(47,143,92,.18)}
.pill.nis2{color:var(--accent-600);border-color:var(--accent-100);background:var(--accent-100)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--r-3);font:500 10px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase}
.badge.ok{background:rgba(47,143,92,.12);color:var(--ok)}
.badge.warn{background:rgba(176,130,58,.12);color:var(--warn)}
.badge.err{background:rgba(184,58,46,.12);color:var(--err)}
.badge.neutral{background:var(--ink-100);color:var(--ink-700)}

/* Navbar */
.navbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border:1px solid var(--rule);border-radius:var(--r-6);background:var(--paper)}
.navbar .l{display:flex;align-items:center;gap:32px}
.navbar .links{display:flex;gap:22px;font:500 13px/1 var(--font-body);color:var(--ink-700)}
.navbar .links a{color:inherit;text-decoration:none}
.navbar .links a:hover{color:var(--accent-600)}
.navbar .links a.active{color:var(--ink-900);font-weight:600}

/* Table */
table.t{width:100%;border-collapse:collapse;font:400 13px/1.4 var(--font-body)}
table.t th{text-align:left;font:500 10px/1 var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500);padding:10px 14px;border-bottom:1px solid var(--rule-strong)}
table.t td{padding:14px;border-bottom:1px solid var(--rule);color:var(--ink-800)}
table.t tr:hover td{background:var(--paper-2)}
table.t td.mono{font-family:var(--font-mono);color:var(--ink-700)}

/* Layout helpers */
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.stack{display:flex;flex-direction:column;gap:10px}
.demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.demo-grid.two{grid-template-columns:repeat(2,1fr)}
.demo-grid.four{grid-template-columns:repeat(4,1fr)}
@media (max-width:720px){.demo-grid,.demo-grid.two,.demo-grid.four{grid-template-columns:1fr}}

[data-accent="compliance"]{--accent:#DC2626;--accent-600:#B91C1C;--accent-100:#FEE2E2}
[data-accent="security"]{--accent:#1E40AF;--accent-600:#1E3A8A;--accent-100:#DBEAFE}
[data-accent="finance"]{--accent:#059669;--accent-600:#047857;--accent-100:#D1FAE5}
[data-accent="transparency"]{--accent:#7C3AED;--accent-600:#6D28D9;--accent-100:#EDE9FE}
@media (prefers-color-scheme:dark){
  :root:not([data-theme="light"]) [data-accent="compliance"]{--accent-100:rgba(220,38,38,.18)}
  :root:not([data-theme="light"]) [data-accent="security"]{--accent-100:rgba(30,64,175,.20)}
  :root:not([data-theme="light"]) [data-accent="finance"]{--accent-100:rgba(5,150,105,.20)}
  :root:not([data-theme="light"]) [data-accent="transparency"]{--accent-100:rgba(124,58,237,.20)}
}
:root[data-theme="dark"] [data-accent="compliance"]{--accent-100:rgba(220,38,38,.18)}
:root[data-theme="dark"] [data-accent="security"]{--accent-100:rgba(30,64,175,.20)}
:root[data-theme="dark"] [data-accent="finance"]{--accent-100:rgba(5,150,105,.20)}
:root[data-theme="dark"] [data-accent="transparency"]{--accent-100:rgba(124,58,237,.20)}

/* Page chrome — header / footer / wrap reused across all landings */
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.site-header{padding:18px 24px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;background:var(--paper)}
.site-header .site-logo{display:inline-flex;align-items:center;color:var(--ink-900);text-decoration:none;line-height:0}
.site-header .site-logo svg{height:22px;width:auto;display:block;color:var(--ink-900)}
.site-header nav{display:flex;align-items:center;gap:2px;flex-wrap:wrap}
.site-header nav a{padding:6px 10px;border-radius:var(--r-4);text-decoration:none;color:var(--ink-700);font:500 11px/1 var(--font-mono);letter-spacing:.06em;text-transform:uppercase;transition:.12s}
.site-header nav a:hover{color:var(--ink-900);background:var(--paper-2)}
.site-header nav a.active{color:var(--ink-900);background:var(--accent-100)}
.site-footer{padding:48px 24px 36px;border-top:1px solid var(--rule);background:var(--paper);margin-top:80px;text-align:center;color:var(--ink-500);font:400 13px/1.5 var(--font-body)}
.site-footer a{color:var(--ink-700);margin:0 8px;text-decoration:none}
.site-footer a:hover{color:var(--accent-600)}
.site-footer .sources{margin-top:14px;font:500 10px/1.5 var(--font-mono);color:var(--ink-300);letter-spacing:.1em;text-transform:uppercase}


/* Hero (landing variant — denser than homepage hero) */
.hero-page{padding:48px 24px 24px;border-bottom:1px solid var(--rule);background:var(--paper)}
.hero-page .breadcrumb{font:500 11px/1.4 var(--font-mono);color:var(--ink-500);letter-spacing:.06em;text-transform:uppercase;margin:0 0 18px}
.hero-page .breadcrumb a{color:var(--ink-700);text-decoration:none}
.hero-page .breadcrumb a:hover{color:var(--accent-600)}
.hero-page .breadcrumb .sep{margin:0 8px;color:var(--ink-300)}
.hero-page .eyebrow{font:500 11px/1 var(--font-mono);color:var(--accent-600);letter-spacing:.18em;text-transform:uppercase;margin:0 0 14px;display:inline-block}
.hero-page h1{font:600 40px/1.1 var(--font-display);letter-spacing:-.03em;color:var(--ink-900);margin:0 0 14px;max-width:24ch}
.hero-page .lede{font:400 17px/1.55 var(--font-body);color:var(--ink-700);margin:0;max-width:64ch}
.hero-page .actions{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}

/* Sections */
.section{padding:64px 24px;border-bottom:1px solid var(--rule)}
.section.alt{background:var(--paper-2)}
.section h2{font:600 28px/1.15 var(--font-display);letter-spacing:-.025em;color:var(--ink-900);margin:0 0 14px;padding:0;border:0}
.section .sub{font:400 15px/1.55 var(--font-body);color:var(--ink-700);max-width:62ch;margin:0 0 32px}
.section .head{margin-bottom:28px}
.section .head .eyebrow{font:500 11px/1 var(--font-mono);color:var(--accent-600);letter-spacing:.18em;text-transform:uppercase;margin:0 0 12px;display:inline-block}

/* Stat row — under hero */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0;background:var(--paper-2);border-bottom:1px solid var(--rule)}
.stat-row .stat{padding:24px 22px;border-right:1px solid var(--rule)}
.stat-row .stat:last-child{border-right:0}
.stat-row .stat strong{display:block;font:600 28px/1.1 var(--font-display);letter-spacing:-.02em;color:var(--ink-900)}
.stat-row .stat span{display:block;margin-top:6px;font:500 11px/1.4 var(--font-mono);color:var(--ink-500);letter-spacing:.1em;text-transform:uppercase}
@media (max-width:720px){.stat-row{grid-template-columns:repeat(2,1fr)}.stat-row .stat:nth-child(2n){border-right:0}}

/* Tile grid — feature cards */
.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.tile{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-6);padding:22px;display:flex;flex-direction:column;gap:10px;transition:.15s;color:inherit;text-decoration:none}
a.tile:hover{border-color:var(--rule-strong);box-shadow:var(--shadow-2);transform:translateY(-1px)}
.tile h3{font:600 15px/1.3 var(--font-display);letter-spacing:-.015em;color:var(--ink-900);margin:0}
.tile p{font:400 13px/1.55 var(--font-body);color:var(--ink-700);margin:0}
.tile .tag{font:500 10px/1 var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent-600);align-self:flex-start;padding:4px 8px;border-radius:var(--r-3);background:var(--accent-100)}

/* Data table — standard ranking layout */
.data-table{width:100%;border-collapse:collapse;font:400 13px/1.4 var(--font-body);background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-6);overflow:hidden}
.data-table th{text-align:left;padding:12px 14px;background:var(--paper-2);color:var(--ink-500);font:500 10px/1 var(--font-mono);letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--rule-strong)}
.data-table td{padding:13px 14px;border-bottom:1px solid var(--rule);color:var(--ink-800)}
.data-table tr:last-child td{border-bottom:0}
.data-table tr:hover td{background:var(--paper-2)}
.data-table td.num{text-align:right;font-variant-numeric:tabular-nums;color:var(--accent-600);font-weight:600}
.data-table td.rank{color:var(--ink-500);font:500 11px/1 var(--font-mono);width:48px;text-align:right}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-list details{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-6);padding:14px 18px;transition:.15s}
.faq-list details[open]{border-color:var(--rule-strong);background:var(--paper-2)}
.faq-list summary{cursor:pointer;font:500 14px/1.4 var(--font-body);color:var(--ink-900);list-style:none;padding-right:24px;position:relative}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);color:var(--ink-500);font:400 18px/1 var(--font-mono);transition:.15s}
.faq-list details[open] summary::after{content:"−";color:var(--accent-600)}
.faq-list details p{font:400 13px/1.6 var(--font-body);color:var(--ink-700);margin:10px 0 0;max-width:none}

/* Callout — replaces dramatic warning boxes */
.callout{background:var(--paper);border:1px solid var(--rule);border-left:3px solid var(--accent);border-radius:var(--r-4);padding:14px 18px;margin:0 0 24px;font:400 13px/1.55 var(--font-body);color:var(--ink-700)}
.callout strong{color:var(--ink-900);font-weight:600}
.callout.warn{border-left-color:var(--warn)}
.callout.err{border-left-color:var(--err)}

/* CTA block — replaces gradient ribbon */
.cta-block{margin:48px 0 0;padding:32px;background:var(--paper-2);border:1px solid var(--rule);border-radius:var(--r-6);text-align:center}
.cta-block h3{font:600 20px/1.2 var(--font-display);letter-spacing:-.02em;color:var(--ink-900);margin:0 0 8px}
.cta-block p{font:400 14px/1.55 var(--font-body);color:var(--ink-700);margin:0 auto 20px;max-width:48ch}
.cta-block .actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* Code blocks */
pre.code{background:var(--ink-900);color:var(--ink-100);border-radius:var(--r-6);padding:18px 22px;overflow-x:auto;font:500 12px/1.6 var(--font-mono);margin:0;border:1px solid var(--rule-strong)}

/* Inline form — for newsletter / API key request */
.inline-form{display:flex;gap:8px;flex-wrap:wrap;max-width:520px;margin:0 auto}
.inline-form input,.inline-form select{flex:1 1 200px;padding:10px 14px;border:1px solid var(--rule-strong);border-radius:var(--r-4);background:var(--paper);color:var(--ink-900);font:400 13px/1 var(--font-body)}
.inline-form input:focus,.inline-form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-100)}
.inline-form button{padding:10px 20px;background:var(--accent);color:#fff;border:0;border-radius:var(--r-4);font:600 13px/1 var(--font-body);cursor:pointer;transition:.12s}
.inline-form button:hover{background:var(--accent-600)}

/* Inline check widget — used by /check landing + per-landing demo blocks */
.check-card{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-6);padding:24px;margin:0 0 28px}
.check-card h3{font:600 16px/1.3 var(--font-display);color:var(--ink-900);margin:0 0 6px}
.check-card p{font:400 13px/1.55 var(--font-body);color:var(--ink-700);margin:0 0 16px}
.check-card form{display:flex;gap:8px;flex-wrap:wrap}
.check-card input{flex:1 1 240px;padding:12px 14px;border:1px solid var(--rule-strong);border-radius:var(--r-4);background:var(--paper);color:var(--ink-900);font:500 14px/1 var(--font-body)}
.check-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-100)}
.check-card button{padding:12px 22px;background:var(--accent);color:#fff;border:0;border-radius:var(--r-4);font:600 14px/1 var(--font-body);cursor:pointer}
.check-card button:hover{background:var(--accent-600)}
.check-card .result{margin-top:16px;padding:14px;border-radius:var(--r-4);background:var(--paper-2);border:1px solid var(--rule);font:400 13px/1.5 var(--font-body);min-height:0;display:none}
.check-card .result.show{display:block}

/* Share row */
.share-row{display:flex;gap:6px;flex-wrap:wrap;margin:14px 0 0;font:500 11px/1 var(--font-mono);color:var(--ink-500);letter-spacing:.06em;text-transform:uppercase;align-items:center}
.share-row .label{color:var(--ink-500);margin-right:6px}
.share-row a{padding:6px 10px;border:1px solid var(--rule);border-radius:var(--r-4);color:var(--ink-700);text-decoration:none;background:var(--paper);transition:.12s}
.share-row a:hover{border-color:var(--accent);color:var(--accent-600);background:var(--accent-100)}

/* Responsive */
@media (max-width:720px){
  .hero-page{padding:32px 20px 20px}
  .hero-page h1{font-size:32px}
  .section{padding:48px 20px}
  .section h2{font-size:24px}
  .site-header{padding:14px 18px}
  .site-header nav a{font-size:10px;padding:5px 8px}
}
