/* Balance combat analytics — dashboard styling. Dark by default; .light flips it. */
:root {
  --bg: #0b0e14; --panel: #141925; --panel2: #1b2233; --edge: #283145;
  --fg: #e7ecf3; --muted: #9aa7bd; --accent: #5aa9e6; --gold: #f0cf85;
  --good: #6ad08a; --bad: #e6736e; --warn: #e6b864;
}
.light {
  --bg: #f4f6fb; --panel: #ffffff; --panel2: #eef2f9; --edge: #d4dbe8;
  --fg: #1a2030; --muted: #5a6577; --accent: #2f6fb0; --gold: #9a7b1f;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--fg);
  font-family: "Segoe UI", Roboto, Arial, sans-serif; font-size: 14px;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
header.topbar {
  display: flex; align-items: center; gap: 14px; padding: 10px 18px;
  background: var(--panel); border-bottom: 1px solid var(--edge); flex-wrap: wrap;
}
header.topbar h1 { font-size: 16px; margin: 0; color: var(--gold); white-space: nowrap; }
.spacer { flex: 1; }
.pill {
  background: var(--panel2); border: 1px solid var(--edge); color: var(--muted);
  border-radius: 999px; padding: 3px 10px; font-size: 12px;
}
.pill.live { color: var(--good); border-color: var(--good); }
.pill.closed { color: var(--muted); }

button, select, input {
  background: var(--panel2); color: var(--fg); border: 1px solid var(--edge);
  border-radius: 6px; padding: 5px 9px; font-size: 13px; font-family: inherit;
}
button { cursor: pointer; }
button:hover { border-color: var(--accent); }
button.primary { background: var(--accent); color: #06121f; border-color: var(--accent); font-weight: 600; }
label.ctl { display: inline-flex; align-items: center; gap: 5px; color: var(--muted); font-size: 12px; }

.controlbar {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  padding: 10px 18px; background: var(--panel); border-bottom: 1px solid var(--edge);
}
.cards { display: flex; gap: 10px; flex-wrap: wrap; padding: 14px 18px 0; }
.card {
  background: var(--panel); border: 1px solid var(--edge); border-radius: 8px;
  padding: 10px 14px; min-width: 120px; cursor: pointer;
}
.card .k { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.card .v { font-size: 22px; font-weight: 700; margin-top: 2px; }

.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(440px, 1fr)); gap: 14px; padding: 14px 18px; }
.widget { background: var(--panel); border: 1px solid var(--edge); border-radius: 8px; display: flex; flex-direction: column; }
.widget .wctl { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; padding: 8px 10px; border-bottom: 1px solid var(--edge); }
.widget .wctl .title { font-weight: 600; color: var(--gold); margin-right: auto; }
.widget .chart { width: 100%; height: 320px; }
.widget.wide { grid-column: 1 / -1; }
.widget.wide .chart { height: 360px; }
.widget .x { color: var(--muted); border: none; background: none; font-size: 16px; padding: 0 4px; }

.drawer {
  position: fixed; right: 0; top: 0; height: 100vh; width: min(680px, 92vw);
  background: var(--panel); border-left: 1px solid var(--edge); box-shadow: -8px 0 24px #0008;
  transform: translateX(100%); transition: transform .18s ease; overflow: auto; z-index: 50;
}
.drawer.open { transform: translateX(0); }
.drawer h3 { margin: 0; padding: 12px 16px; border-bottom: 1px solid var(--edge); color: var(--gold); display: flex; }
.drawer .body { padding: 10px 16px; }
table.rows { width: 100%; border-collapse: collapse; font-size: 12px; }
table.rows th, table.rows td { text-align: left; padding: 4px 6px; border-bottom: 1px solid var(--edge); white-space: nowrap; }
table.rows th { color: var(--muted); position: sticky; top: 0; background: var(--panel); }
.tag { padding: 1px 6px; border-radius: 4px; font-size: 11px; }
.tag.crit { background: #4a2; color: #fff; } .tag.miss { background: #555; color: #ccc; }
.tag.block { background: #36c; color: #fff; } .tag.dodge { background: #a73; color: #fff; }
.tag.heal { background: #2a7; color: #fff; } .tag.hit { background: var(--panel2); color: var(--fg); }

.center { max-width: 460px; margin: 12vh auto; text-align: center; padding: 0 16px; }
.center h1 { color: var(--gold); }
.center .codein { font-size: 28px; letter-spacing: 8px; text-align: center; width: 220px; }
.note { color: var(--muted); font-size: 12px; }
.chips { display: inline-flex; gap: 5px; flex-wrap: wrap; }
.chip { background: var(--panel2); border: 1px solid var(--edge); border-radius: 999px; padding: 2px 8px; font-size: 12px; cursor: pointer; }
.chip.on { background: var(--accent); color: #06121f; border-color: var(--accent); }
.toast { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%); background: var(--panel2); border: 1px solid var(--accent); border-radius: 6px; padding: 8px 14px; z-index: 80; }
