*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#0a0a0b;--surface:#111113;--surface-2:#161618;--surface-3:#1c1c1f;
  --border:rgba(255,255,255,0.07);--border-bright:rgba(255,255,255,0.13);
  --text:#c8c8cc;--text-muted:#6b6b72;--text-faint:#3a3a40;
  --accent:#e08020;--accent-dim:rgba(224,128,32,0.15);--accent-glow:rgba(224,128,32,0.08);
  --teal:#2a9d8f;--teal-dim:rgba(42,157,143,0.15);
  --red:#e05555;--red-dim:rgba(224,85,85,0.15);
  --gold:#d4a017;
  --font-mono:'Share Tech Mono','Courier New',monospace;
  --font-ui:'Rajdhani','Segoe UI',sans-serif;
  --radius:4px;--panel-header:28px;--titlebar:44px;--statbar:42px;--input-area:52px;
  /* layout */
  --sidebar-w:256px;--top-h:48px;
  /* bridge vars for existing class references */
  --bg2:var(--surface);--bg3:var(--surface-2);--bg4:var(--surface-3);
  --text-dim:var(--text-muted);--text-hi:var(--text);
  --accent2:var(--teal);--green:var(--teal);
}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-ui);
  font-size:14px;line-height:1.72;
  color:var(--text);background:var(--bg);
  overflow-x:hidden;
}

/* global scrollbars */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:2px;}

/* top nav */
.topnav{
  position:sticky;top:0;z-index:100;
  background:var(--surface);border-bottom:1px solid var(--border-bright);
  height:var(--top-h);display:flex;align-items:center;
  padding:0 20px;gap:16px;flex-wrap:wrap;
}
.topnav .brand{
  font-family:var(--font-ui);font-weight:700;font-size:15px;
  letter-spacing:3px;color:var(--accent);text-transform:uppercase;
  text-decoration:none;
}
.topnav a{color:var(--text-muted);text-decoration:none;font-size:12.5px;}
.topnav a:hover{color:var(--accent);}
.topnav .chapter-links{display:flex;gap:8px;flex-wrap:wrap;margin-left:auto;}
.topnav .chapter-links a{
  font-family:var(--font-ui);font-size:11px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  padding:3px 9px;border-radius:var(--radius);
  background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);
}
.topnav .chapter-links a:hover{background:var(--accent);color:#000;}

/* mobile header */
#mobile-header{
  display:none;
  position:sticky;top:0;z-index:200;width:100%;
  height:var(--top-h);background:var(--surface);
  border-bottom:1px solid var(--border-bright);
  align-items:center;justify-content:space-between;padding:0 16px;
}
#mobile-header .mob-brand{
  font-family:var(--font-ui);font-size:14px;font-weight:700;
  letter-spacing:3px;color:var(--accent);text-transform:uppercase;
}
#menu-toggle{
  background:none;border:1px solid var(--border-bright);border-radius:var(--radius);
  padding:5px 7px;cursor:pointer;display:flex;flex-direction:column;gap:4px;
}
#menu-toggle span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px;}

#sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.65);z-index:300;
}
#sidebar-overlay.active{display:block;}

/* layout wrapper */
.layout{display:flex;min-height:calc(100vh - var(--top-h));}

/* sidebar */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--surface);border-right:1px solid var(--border-bright);
  position:sticky;top:var(--top-h);
  height:calc(100vh - var(--top-h));
  overflow-y:auto;padding:16px 0;
}
.sidebar::-webkit-scrollbar{width:4px;}
.sidebar::-webkit-scrollbar-track{background:transparent;}
.sidebar::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:2px;}
.sg{margin-bottom:18px;}
.sg-label{
  font-family:var(--font-ui);font-size:9px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--text-muted);
  padding:0 15px 5px;display:block;
}
.sidebar a{
  display:block;padding:4px 15px;font-size:12.5px;
  color:var(--text-muted);text-decoration:none;
  border-left:2px solid transparent;
}
.sidebar a:hover{color:var(--accent);background:var(--surface-2);}
.sidebar a.sub{padding-left:26px;font-size:11.5px;}

