/* ============================================================
   WARBAND CALCULATOR — design system
   Dark-fantasy war-room instrument. Charcoal + blood + brass.
   Type: Saira Condensed (display) / Saira (UI) / JetBrains Mono (numbers)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700;800&family=Saira:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root{
  /* surfaces */
  --ink-950:#080605; --ink-900:#0b0908; --ink-850:#100c0a; --ink-800:#15100d;
  --panel:#1a1310; --panel-2:#221a14; --panel-3:#2a2018;
  --line:#3a2a20; --line-2:#4a362a; --line-soft:rgba(201,164,76,.13);
  /* brand */
  --blood:#8a1410; --blood-bright:#cf2b22; --blood-glow:rgba(207,43,34,.45);
  --ember:#dc8f33; --gold:#cba556; --gold-dim:#8f7638;
  /* text */
  --bone:#ece2cd; --bone-dim:#cabfa8; --ash:#a3927f; --ash-dim:#7c6e5e;
  /* status */
  --green:#74a444; --green-bright:#9ed46b; --steel:#7d8b94; --steel-bright:#a8b7c0;
  --amber:#e0b13e;
  /* type */
  --f-disp:'Saira Condensed',-apple-system,sans-serif;
  --f-ui:'Saira',-apple-system,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,monospace;
  /* radius / shadow */
  --r-xs:3px; --r-sm:4px; --r:6px; --r-lg:9px;
  --sh-1:0 1px 0 rgba(255,255,255,.03) inset, 0 6px 18px rgba(0,0,0,.4);
  --sh-2:0 1px 0 rgba(255,255,255,.04) inset, 0 14px 40px rgba(0,0,0,.55);
  --ring:0 0 0 2px var(--ink-900), 0 0 0 4px var(--ember);
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{background:var(--ink-900);}
body{
  font-family:var(--f-ui);color:var(--bone);font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:
    radial-gradient(ellipse 70% 42% at 50% -8%,rgba(138,20,16,.22),transparent 70%),
    radial-gradient(ellipse 50% 40% at 96% 108%,rgba(220,143,51,.08),transparent 70%),
    var(--ink-900);
  min-height:100vh;
}
/* film grain + smoke */
.tex{content:"";position:fixed;inset:0;pointer-events:none;z-index:60;mix-blend-mode:overlay;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");}
.vig{position:fixed;inset:0;pointer-events:none;z-index:59;
  background:radial-gradient(ellipse 120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%);}

/* ---------- typography helpers ---------- */
.disp{font-family:var(--f-disp);font-weight:700;letter-spacing:.01em;}
.eyebrow{font-family:var(--f-disp);font-weight:700;font-size:11px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--ember);}
.mono{font-family:var(--f-mono);font-variant-numeric:tabular-nums;}
.num{font-family:var(--f-mono);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em;}
h1,h2,h3,h4{font-family:var(--f-disp);font-weight:700;line-height:1.04;color:var(--bone);}
a{color:var(--ember);text-decoration:none;}
::selection{background:rgba(207,43,34,.4);color:#fff;}

/* ============================================================
   APP SHELL  (injected by shell.js)
   ============================================================ */
.app{display:grid;grid-template-columns:230px 1fr;min-height:100vh;align-items:start;}
.rail{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,var(--ink-850),var(--ink-900));
  border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:5;}
.rail::after{content:"";position:absolute;top:0;right:-1px;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,var(--gold-dim),transparent);opacity:.5;}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px;border-bottom:1px solid var(--line);}
.sigil{width:38px;height:38px;flex:none;position:relative;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 35%,#2a1a14,#120c09);border:1px solid var(--line-2);
  border-radius:7px;box-shadow:0 3px 10px rgba(0,0,0,.5),0 0 0 1px rgba(207,43,34,.15);}
.sigil svg{width:22px;height:22px;}
.sigil.logo{overflow:hidden;border-radius:50%;background:#0d0908;}
.sigil.logo img{width:100%;height:100%;object-fit:cover;display:block;}
.brand .bt{font-family:var(--f-disp);font-weight:800;font-size:16px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--bone);line-height:1;}
.brand .bs{font-family:var(--f-disp);font-weight:600;font-size:9.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-top:3px;}
.rail-nav{flex:1;overflow:auto;padding:14px 12px;display:flex;flex-direction:column;gap:3px;}
.nav-grp{font-family:var(--f-disp);font-weight:700;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ash-dim);padding:14px 10px 6px;}
.nav-grp:first-child{padding-top:2px;}
.nav-i{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-sm);
  color:var(--bone-dim);cursor:pointer;font-size:13.5px;font-weight:500;position:relative;
  border:1px solid transparent;transition:.14s;white-space:nowrap;}
