:root{--bg:#15171c;--panel:#1e2128;--line:#2c313c;--text:#e7e9ee;--sub:#8a92a6;--accent:#5aa6ff;--bad:#ff5d6c;--live:#3ddc84}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 -apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text)}
header{padding:18px 24px;border-bottom:1px solid var(--line)}
header h1{margin:0 0 4px;font-size:18px}
header .meta{color:var(--sub);font-size:13px}
header a{color:var(--accent);text-decoration:none}
nav{display:flex;gap:4px;padding:0 24px;border-bottom:1px solid var(--line);background:var(--panel);position:sticky;top:0;z-index:2}
nav button{background:none;border:none;color:var(--sub);padding:12px 16px;cursor:pointer;font-size:14px;border-bottom:2px solid transparent}
nav button.on{color:var(--text);border-bottom-color:var(--accent)}
.tab{display:none;padding:20px 24px}
.tab.active{display:block}
.note{color:var(--sub);margin:0 0 16px;max-width:760px}
.toolbar{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.toolbar button{background:var(--accent);border:none;color:#08101f;font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer}
table{border-collapse:collapse;width:100%;max-width:900px}
td,th{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:middle;text-align:left}
th{color:var(--sub);font-weight:500;font-size:12px}
.crop{width:76px;height:76px;border-radius:8px;display:block;background:#0008;image-rendering:auto}
.matchwrap{display:flex;align-items:center;gap:10px}
.matchmeta{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.idx{font-variant-numeric:tabular-nums;color:var(--sub);white-space:nowrap}
.sub{color:var(--sub);font-size:12px}
.arrow{color:var(--sub);font-size:20px;text-align:center}
.clbadge{display:inline-block;margin-top:4px;padding:1px 8px;border-radius:10px;color:#0b0d11;font-weight:600;font-size:12px}
.mm{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:6px 12px;border-radius:8px;cursor:pointer;white-space:nowrap}
.mm:hover{border-color:var(--bad)}
tr.mismatch{background:rgba(255,93,108,.10)}
tr.mismatch .mm{border-color:var(--bad);color:var(--bad)}
.tag{margin-left:6px;font-size:12px;color:var(--text);opacity:.9}
/* B1 mark-used + show-used reveal */
.used-row{display:none}
body.show-used .used-row{display:table-row;opacity:.5}
.use{background:var(--panel);border:1px solid var(--line);color:var(--sub);padding:6px 12px;border-radius:8px;cursor:pointer;white-space:nowrap}
.use:hover{border-color:var(--accent);color:var(--text)}
.use.on{border-color:#ffce4d;color:#ffce4d}
/* B7 star bookmark */
.star{background:none;border:none;color:var(--line);cursor:pointer;font-size:15px;padding:0 6px 0 0;line-height:1}
.star:hover{color:var(--sub)}
.star.on{color:#ffce4d}
tr.starred{background:rgba(255,206,77,.08)}
.idx .ifn{font-variant-numeric:tabular-nums}
/* B6 qty badge + jump */
.qty{margin-left:8px;color:var(--accent);font-size:12px;cursor:pointer;white-space:nowrap}
.qty:hover{text-decoration:underline}
/* B2 inline tag editor */
.tagedit{cursor:pointer}
.tagadd{color:var(--sub);font-size:12px;opacity:.6;margin-left:6px}
.tagedit:hover .tagadd{opacity:1;text-decoration:underline}
/* B3 qty-0 rows + toggle */
.zerorow{display:none}
body.show-zeros .zerorow{display:table-row;opacity:.6}
.zerotoggle,.showused{color:var(--sub);font-size:13px;cursor:pointer;user-select:none;display:inline-flex;align-items:center;gap:6px}
.zerotoggle{margin-bottom:12px}
/* B4 fuse */
.fuse{background:none;border:1px solid var(--line);color:var(--sub);font-size:11px;padding:2px 8px;border-radius:8px;cursor:pointer;margin-left:8px}
.fuse:hover{border-color:var(--accent);color:var(--text)}
.fuse.armed{border-color:#ffce4d;color:#ffce4d}
tr.fusearm{background:rgba(255,206,77,.10)}
/* B5 accordion */
.exp{background:none;border:1px solid var(--line);color:var(--sub);font-size:11px;padding:0 6px;border-radius:6px;cursor:pointer;margin-left:6px}
.exp:hover{border-color:var(--accent);color:var(--text)}
tr.qexp>td{background:#0c0e12;border-bottom:1px solid var(--line)}
.exphdr{color:var(--sub);margin-bottom:10px}
.exphdr .reasel{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:4px 6px}
.instgrid{display:flex;flex-wrap:wrap;gap:10px}
.inst{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px;border:1px solid var(--line);border-radius:8px;cursor:default;width:84px}
.inst.iused{opacity:.45}
.inst .instlbl{color:var(--accent);font-size:11px;cursor:pointer}
.inst .instlbl:hover{text-decoration:underline}
.inst input{cursor:pointer}
/* cross-tab jump flash */
.flash{animation:flashbg 1.5s ease-out}
@keyframes flashbg{from{background:rgba(90,166,255,.4)}to{background:transparent}}
.pos{display:block;margin-top:6px;color:var(--accent);font-weight:600;font-size:12px}
.num{font-variant-numeric:tabular-nums;font-size:18px;font-weight:600}
.pct{color:var(--sub)}
.barcell{width:40%}
.bar{height:14px;border-radius:7px;min-width:2px}
.cycle{margin-bottom:18px}
.cyclehdr{font-weight:600;margin-bottom:12px;font-size:15px}
.cyclestrip{display:flex;gap:12px;flex-wrap:wrap}
.slot{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;border:1px solid var(--line);border-radius:12px;background:var(--panel)}
.slot.current{border-color:var(--accent);box-shadow:0 0 0 2px rgba(90,166,255,.35)}
.slotnum{font-variant-numeric:tabular-nums;color:var(--sub);font-size:12px}
.slot .here{position:absolute;top:-9px;right:-6px;background:var(--accent);color:#08101f;font-size:11px;font-weight:700;padding:1px 7px;border-radius:8px;white-space:nowrap}
details.allscans{margin-top:4px}
details.allscans>summary{cursor:pointer;color:var(--accent);padding:10px 0;font-weight:600;list-style:revert}
.cyclesep td{background:var(--panel);color:var(--accent);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* hosted: session list landing */
.sessionlist{padding:20px 24px;max-width:680px}
.sessionlist a{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;margin-bottom:10px;border:1px solid var(--line);border-radius:12px;background:var(--panel);color:var(--text);text-decoration:none}
.sessionlist a:hover{border-color:var(--accent)}
.sessionlist .sname{font-weight:600}
.sessionlist .empty{color:var(--sub)}
/* hosted: sync state in header */
.sync{font-size:12px;color:var(--sub)}
.sync.err{color:var(--bad)}

/* ── Responsive: phone / narrow viewport ────────────────────────────────────── */
@media (max-width:640px){
  header{padding:14px 16px}
  header h1{font-size:16px}
  header .meta{font-size:12px}
  nav{padding:0 6px}
  nav button{padding:11px 10px;font-size:13px}
  .tab{padding:14px 10px}
  .note{margin-bottom:12px;font-size:13px}
  .toolbar{flex-wrap:wrap;gap:10px}
  table{font-size:13px}
  td,th{padding:6px 4px}
  .crop{width:50px;height:50px}
  .arrow{display:none}
  #review thead th:nth-child(3){display:none}
  .matchwrap{gap:6px}
  .matchmeta{gap:2px}
  .clbadge{font-size:11px;padding:1px 6px}
  .tag{margin-left:0;display:block}
  .mm,.use{padding:5px 8px;font-size:12px}
  .act{white-space:normal}
  .qty{margin-left:0;display:inline-block}
  .num{font-size:16px}
  .barcell{width:22%}
  .bar{height:10px}
  .inst{width:72px}
  .instgrid{gap:8px}
  .cyclestrip{gap:8px}
  .slot{padding:8px}
  .exphdr .reasel{max-width:46vw}
}
