:root{
  /* Neutral print/paper palette */
  --bg:        #f5f1e8;
  --bg-2:      #efe9dc;
  --bg-3:      #e8e0cf;
  --surface:   rgba(0,0,0,0.025);
  --surface-2: rgba(0,0,0,0.04);
  --border:    rgba(20,16,10,0.12);
  --border-strong: rgba(20,16,10,0.22);
  --ink:       #1a1612;
  --text:      #2a241d;
  --text-2:    #4a4236;
  --muted:     #6a6154;
  --muted-2:   #8a8170;
  --accent:    #b8460e;  /* burnt amber */
  --accent-2:  #8a3408;
  --accent-tint: rgba(184,70,14,0.08);
  --accent-line: rgba(184,70,14,0.24);
  --danger:    #a33020;
  --ok:        #3e6b3a;
  --warn:      #a06a14;
  --display:   'Newsreader', Georgia, 'Times New Roman', serif;
  --body:      'Inter', -apple-system, Helvetica, Arial, sans-serif;
  --mono:      'JetBrains Mono', ui-monospace, Menlo, monospace;
}
html,body{margin:0;padding:0;background:#2a241d}
*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;box-sizing:border-box}
deck-stage section{background:var(--bg);color:var(--text);font-family:var(--body);font-size:30px;line-height:1.5}

/* ── Frame chrome ───────────────────────────────────────── */
.frame{position:absolute;inset:0;padding:72px 100px 64px 100px;display:flex;flex-direction:column}
.frame.alt{background:var(--bg-2)}
.frame.glow{background:var(--bg-2)}
.frame.seam{background:var(--bg-3);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.topbar{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:22px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.topbar .brand{display:flex;align-items:center;gap:14px}
.topbar .brand img{height:26px;opacity:0.9}
.topbar .sec{color:var(--text-2)}
.topbar .sec b{color:var(--accent);font-weight:700}
.topbar-rule{height:1px;margin-top:14px;background:var(--border-strong)}

/* ── Headings ───────────────────────────────────────────── */
.eyebrow{
  font-family:var(--body);font-weight:600;font-size:22px;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--accent);
  margin-top:42px;
}
.title{
  font-family:var(--display);font-weight:500;font-size:86px;line-height:1.02;
  letter-spacing:-0.5px;color:var(--ink);margin:14px 0 0 0;text-wrap:balance;
}
.title.md{font-size:64px;letter-spacing:-0.3px}
.title.sm{font-size:50px;letter-spacing:-0.2px}
.title .accent{color:var(--accent);font-style:italic;font-weight:500}
.subtitle{
  font-family:var(--body);font-weight:400;font-size:32px;line-height:1.45;
  color:var(--text-2);margin-top:22px;max-width:1500px;text-wrap:pretty;
}
.h-gradient{
  display:inline-block;
  font-family:var(--display);font-weight:600;
  color:var(--accent);
  border-bottom:2px solid var(--accent);padding-bottom:10px;
}

/* ── Footer ─────────────────────────────────────────────── */
.footer{
  margin-top:auto;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:19px;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;
  padding-top:18px;border-top:1px solid var(--border);
}
.footer .pg{color:var(--text-2)}

.body{flex:1;display:flex;flex-direction:column;min-height:0}
.body-text{font-size:28px;line-height:1.55;color:var(--text)}
.small{font-size:24px;line-height:1.5;color:var(--muted)}
.mono{font-family:var(--mono)}
.accent{color:var(--accent);font-weight:600}
.rule-rule{font-family:var(--body);font-weight:600;font-size:20px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}

/* ── Lists / KV ─────────────────────────────────────────── */
.kv{display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:start}
.kv .k{
  font-family:var(--display);font-weight:600;font-size:28px;letter-spacing:0;
  padding-top:4px;color:var(--accent);font-style:italic;
}
.kv .v{font-size:26px;line-height:1.45;color:var(--text)}
.kv .v b{color:var(--ink);font-weight:600}

ul.dash{list-style:none;padding:0;margin:0}
ul.dash li{position:relative;padding:8px 0 8px 28px;font-size:26px;line-height:1.45;color:var(--text)}
ul.dash li::before{
  content:'\2023';position:absolute;left:0;top:7px;font-weight:700;font-size:1.15em;line-height:1;
  color:var(--accent);
}

/* ── Tags / chips ───────────────────────────────────────── */
.tag{display:inline-block;font-family:var(--mono);font-size:18px;padding:4px 12px;border-radius:3px;letter-spacing:0.08em;text-transform:uppercase;border:1px solid transparent;font-weight:500}
.tag.mature{background:rgba(62,107,58,0.10);color:#3e6b3a;border-color:rgba(62,107,58,0.28)}
.tag.custom{background:rgba(184,70,14,0.08);color:var(--accent);border-color:var(--accent-line)}
.tag.unsolved{background:rgba(163,48,32,0.08);color:var(--danger);border-color:rgba(163,48,32,0.28)}

.risk-chip{font-family:var(--body);font-weight:700;font-size:20px;padding:5px 14px;border-radius:4px;letter-spacing:0.04em;border:1px solid transparent}
.risk-chip.d3{background:rgba(163,48,32,0.10);color:var(--danger);border-color:rgba(163,48,32,0.32)}
.risk-chip.d2{background:rgba(160,106,20,0.10);color:var(--warn);border-color:rgba(160,106,20,0.32)}
.risk-chip.d1{background:rgba(184,70,14,0.10);color:var(--accent);border-color:var(--accent-line)}
.risk-chip.d0{background:rgba(0,0,0,0.04);color:var(--text-2);border-color:var(--border)}

.owasp-id{font-family:var(--mono);font-weight:600;font-size:18px;color:var(--accent);letter-spacing:0.06em;padding:3px 9px;background:var(--accent-tint);border:1px solid var(--accent-line);border-radius:3px;display:inline-block}

/* ── Cards / panels ─────────────────────────────────────── */
.panel{
  background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:22px 26px;
}
.panel.glow{
  background:var(--accent-tint);
  border-color:var(--accent-line);
}
.panel .label{
  font-family:var(--body);font-weight:600;font-size:19px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;
}
.panel h4{
  font-family:var(--display);font-weight:600;font-size:30px;margin:0 0 8px 0;color:var(--ink);letter-spacing:0;
}

.critical{
  padding:14px 0 14px 26px;margin-top:14px;
  border-left:3px solid var(--accent);
  background:var(--accent-tint);border-radius:0 4px 4px 0;
  padding-right:22px;
}
.critical .label{
  font-family:var(--body);font-weight:600;font-size:19px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--accent);margin-bottom:6px;
}
.critical .text{
  font-family:var(--display);font-size:28px;line-height:1.4;color:var(--ink);font-weight:400;
}

/* ── Tables ─────────────────────────────────────────────── */
table.plain{width:100%;border-collapse:collapse;font-size:22px;font-family:var(--body)}
table.plain th, table.plain td{
  text-align:left;vertical-align:top;padding:12px 18px 12px 0;
  border-top:1px solid var(--border);line-height:1.4;color:var(--text);
}
table.plain th{
  font-family:var(--body);font-weight:600;font-size:19px;
  text-transform:uppercase;letter-spacing:0.16em;
  color:var(--accent);
  border-top:none;padding-bottom:12px;
}
table.plain td b{color:var(--ink);font-weight:600}

/* ── Layout helpers ─────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px}
.four-col{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* ── Plane cards (12 planes overview) ───────────────────── */
.plane-card{
  display:grid;grid-template-columns:44px 1fr;gap:14px;padding:14px 0;
  border-top:1px solid var(--border);
}
.plane-card:last-child{border-bottom:1px solid var(--border)}
.plane-card .n{
  font-family:var(--display);font-weight:600;font-size:24px;padding-top:4px;letter-spacing:0;
  color:var(--accent);font-style:italic;
}
.plane-card .name{
  font-family:var(--display);font-weight:600;font-size:28px;color:var(--ink);
  margin-bottom:2px;letter-spacing:0;
}
.plane-card .purpose{font-size:20px;line-height:1.4;color:var(--muted)}

/* ── Flow strip ─────────────────────────────────────────── */
.flow{display:grid;grid-template-columns:repeat(13,1fr);gap:0;font-family:var(--mono);font-size:13px;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--surface)}
.flow .step{padding:14px 10px;border-right:1px solid var(--border);line-height:1.3;color:var(--text);overflow-wrap:break-word;min-width:0}
.flow .step:last-child{border-right:none}
.flow .step .i{
  font-family:var(--body);font-weight:700;font-size:14px;letter-spacing:0.14em;
  color:var(--accent);
  display:block;margin-bottom:5px;
}
.flow .step .p{display:block;color:var(--muted);font-size:13px;margin-top:8px;letter-spacing:0.10em;text-transform:uppercase}