/* main content */
.main{flex:1;min-width:0;padding:44px 52px;max-width:900px;}

/* typography */
h1{
  font-family:var(--font-ui);font-size:1.85rem;font-weight:700;
  color:var(--accent);letter-spacing:2px;margin-bottom:6px;
}
h1+p.lead{color:var(--text-muted);margin-bottom:36px;font-size:14px;}
.chapter-title{
  font-family:var(--font-ui);font-size:1rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent);
  margin:60px 0 0;padding-top:60px;
  border-top:2px solid var(--accent);
  display:flex;align-items:center;gap:10px;
}
.chapter-num{
  font-size:10px;background:var(--accent);color:var(--bg);
  padding:2px 7px;border-radius:2px;font-weight:900;
  letter-spacing:.1em;
}
h2{
  font-family:var(--font-ui);font-size:1.2rem;font-weight:700;
  color:var(--accent);letter-spacing:0.5px;
  margin:44px 0 12px;padding-top:44px;
  border-top:1px solid var(--border-bright);
}
h2.first{margin-top:16px;padding-top:0;border-top:none;}
h3{
  font-family:var(--font-ui);font-size:.97rem;font-weight:700;
  color:var(--accent);letter-spacing:0.5px;margin:24px 0 8px;
}
h4{
  font-family:var(--font-ui);font-size:.84rem;font-weight:700;
  color:var(--accent);margin:18px 0 6px;
  text-transform:uppercase;letter-spacing:.06em;
}
p{margin-bottom:12px;}
a{color:var(--text-muted);}
a:hover{color:var(--accent);}
strong{color:var(--text);font-weight:600;}