.nav-i svg{width:17px;height:17px;flex:none;opacity:.78;}
.nav-i .nb{margin-left:auto;font-family:var(--f-mono);font-size:11px;font-weight:600;
  background:var(--panel-3);color:var(--ash);border-radius:4px;padding:1px 6px;}
.nav-i:hover{background:var(--panel);color:var(--bone);}
.nav-i.on{background:linear-gradient(90deg,rgba(207,43,34,.16),rgba(207,43,34,.04));
  border-color:rgba(207,43,34,.4);color:var(--bone);}
.nav-i.on svg{opacity:1;color:var(--ember);}
.nav-i.on::before{content:"";position:absolute;left:-12px;top:6px;bottom:6px;width:3px;
  border-radius:2px;background:linear-gradient(180deg,var(--ember),var(--blood-bright));}
.nav-i.on .nb{background:var(--ember);color:var(--ink-900);}
.rail-foot{padding:12px;border-top:1px solid var(--line);}
.prof{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm);background:var(--panel);
  border:1px solid var(--line);}
.prof .av{width:30px;height:30px;border-radius:6px;flex:none;background:linear-gradient(135deg,#3a2a20,#1a1310);
  border:1px solid var(--line-2);display:grid;place-items:center;font-family:var(--f-disp);font-weight:800;
  color:var(--gold);font-size:13px;}
.prof .pn{font-size:12.5px;font-weight:600;color:var(--bone);line-height:1.2;}
.prof .ps{font-size:10.5px;color:var(--ash);display:flex;align-items:center;gap:5px;margin-top:2px;}
.dot{width:6px;height:6px;border-radius:50%;background:var(--green-bright);box-shadow:0 0 6px var(--green-bright);}

/* topbar */
.main{display:flex;flex-direction:column;min-width:0;}
.topbar{display:flex;align-items:center;gap:16px;padding:0 26px;height:64px;flex:none;
  border-bottom:1px solid var(--line);background:rgba(11,9,8,.75);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:20;}
.tb-title{min-width:0;}
.tb-title .e{font-family:var(--f-disp);font-weight:700;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ember);}
.tb-title h1{font-size:21px;letter-spacing:.01em;margin-top:1px;white-space:nowrap;}
.tb-sp{flex:1;}
.ctx-pill{display:flex;align-items:center;gap:9px;padding:6px 12px 6px 9px;border-radius:99px;
  background:var(--panel);border:1px solid var(--line);}
.ctx-pill .ci{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  background:rgba(207,43,34,.14);border:1px solid rgba(207,43,34,.4);color:var(--blood-bright);}
.ctx-pill .ci svg{width:14px;height:14px;}
.ctx-pill .cl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash);font-weight:600;line-height:1;}
.ctx-pill .cv{font-family:var(--f-disp);font-weight:700;font-size:13px;color:var(--bone);line-height:1;margin-top:3px;}
.content{padding:24px 26px 60px;}
.wide{max-width:1180px;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{font-family:var(--f-ui);font-weight:600;font-size:13px;color:var(--bone);cursor:pointer;
  background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);
  padding:9px 15px;border-radius:var(--r-sm);transition:.14s;display:inline-flex;align-items:center;
  gap:8px;line-height:1;white-space:nowrap;}
