:root{
  --bg:#16151c; --panel:#211f29; --panel2:#2a2833; --line:#3a3744;
  --pink:#ff66aa; --pink2:#ff8ec1; --text:#ece9f3; --muted:#9c97ad;
  --accent:#7d6cff; --good:#6ee7a8; --warn:#ffcf6e;
}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(180deg,#1b1922,#141219);color:var(--text);
  font:15px/1.5 "Segoe UI",system-ui,sans-serif;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:var(--pink2)}
code{background:#0d0c12;padding:1px 5px;border-radius:5px;font-size:.9em}
header{padding:32px 24px 8px;max-width:1180px;margin:0 auto}
h1{margin:0 0 4px;font-size:26px;letter-spacing:.2px}
h1 .k{color:var(--pink)}
.sub{color:var(--muted);margin:0 0 18px}
main{max-width:1180px;margin:0 auto;padding:0 24px 80px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:16px 0}
button{font:inherit;cursor:pointer;border:0;border-radius:10px;padding:11px 18px;color:#fff;
  background:linear-gradient(135deg,var(--pink),#d94f8f);font-weight:600;transition:.15s transform}
button:hover{transform:translateY(-1px)}
button.alt{background:var(--panel2);border:1px solid var(--line);color:var(--text);font-weight:500}
button:disabled{opacity:.5;cursor:default;transform:none}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hint{color:var(--muted);font-size:13px}
#status{margin-top:12px;font-size:14px;color:var(--muted);white-space:pre-wrap}
#status .err{color:#ff7b7b}
.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.stat .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.8px}
.stat .val{font-size:28px;font-weight:700;margin-top:4px}
.stat .val.sm{font-size:18px}
.stat .extra{color:var(--muted);font-size:13px;margin-top:4px}
h2{font-size:18px;margin:30px 0 4px}
h2 .muted{color:var(--muted);font-weight:400;font-size:14px}
canvas{width:100%;display:block;border-radius:10px}
.chartwrap{position:relative}
/* lock the rendered height so HiDPI buffer scaling can't blow the chart up */
.chartwrap canvas{height:300px;max-height:42vh}
.tabs{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:12px 0 2px}
.tabgroup{display:flex;gap:4px;align-items:center;background:var(--panel);
  border:1px solid var(--line);border-radius:11px;padding:4px}
.tabgroup .lbl{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.7px;padding:0 8px;white-space:nowrap}
/* player tabs scroll sideways instead of wrapping when there are many names */
.tabgroup.scrollx{flex:1 1 100%;max-width:100%;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:thin}
.tabgroup.scrollx .lbl{position:sticky;left:0;background:var(--panel);z-index:1}
.tabgroup.scrollx::-webkit-scrollbar{height:7px}
.tabgroup.scrollx::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}
.tab{padding:6px 13px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--muted);
  user-select:none;white-space:nowrap;transition:.12s}
.tab .hint{font-size:11px;opacity:.7}
.tab.active{background:linear-gradient(135deg,var(--pink),#d94f8f);color:#fff;font-weight:600}
.tab.active .hint{color:#fff;opacity:.85}
.tab:hover:not(.active){color:var(--text);background:var(--panel2)}
/* PP mode: prominent segmented control so the ranked/all switch stands out */
.tabgroup.seg{background:var(--panel2);border-color:var(--pink);box-shadow:0 0 0 1px var(--pink) inset}
.tabgroup.seg .lbl{color:var(--pink2)}
.tabgroup.seg .tab{padding:7px 16px;font-size:14px;font-weight:600}

/* grade distribution bar */
#gradeBar{padding:14px 18px}
.gradebar{display:flex;height:14px;border-radius:8px;overflow:hidden;background:var(--panel2);border:1px solid var(--line)}
.gradebar .seg{min-width:2px}
.seg.g-X{background:#ffd24d}.seg.g-SS{background:#ffe9b0}.seg.g-S{background:#8fd0ff}
.seg.g-A{background:#6ee7a8}.seg.g-low{background:#ff9d9d}
.gradekeys{display:flex;gap:20px;flex-wrap:wrap;margin-top:12px;font-size:13.5px;color:var(--muted)}
.gkey b{margin-right:5px}
.g-SS{color:#ffe9b0;background:#ffe9b018}
.g-low{color:#ff9d9d;background:#ff9d9d18}
.tip{position:absolute;pointer-events:none;background:#0d0c12;border:1px solid var(--line);
  border-radius:8px;padding:7px 10px;font-size:12px;color:var(--text);opacity:0;transition:opacity .08s;
  transform:translate(-50%,-115%);white-space:nowrap;z-index:5;box-shadow:0 6px 20px #0008}
details{margin:10px 0}
summary{cursor:pointer;color:var(--pink2);font-weight:600;user-select:none}
summary::marker{color:var(--muted)}
table{border-collapse:collapse;width:100%;font-size:13px;margin-top:10px}
th,td{padding:7px 9px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
.mapcell{display:inline-block;max-width:360px;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;vertical-align:middle}
th:first-child,td:first-child,th.l,td.l{text-align:left}
th{position:sticky;top:0;background:var(--panel2);cursor:pointer;color:var(--muted);font-weight:600}
th:hover{color:var(--text)}
tbody tr:hover{background:#ffffff08}
.scroll{max-height:520px;overflow:auto;border:1px solid var(--line);border-radius:10px}
.grade{font-weight:700;padding:1px 7px;border-radius:6px;font-size:12px}
.g-X,.g-XH{color:#ffe08a;background:#ffe08a18}
.g-S,.g-SH{color:#8fd0ff;background:#8fd0ff18}
.g-A{color:#6ee7a8;background:#6ee7a818}
.g-B{color:#c9a0ff;background:#c9a0ff18}
.g-C,.g-D{color:#ff9d9d;background:#ff9d9d18}
.pill{display:inline-block;background:var(--panel2);border:1px solid var(--line);border-radius:20px;
  padding:2px 9px;font-size:11px;color:var(--muted);margin:0 0 0 6px}
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:8px 0}
.toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.toggle input{accent-color:var(--pink);cursor:pointer}
input[type=search]{background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:8px 11px;font:inherit;min-width:220px}
pre.json{background:#0d0c12;border:1px solid var(--line);border-radius:8px;padding:10px;
  font-size:12px;max-height:340px;overflow:auto;color:#cfd6e6;white-space:pre-wrap;word-break:break-word}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:6px 2px}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}
.legend.toggles span.clickable{cursor:pointer;user-select:none;transition:opacity .12s,color .12s}
.legend.toggles span.clickable:hover{color:var(--text)}
.legend.toggles span.off{opacity:.4;text-decoration:line-through}
.legend .legend-hint{font-style:italic;opacity:.7;margin-left:auto}
.note{font-size:12.5px;color:var(--muted);background:#ffcf6e10;border:1px solid #ffcf6e30;
  border-radius:8px;padding:8px 11px;margin-top:8px}
#app{display:none}
footer{max-width:1180px;margin:0 auto;padding:24px;color:var(--muted);font-size:12.5px;
  border-top:1px solid var(--line)}
footer p{margin:4px 0}
footer a{color:var(--pink2)}