/* ── Pull quote ─────────────────────────────────────────── */
.pull-quote{
  font-family:var(--display);font-weight:500;
  font-size:60px;line-height:1.2;letter-spacing:-0.3px;
  color:var(--ink);text-wrap:balance;
}
.pull-quote .hl{
  color:var(--accent);font-style:italic;
}

/* ── Cover ──────────────────────────────────────────────── */
.cover{
  position:absolute;inset:0;padding:56px 100px 50px 100px;
  background:var(--bg);
  display:flex;flex-direction:column;color:var(--ink);
  border-top:4px solid var(--accent);
}
.cover .meta-top{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:22px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
}
.cover .meta-top img{height:44px;width:auto;filter:invert(1) brightness(0.15)}
.cover .main{flex:1;display:flex;flex-direction:column;justify-content:center;padding-top:20px}
.cover .kicker-row{
  display:flex;gap:24px;align-items:center;margin-bottom:24px;
  font-family:var(--body);font-weight:600;font-size:24px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--accent);
}
.cover .kicker-row .dot{
  width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block;
}
.cover h1{
  font-family:var(--display);font-weight:500;font-size:136px;line-height:0.98;
  letter-spacing:-2px;margin:0;text-wrap:balance;color:var(--ink);
}
.cover h1 .br{display:block}
.cover h1 .hl{color:var(--accent);font-style:italic;font-weight:500}
.cover .sub{
  font-family:var(--body);font-weight:400;font-size:32px;line-height:1.45;
  color:var(--text-2);margin-top:36px;max-width:1400px;
}
.cover .foot{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:19px;letter-spacing:0.12em;color:var(--muted);
  padding-top:20px;border-top:1px solid var(--border);
}

/* ── Numbered grid for 16 diagnostic ────────────────────── */
.diag-row{
  display:grid;grid-template-columns:40px 1fr 150px;gap:14px;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--border);
}
.diag-row .n{
  font-family:var(--display);font-weight:600;font-size:24px;letter-spacing:0;
  color:var(--accent);font-style:italic;
}
.diag-row .q{font-size:22px;line-height:1.4;color:var(--text)}
.diag-row .p{font-family:var(--mono);font-size:15px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);text-align:right}