/* code */
code{
  font-family:var(--font-mono);
  font-size:13px;background:var(--surface-2);
  border:1px solid var(--border-bright);border-radius:var(--radius);
  padding:1px 5px;color:var(--teal);
  overflow-x:auto;max-width:100%;
}
pre{
  background:var(--surface-2);border:1px solid var(--border-bright);
  border-radius:0 0 var(--radius) var(--radius);padding:13px 15px;
  overflow-x:auto;max-width:100%;
  font-family:var(--font-mono);
  font-size:13px;line-height:1.6;color:var(--text);white-space:pre;
}
pre .c{color:var(--text-muted)}
pre .k{color:#c586c0}
pre .kn{color:#c586c0}
pre .s{color:#ce9178}
pre .nc{color:#4ec9b0}
pre .nf{color:#dcdcaa}
pre .nb{color:#569cd6}
pre .mi{color:#b5cea8}
pre .o{color:var(--text-muted)}

ol,ul{padding-left:20px;margin-bottom:12px;}
li{margin-bottom:4px;}

/* code blocks */
.code-block{margin:12px 0;}
.code-label{
  font-family:var(--font-ui);font-size:10.5px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);
  background:var(--surface-2);border:1px solid var(--border-bright);
  border-bottom:none;padding:5px 13px;
  border-radius:var(--radius) var(--radius) 0 0;
  display:flex;justify-content:space-between;align-items:center;
}
.code-label button{
  background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius);
  color:var(--accent);font-family:var(--font-ui);font-size:10px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;padding:2px 9px;cursor:pointer;
}
.code-label button:hover{background:var(--accent);color:#000;}

/* callouts */
.callout{border-radius:var(--radius);padding:10px 14px;margin:12px 0;font-size:13.5px;border-left:3px solid;}
.callout.warn{background:rgba(224,128,32,0.07);border-color:var(--accent);color:#c07830;}
.callout.info{background:rgba(42,157,143,0.07);border-color:var(--teal);color:var(--teal);}
.callout.tip{background:rgba(42,157,143,0.07);border-color:var(--teal);color:var(--teal);}
.callout.fix{background:var(--red-dim);border-color:var(--red);color:var(--red);}
.callout strong{color:inherit;font-weight:700;}

/* tables */
.table-wrap{overflow-x:auto;max-width:100%;margin:12px 0;}
table{border-collapse:collapse;width:100%;font-size:12.5px;}
th{
  text-align:left;padding:7px 11px;
  background:var(--surface-2);border:1px solid var(--border-bright);
  color:var(--text-muted);font-family:var(--font-ui);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.07em;
}
td{padding:7px 11px;border:1px solid var(--border-bright);vertical-align:top;}
td code{font-size:11.5px;}
tr:nth-child(even) td{background:var(--surface-2);}

/* score preview */
.score-preview{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:14px;
  font-family:var(--font-mono);
  font-size:13px;line-height:1.55;overflow-x:auto;max-width:100%;
}
.sf-border{color:var(--text-faint);}
.sf-header{color:var(--gold);}
.sf-label{color:var(--text-muted);}
.sf-val{color:var(--text);}
.sf-good{color:var(--teal);}
.sf-accent{color:var(--accent);}

/* combat preview */
.combat-preview{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:14px 16px;
  font-family:var(--font-mono);
  font-size:13px;line-height:1.8;overflow-x:auto;
}
.cm-atk{color:#d08060;}
.cm-miss{color:var(--text-muted);}
.cm-die{color:var(--red);}
.cm-env{color:var(--text-muted);}
.cm-vl{color:var(--teal);}
.cm-vs{color:#a0a840;}
.cm-vh{color:#c07830;}
.cm-vv{color:var(--red);}

/* race grid */
.race-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;margin:12px 0;}
.race-tag{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:5px 10px;font-size:12px;
}
.race-tag .rn{color:var(--text);font-weight:600;}
.race-tag .rd{color:var(--text-muted);font-size:11px;}
.race-tag.occ{border-color:rgba(42,157,143,0.3);}
.race-tag.occ .rn{color:var(--teal);}

/* arch cards */
.arch-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0;}
.arch-card{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:11px 14px;
}
.arch-card.dragon{border-color:rgba(224,85,85,0.25);}
.arch-card.feral{border-color:rgba(42,157,143,0.25);}
.arch-card.undead{border-color:rgba(120,80,160,0.3);}
.arch-card.humanoid{border-color:var(--border-bright);}
.arch-name{font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--text);margin-bottom:4px;}
.arch-races{font-size:11.5px;color:var(--text-muted);margin-bottom:6px;}
.arch-attacks{font-size:12px;color:var(--text);}

/* dev setup */
.setup-step{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:12px 16px;margin:8px 0;
}
.setup-num{
  font-family:var(--font-ui);font-size:10px;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;
}
.setup-title{font-family:var(--font-ui);font-weight:700;font-size:13.5px;color:var(--text);margin-bottom:4px;}
.setup-body{font-size:13px;color:var(--text);}
.ml{display:inline-block;font-size:10px;padding:2px 8px;border-radius:2px;margin-bottom:6px;font-weight:700;letter-spacing:.06em;}
.mac{background:var(--teal-dim);color:var(--teal);border:1px solid rgba(42,157,143,0.3);}
.win{background:rgba(42,157,143,0.07);color:var(--teal);border:1px solid rgba(42,157,143,0.2);}
.vps{background:var(--red-dim);color:var(--red);border:1px solid rgba(224,85,85,0.3);}

/* filetree */
.filetree{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:14px;
  font-family:var(--font-mono);
  font-size:13px;line-height:1.8;overflow-x:auto;
}
.filetree .dir{color:var(--teal);}
.filetree .new{color:var(--accent);}
.filetree .note{color:var(--text-muted);}

/* tattoo grid */
.tattoo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:7px;margin:12px 0;}
.tattoo-card{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:8px 11px;
}
.t-name{color:var(--gold);font-weight:700;font-size:12.5px;margin-bottom:2px;}
.t-effect{color:var(--text);font-size:12px;}
.t-sdc{color:var(--text-muted);font-size:11px;}
.tattoo-card.weapon{border-color:rgba(224,128,32,0.3);}
.tattoo-card.protection{border-color:rgba(42,157,143,0.3);}
.tattoo-card.power{border-color:rgba(160,80,200,0.3);}

/* page footer */
.page-footer{
  margin-top:60px;padding-top:22px;
  border-top:1px solid var(--border-bright);
  color:var(--text-muted);font-size:12.5px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 768px) {
  .topnav { display: none !important; }
  #mobile-header { display: flex !important; }

  .sidebar {
    position: fixed;
    top: 0;
    left: -280px;
    width: 260px;
    height: 100%;
    z-index: 400;
    transition: left 0.25s ease;
  }
  .sidebar.open { left: 0; }

  .layout { display: block; }

  .main {
    margin-left: 0 !important;
    padding: 22px 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  body.sidebar-open { overflow: hidden; }

  h1 { font-size: 1.45rem; }
  h2 { font-size: 1.05rem; }
  .chapter-title { font-size: .85rem; }

  .arch-grid { grid-template-columns: 1fr; }
  .race-grid { grid-template-columns: 1fr 1fr; }
  .tattoo-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .race-grid { grid-template-columns: 1fr; }
}

/* combat flow diagram */
.flow-row{display:flex;gap:8px;margin:14px 0;flex-wrap:wrap;}
.flow-box{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:10px 14px;flex:1;min-width:160px;
}
.flow-box.highlight{border-color:var(--teal);}
.flow-box.result-hit{border-color:var(--red);}
.flow-box.result-miss{border-color:var(--teal);}
.flow-title{
  font-family:var(--font-ui);font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:5px;
}
.flow-body{font-size:12.5px;color:var(--text);}

/* HTH tables */
.hth-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0;}
.hth-card{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:12px 14px;
}
.hth-name{font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--text);margin-bottom:3px;}
.hth-sub{font-size:11px;color:var(--text-muted);margin-bottom:8px;}
.hth-bonus{font-size:12px;color:var(--text);line-height:1.7;}
.hth-card.basic{border-color:rgba(42,157,143,0.15);}
.hth-card.expert{border-color:rgba(42,157,143,0.3);}
.hth-card.martial{border-color:rgba(160,80,200,0.3);}
.hth-card.assassin{border-color:rgba(224,85,85,0.3);}

/* spell and psionic cards */
.spell-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;margin:14px 0;}
.spell-card{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:9px 12px;
}
.spell-name{font-family:var(--font-ui);font-weight:700;font-size:13px;margin-bottom:3px;}
.spell-meta{font-size:11px;color:var(--text-muted);margin-bottom:5px;}
.spell-effect{font-size:12px;color:var(--text);}
.spell-card.l1{border-color:rgba(42,157,143,0.3);} .spell-card.l1 .spell-name{color:var(--teal);}
.spell-card.l2{border-color:rgba(42,157,143,0.2);} .spell-card.l2 .spell-name{color:var(--teal);}
.spell-card.l3{border-color:rgba(212,160,23,0.25);} .spell-card.l3 .spell-name{color:var(--gold);}
.spell-card.l4{border-color:rgba(224,128,32,0.2);} .spell-card.l4 .spell-name{color:var(--accent);}
.spell-card.l5{border-color:rgba(224,128,32,0.3);} .spell-card.l5 .spell-name{color:var(--accent);}
.spell-card.l6{border-color:rgba(224,85,85,0.25);} .spell-card.l6 .spell-name{color:var(--red);}
.spell-card.l7{border-color:rgba(224,85,85,0.35);} .spell-card.l7 .spell-name{color:var(--red);}

/* saving throw cards */
.save-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:14px 0;}
.save-card{
  background:var(--surface);border:1px solid var(--border-bright);
  border-radius:var(--radius);padding:9px 12px;
}
.save-type{font-family:var(--font-ui);font-weight:700;font-size:12.5px;color:var(--text);margin-bottom:3px;}
.save-roll{font-size:11.5px;color:var(--teal);margin-bottom:4px;}
.save-desc{font-size:11.5px;color:var(--text-muted);}

@media (max-width:768px){
  .hth-grid{grid-template-columns:1fr;}
  .spell-grid{grid-template-columns:1fr;}
  .save-grid{grid-template-columns:1fr 1fr;}
  .flow-row{flex-direction:column;}
}
@media (max-width:480px){
  .save-grid{grid-template-columns:1fr;}
}