.btn svg{width:15px;height:15px;}
.btn:hover{border-color:var(--ember);color:var(--ember);}
.btn:active{transform:translateY(1px);}
.btn:focus-visible{outline:none;box-shadow:var(--ring);}
.btn-blood{background:linear-gradient(180deg,#d6332a,var(--blood));border-color:#641009;color:#fff;
  font-family:var(--f-disp);font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 4px 16px rgba(138,20,16,.45),0 1px 0 rgba(255,255,255,.12) inset;}
.btn-blood:hover{filter:brightness(1.1);color:#fff;border-color:#641009;}
.btn-gold{background:linear-gradient(180deg,#d9b35e,#a07f33);border-color:#6e571f;color:#1a1208;
  font-family:var(--f-disp);font-weight:700;letter-spacing:.05em;text-transform:uppercase;}
.btn-gold:hover{filter:brightness(1.08);color:#1a1208;border-color:#6e571f;}
.btn-steel{border-color:var(--steel);color:var(--steel-bright);}
.btn-steel:hover{border-color:var(--steel-bright);color:#fff;}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--bone-dim);}
.btn-ghost:hover{background:var(--panel);border-color:var(--line-2);color:var(--bone);}
.btn-sm{padding:6px 11px;font-size:12px;}.btn-sm svg{width:13px;height:13px;}
.btn-lg{padding:13px 24px;font-size:15px;}
.btn-x{width:28px;height:28px;padding:0;justify-content:center;background:transparent;border:1px solid var(--line);
  color:var(--ash);border-radius:var(--r-sm);}
.btn-x:hover{border-color:var(--blood-bright);color:var(--blood-bright);}
.iconbtn{width:34px;height:34px;padding:0;justify-content:center;}

/* ============================================================
   PANELS / CARDS
   ============================================================ */
.panel{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);
  border-radius:var(--r);box-shadow:var(--sh-1);position:relative;}
.panel.pad{padding:18px;}
/* brass rivets on corners */
.panel.riv::before,.panel.riv::after{content:"";position:absolute;width:5px;height:5px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#e7c977,#7a5f25);box-shadow:0 0 0 1px rgba(0,0,0,.5);}
.panel.riv::before{top:8px;left:8px;}.panel.riv::after{top:8px;right:8px;}
.panel-h{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line);
  font-family:var(--f-disp);font-weight:700;font-size:13.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);}
.panel-h .hi{width:26px;height:26px;border-radius:var(--r-xs);display:grid;place-items:center;flex:none;
  background:var(--ink-850);border:1px solid var(--line);color:var(--ember);}
.panel-h .hi svg{width:15px;height:15px;}
.panel-h .sub{margin-left:auto;font-family:var(--f-ui);font-weight:500;font-size:12px;color:var(--ash);
  letter-spacing:0;text-transform:none;display:flex;align-items:center;gap:6px;}
.panel-b{padding:16px;}
.divider{height:1px;background:var(--line);margin:0;border:none;}
.dash{border-top:1px dashed var(--line);}

/* ============================================================
   FORM CONTROLS
   ============================================================ */
.field{display:flex;flex-direction:column;gap:6px;min-width:0;}
label,.lbl{font-family:var(--f-ui);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ash);}
.lbl .q{color:var(--ash-dim);font-weight:500;text-transform:none;letter-spacing:0;font-size:11px;}
input,select,textarea{font-family:var(--f-ui);font-size:13.5px;color:var(--bone);width:100%;
  background:var(--ink-850);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 11px;
  transition:.14s;}
input.num,input.mono{font-family:var(--f-mono);font-weight:600;text-align:right;letter-spacing:-.01em;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ember);
  box-shadow:0 0 0 3px rgba(220,143,51,.16);background:var(--ink-800);}
input::placeholder{color:var(--ash-dim);}
input.err,select.err{border-color:var(--blood-bright);box-shadow:0 0 0 3px rgba(207,43,34,.18);}
.help{font-size:11.5px;color:var(--ash);line-height:1.5;}
.err-msg{font-size:11.5px;color:var(--blood-bright);display:flex;align-items:center;gap:5px;font-weight:500;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.row{display:flex;align-items:center;gap:10px;}

/* segmented control (combat mode) */
.seg{display:flex;gap:4px;padding:4px;background:var(--ink-850);border:1px solid var(--line);border-radius:var(--r);}
.seg button{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 10px;
  border-radius:var(--r-sm);background:transparent;border:1px solid transparent;color:var(--ash);
  font-family:var(--f-disp);font-weight:700;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:.14s;}
.seg button svg{width:15px;height:15px;}
.seg button:hover{color:var(--bone);}
.seg button.on{background:linear-gradient(180deg,var(--panel-2),var(--panel));color:var(--bone);
  border-color:var(--line-2);box-shadow:0 2px 8px rgba(0,0,0,.4);}
.seg button.on.blood{color:#fff;background:linear-gradient(180deg,#b02018,var(--blood));border-color:#641009;}
.seg button.on.blood svg{color:#fff;}

/* checkbox / toggle */
.chk{display:flex;align-items:flex-start;gap:9px;cursor:pointer;font-size:13px;color:var(--bone-dim);line-height:1.4;}
.chk .box{width:18px;height:18px;border-radius:4px;border:1px solid var(--line-2);background:var(--ink-850);
  flex:none;display:grid;place-items:center;margin-top:1px;transition:.14s;}
.chk.on .box{background:linear-gradient(180deg,#d6332a,var(--blood));border-color:#641009;}
.chk.on .box svg{width:12px;height:12px;color:#fff;}
.chk .box svg{opacity:0;}.chk.on .box svg{opacity:1;}
.chk b{color:var(--bone);font-weight:600;}

/* slider */
.slider{-webkit-appearance:none;appearance:none;height:5px;border-radius:99px;background:var(--ink-850);
  border:1px solid var(--line);}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#e7c977,#a07f33);border:1px solid #6e571f;cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.5);}

/* ============================================================
   BADGES / CHIPS / TIERS
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--f-disp);font-weight:700;font-size:10.5px;
  letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px;border:1px solid var(--line-2);
  color:var(--ash);background:var(--ink-850);line-height:1;}
.badge.blood{color:#fff;background:linear-gradient(180deg,var(--blood-bright),var(--blood));border-color:#641009;}
.badge.gold{color:#1a1208;background:linear-gradient(180deg,#d9b35e,#a07f33);border-color:#6e571f;}
.badge.green{color:var(--green-bright);background:rgba(116,164,68,.14);border-color:rgba(116,164,68,.5);}
.badge.steel{color:var(--steel-bright);background:rgba(125,139,148,.14);border-color:rgba(125,139,148,.5);}
.badge.ghost{color:var(--ash);}
.tier{display:inline-grid;place-items:center;min-width:24px;height:20px;padding:0 5px;border-radius:4px;
  font-family:var(--f-mono);font-weight:700;font-size:11px;color:var(--ember);background:var(--ink-850);
  border:1px solid var(--line-2);}
.tier.t6{color:var(--gold);border-color:var(--gold-dim);background:rgba(203,165,86,.1);}
/* faction dots */
.fac{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--bone-dim);}
.fac::before{content:"";width:8px;height:8px;border-radius:50%;}
.fac.undiv::before{background:#c9a44c;}
.fac.khorne::before{background:#cf2b22;}
.fac.nurgle::before{background:#8aa53a;}
.fac.tzeentch::before{background:#4a82c4;}
.fac.slaanesh::before{background:#c46bb0;}

/* role chips */
.role{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-disp);font-weight:700;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:4px;}
.role.tank{color:var(--steel-bright);background:rgba(125,139,148,.16);border:1px solid rgba(125,139,148,.5);}
.role.dps{color:#fff;background:linear-gradient(180deg,rgba(207,43,34,.4),rgba(138,20,16,.3));
  border:1px solid rgba(207,43,34,.55);}

/* ============================================================
   STAT BLOCKS
   ============================================================ */
.stats{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.stat{background:var(--panel);padding:12px 14px;}
.stat .k{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ash);font-weight:600;
  display:flex;align-items:center;gap:5px;}
.stat .v{font-family:var(--f-mono);font-weight:700;font-size:20px;color:var(--bone);margin-top:5px;line-height:1;
  letter-spacing:-.02em;}
.stat .v small{font-size:12px;color:var(--ash);font-weight:500;}
.stat .v.off{color:var(--blood-bright);}.stat .v.dur{color:var(--steel-bright);}
.stat .v.good{color:var(--green-bright);}.stat .v.gold{color:var(--gold);}
.stat .d{font-size:11px;color:var(--ash);margin-top:4px;font-family:var(--f-mono);}
.stat .d.up{color:var(--green-bright);}.stat .d.dn{color:var(--blood-bright);}

/* ============================================================
   TABLES
   ============================================================ */
.dtable{width:100%;border-collapse:collapse;font-size:13px;}
.dtable th{font-family:var(--f-disp);font-weight:700;font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);text-align:left;padding:10px 12px;background:var(--ink-850);border-bottom:1px solid var(--line);
  position:sticky;top:0;white-space:nowrap;}
.dtable th.r,.dtable td.r{text-align:right;}
.dtable td{padding:11px 12px;border-bottom:1px solid rgba(58,42,32,.55);color:var(--bone-dim);vertical-align:middle;}
.dtable tr:last-child td{border-bottom:none;}
.dtable tbody tr:hover{background:rgba(220,143,51,.04);}
.dtable td .num{color:var(--bone);}
.dtable .muted{color:var(--ash);}

/* ============================================================
   PROGRESS BARS
   ============================================================ */
.bar{height:8px;border-radius:99px;background:var(--ink-850);border:1px solid var(--line);overflow:hidden;}
.bar .fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blood),var(--blood-bright),var(--ember));}
.bar.green .fill{background:linear-gradient(90deg,#3f5e28,var(--green),var(--green-bright));}
.bar.steel .fill{background:linear-gradient(90deg,#46545c,var(--steel),var(--steel-bright));}
.blbl{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;text-transform:uppercase;
  letter-spacing:.08em;color:var(--ash);margin-bottom:6px;font-weight:600;}
.blbl .num{color:var(--bone);font-size:12.5px;}

/* ============================================================
   VERDICT / ROUNDS
   ============================================================ */
.verdict{position:relative;text-align:center;padding:26px 20px;border-radius:var(--r);border:1px solid var(--line);
  overflow:hidden;}
.verdict.win{background:linear-gradient(180deg,rgba(116,164,68,.2),rgba(116,164,68,.04));border-color:#3f5e28;}
.verdict.lose{background:linear-gradient(180deg,rgba(207,43,34,.24),rgba(138,20,16,.06));border-color:#641009;}
.verdict .vlbl{font-family:var(--f-disp);font-weight:700;font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ash);}
.verdict .vbig{font-family:var(--f-disp);font-weight:800;font-size:38px;letter-spacing:.03em;text-transform:uppercase;
  margin-top:6px;line-height:1;}
.verdict.win .vbig{color:var(--green-bright);text-shadow:0 0 26px rgba(116,164,68,.5);}
.verdict.lose .vbig{color:var(--blood-bright);text-shadow:0 0 26px var(--blood-glow);}
.verdict .vsub{margin-top:9px;font-size:14px;color:var(--bone-dim);}
.round{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);}
.round-h{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--line);
  font-family:var(--f-disp);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ember);}
.round-h .rn{width:22px;height:22px;border-radius:5px;display:grid;place-items:center;background:rgba(207,43,34,.14);
  border:1px solid rgba(207,43,34,.4);color:var(--blood-bright);font-family:var(--f-mono);font-size:12px;}
.rrow{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;font-size:13px;
  border-bottom:1px dotted rgba(58,42,32,.6);}
.rrow:last-child{border-bottom:none;}
.rrow .rl{color:var(--ash);display:flex;align-items:center;gap:8px;}
.dmg{color:var(--blood-bright);}.durc{color:var(--steel-bright);}

/* ============================================================
   EMPTY / LOADING / MISC
   ============================================================ */
.empty{text-align:center;padding:46px 24px;color:var(--ash);}
.empty .ei{width:60px;height:60px;margin:0 auto 16px;border-radius:12px;display:grid;place-items:center;
  background:var(--ink-850);border:1px solid var(--line);color:var(--ash-dim);}
.empty .ei svg{width:30px;height:30px;}
.empty h3{color:var(--bone-dim);font-size:18px;margin-bottom:6px;}
.empty p{font-size:13.5px;max-width:360px;margin:0 auto;line-height:1.6;}
.skel{background:linear-gradient(90deg,var(--panel) 25%,var(--panel-3) 50%,var(--panel) 75%);
  background-size:200% 100%;animation:sk 1.3s infinite;border-radius:var(--r-sm);}
@keyframes sk{to{background-position:-200% 0;}}
.spin{width:34px;height:34px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--ember);
  animation:sp .8s linear infinite;}@keyframes sp{to{transform:rotate(360deg);}}
.alert{display:flex;gap:11px;padding:12px 14px;border-radius:var(--r-sm);font-size:13px;line-height:1.5;align-items:flex-start;}
.alert svg{width:17px;height:17px;flex:none;margin-top:1px;}
.alert.warn{background:rgba(207,43,34,.1);border:1px solid #5c2018;color:var(--ember);}
.alert.info{background:rgba(125,139,148,.1);border:1px solid rgba(125,139,148,.4);color:var(--steel-bright);}
.alert.good{background:rgba(116,164,68,.1);border:1px solid rgba(116,164,68,.4);color:var(--green-bright);}
.alert b{color:var(--bone);}

/* presets / scroll */
.scroll-x{overflow-x:auto;}
.tag{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:99px;font-size:12px;
  background:var(--ink-850);border:1px solid var(--line);color:var(--bone-dim);cursor:pointer;}
.tag:hover{border-color:var(--line-2);color:var(--bone);}
.tag.on{background:rgba(220,143,51,.12);border-color:var(--ember);color:var(--ember);}
.kbd{font-family:var(--f-mono);font-size:11px;background:var(--ink-850);border:1px solid var(--line-2);
  border-bottom-width:2px;border-radius:4px;padding:2px 6px;color:var(--bone-dim);}
.sect{font-family:var(--f-disp);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);display:flex;align-items:center;gap:10px;margin:0 0 12px;}
.sect::after{content:"";flex:1;height:1px;background:var(--line);}
