:root {
  /* OPINDEX palette */
  --bg:   #0F1216;
  --bg2:  #1B1F26;
  --bg3:  #232A33;
  --bg4:  #2A3240;
  --border:  rgba(46,54,66,0.8);
  --border2: #2E3642;
  --text:  #E6E8EB;
  --muted: #7E8794;
  --muted2:#B7BEC8;
  /* Primary accent: Signal Red */
  --accent:     #C43C3C;
  --accent-dim: rgba(196,60,60,0.12);
  /* ATK / DEF sides */
  --atk:     #C43C3C;
  --atk-dim: rgba(196,60,60,0.12);
  --def:     #B7BEC8;
  --def-dim: rgba(183,190,200,0.10);
  /* Semantic */
  --green:     #3FAE6E;
  --green-dim: rgba(63,174,110,0.12);
  --red:       #C43C3C;
  --red-dim:   rgba(196,60,60,0.12);
  --amber:     #D8A23A;
  --amber-dim: rgba(216,162,58,0.12);
  --purple:    #7E8794;
  --purple-dim:rgba(126,135,148,0.12);
  /* Radius: OPINDEX = hard edges */
  --r:    6px;
  --r-sm: 6px;
  --r-xs: 4px;
}
* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; }
body { font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif; background: var(--bg); color: var(--text); font-size: 15px; overscroll-behavior: none; letter-spacing: 0.2px; }

/* OVERLAY */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.85); display: flex; align-items: center; justify-content: center; z-index: 300; padding: 16px; overflow-y: auto; }
.modal { background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--r); padding: 28px 22px; width: 100%; max-width: 420px; }
.modal-title { font-size: 20px; font-weight: 800; margin-bottom: 4px; }
.modal-sub { font-size: 13px; color: var(--muted2); margin-bottom: 22px; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--muted2); margin-bottom: 6px; }
.inp { width: 100%; background: var(--bg3); border: 1px solid var(--border2); border-radius: var(--r-sm); padding: 11px 12px; color: var(--text); font-size: 15px; outline: none; transition: border-color 0.15s; }
.inp:focus { border-color: var(--accent); }
.inp::placeholder { color: var(--muted); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tsec { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.07em; margin: 14px 0 8px; }
.tsec.my { color: var(--accent); }
.tsec.enemy { color: var(--red); }
.mode-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin-bottom: 18px; }
.mode-btn { flex: 1; padding: 11px; border-radius: var(--r-sm); border: 1.5px solid var(--border2); background: var(--bg3); color: var(--muted2); font-size: 14px; font-weight: 700; cursor: pointer; transition: all 0.15s; }
.mode-btn.on-solo { border-color: var(--border2); background: var(--bg4); color: var(--text); }
.mode-btn.on-player { border-color: rgba(196,60,60,0.6); background: rgba(196,60,60,0.12); color: var(--text); }
.mode-btn.on-obs { border-color: rgba(216,162,58,0.5); background: rgba(216,162,58,0.10); color: var(--amber); }
.mode-btn.on-solo { border-color: var(--border2); background: var(--bg4); color: var(--text); }
.btn-main { width: 100%; padding: 14px; border-radius: var(--r-sm); border: 1px solid rgba(196,60,60,0.6); background: rgba(196,60,60,0.12); color: var(--text); font-size: 15px; font-weight: 700; cursor: pointer; margin-top: 20px; letter-spacing: 0.4px; }
.btn-main:active { opacity: 0.85; }

/* HEADER */
header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--bg); border-bottom: 1px solid var(--border2); position: sticky; top: 0; z-index: 100; gap: 10px; }
.h-left { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.logo { font-size: 13px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase; color: #8b8e84; }
.logo span { color: #8b8e84; }
.logo .logo-accent { color: #6d1e1e; }
.live-pill { display: flex; align-items: center; gap: 4px; background: rgba(196,60,60,0.10); border: 1px solid rgba(196,60,60,0.35); border-radius: 3px; padding: 3px 8px; font-size: 10px; font-weight: 700; color: var(--red); text-transform: uppercase; letter-spacing: 0.6px; }
.live-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--red); animation: blink 1.4s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.2} }
.wip-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 14px;
  background: rgba(216,162,58,0.10);
  border-bottom: 1px solid var(--amber);
  color: var(--amber);
  font-family: "Share Tech Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 10px;
  letter-spacing: 0.6px;
  line-height: 1.4;
}
.wip-banner.hidden { display: none; }
.wip-icon { flex-shrink: 0; opacity: 0.9; }
.wip-banner span { flex: 1; }
.wip-dismiss {
  background: transparent;
  border: none;
  color: var(--amber);
  opacity: 0.5;
  cursor: pointer;
  font-size: 11px;
  padding: 2px 4px;
  line-height: 1;
  flex-shrink: 0;
  transition: opacity 0.1s;
}
.wip-dismiss:hover { opacity: 1; }
.h-center { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 1; min-width: 0; }
.score-row { display: flex; align-items: center; gap: 8px; }
.score-team { font-size: 10px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; }
.score-team.my { color: var(--text); padding: 2px 6px; border: 1px solid rgba(196,60,60,0.4); border-radius: 3px; }
.score-team.en { color: var(--muted); padding: 2px 6px; border: 1px solid var(--border2); border-radius: 3px; }
.score-nums { display: flex; align-items: center; gap: 5px; font-size: 20px; font-weight: 900; }
.score-sep { color: var(--muted); font-size: 14px; font-weight: 400; }
.sadj { display: flex; align-items: center; gap: 3px; }
.sadj-btn { width: 24px; height: 24px; border-radius: var(--r-xs); border: 1px solid var(--border2); background: var(--bg3); color: var(--muted2); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.sadj-btn:active { background: var(--bg4); }
.r-row { display: flex; align-items: center; gap: 6px; }
.r-badge { background: var(--bg3); border: 1px solid var(--border2); border-radius: var(--r-xs); padding: 2px 8px; font-size: 11px; font-weight: 800; }
.rdots { display: flex; gap: 3px; }
.rdot { width: 7px; height: 7px; border-radius: 2px; background: var(--bg4); border: 1px solid var(--border); }
.rdot.cur { background: var(--amber); border-color: var(--amber); animation: blink 1s infinite; }
.h-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.ctx-tag { font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: var(--r-xs); border: 1px solid var(--border2); }
.ctx-tag.player { color: var(--muted2); border-color: var(--border2); background: transparent; }
.ctx-tag.obs { color: var(--amber); border-color: rgba(240,160,48,0.3); background: var(--amber-dim); }
.ctx-tag.solo { color: var(--green); border-color: rgba(62,201,126,0.3); background: var(--green-dim); }
.new-btn { background: none; border: 1px solid var(--border2); border-radius: var(--r-xs); padding: 4px 9px; color: var(--muted2); font-size: 11px; font-weight: 700; cursor: pointer; }
.new-btn:hover { background: var(--bg3); }
.end-btn { background: none; border: 1px solid rgba(224,85,85,0.35); border-radius: var(--r-xs); padding: 4px 9px; color: var(--red); font-size: 11px; font-weight: 700; cursor: pointer; transition: background 0.1s; }
.end-btn:hover { background: var(--red-dim); }
.end-btn.confirm { background: var(--red-dim); border-color: var(--red); }
.reset-btn { background: none; border: 1px solid var(--border2); border-radius: var(--r-xs); padding: 4px 8px; color: var(--muted); font-size: 14px; line-height: 1; cursor: pointer; transition: all 0.1s; }
.reset-btn:hover { color: var(--red); border-color: rgba(224,85,85,0.35); background: var(--red-dim); }
.reset-btn.confirm { color: var(--red); border-color: var(--red); background: var(--red-dim); font-size: 11px; font-weight: 700; padding: 4px 9px; }

/* TABS */
.tabs { display: flex; background: var(--bg); border-bottom: 1px solid var(--border2); padding: 0 14px; }
.tab { padding: 11px 14px; font-size: 12px; font-weight: 600; color: var(--muted); cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.12s; white-space: nowrap; letter-spacing: 0.4px; text-transform: uppercase; }
.tab:hover { color: var(--muted2); }
.tab.active { color: var(--text); border-bottom-color: var(--red); }

/* VIEWS */
.view { display: none; padding: 14px; max-width: 780px; margin: 0 auto; }
.view.active { display: block; }

/* ENTRY VIEW ─ player strip */
.p-strip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; margin-bottom: 12px; }
.ps-btn { background: var(--bg3); border: 2px solid var(--border); border-radius: var(--r-sm); padding: 8px 4px 10px; cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 4px; transition: all 0.1s; position: relative; }
.ps-btn:active { transform: scale(0.96); }
.ps-av { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 900; }
.ps-name { font-size: 10px; font-weight: 700; color: var(--muted2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; padding: 0 2px; }
.ps-btn.sel { border-color: var(--accent); background: var(--accent-dim); }
.ps-btn.sel .ps-name { color: var(--text); }
.ps-btn.done { border-color: rgba(62,201,126,0.4); background: var(--green-dim); }
.ps-btn.done .ps-name { color: var(--green); }
.ps-pip { position: absolute; top: 4px; right: 4px; width: 7px; height: 7px; border-radius: 50%; background: var(--green); display: none; }
.ps-btn.done .ps-pip { display: block; }
.you-tag { position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%); font-size: 8px; font-weight: 900; color: var(--amber); text-transform: uppercase; letter-spacing: 0.04em; }

/* Round status */
.r-status { display: flex; align-items: center; justify-content: space-between; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 9px 12px; margin-bottom: 10px; }
.r-status-pips { display: flex; gap: 4px; }
.spip { width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 800; border: 1.5px solid var(--border2); color: var(--muted); background: var(--bg4); }
.spip.done { background: var(--green-dim); border-color: rgba(62,201,126,0.5); color: var(--green); }
.spip.me { border-color: var(--amber); color: var(--amber); }
.undo-btn { background: none; border: none; color: var(--muted); font-size: 12px; font-weight: 700; cursor: pointer; text-decoration: underline; text-underline-offset: 2px; }
.undo-btn:hover { color: var(--muted2); }

/* Observer notice */
.obs-bar { background: var(--amber-dim); border: 1px solid rgba(240,160,48,0.25); border-radius: var(--r-sm); padding: 7px 12px; font-size: 12px; color: var(--amber); font-weight: 700; margin-bottom: 10px; }

/* Side */
.side-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.side-btn { padding: 16px 10px; border-radius: var(--r); border: 2px solid var(--border); background: var(--bg3); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 17px; font-weight: 900; letter-spacing: 0.03em; color: var(--muted2); transition: all 0.1s; }
.side-btn:active { transform: scale(0.97); }
.side-btn.atk.on { border-color: var(--red); background: var(--red-dim); color: var(--text); }
.side-btn.def.on { border-color: var(--amber); background: rgba(216,162,58,0.12); color: var(--amber); }

/* Toggle grid */
.tog-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.tog { background: var(--bg3); border: 2px solid var(--border); border-radius: var(--r); padding: 14px 12px; cursor: pointer; display: flex; flex-direction: column; gap: 5px; min-height: 80px; transition: all 0.1s; -webkit-user-select: none; user-select: none; }
.tog:active { transform: scale(0.97); }
.tog-top { display: flex; align-items: center; justify-content: space-between; }
.tog-label { font-size: 15px; font-weight: 800; color: var(--text); }
.tog-dot { width: 11px; height: 11px; border-radius: 50%; background: var(--bg4); border: 1.5px solid var(--border2); transition: all 0.1s; }
.tog-sub { font-size: 11px; color: var(--muted); line-height: 1.3; }
/* on states */
.tog.on { border-color: var(--green); background: var(--green-dim); }
.tog.on .tog-dot { background: var(--green); border-color: var(--green); }
.tog[data-f="died"].on { border-color: var(--red); background: var(--red-dim); }
.tog[data-f="died"].on .tog-dot { background: var(--red); border-color: var(--red); }
.tog[data-f="clutch"].on { border-color: var(--amber); background: var(--amber-dim); }
.tog[data-f="clutch"].on .tog-dot { background: var(--amber); border-color: var(--amber); }

/* Kill counters */
.kc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 14px; }
.kc { background: var(--bg3); border: 2px solid var(--border); border-radius: var(--r); padding: 12px; }
.kc-label { font-size: 12px; font-weight: 800; color: var(--muted2); margin-bottom: 2px; }
.kc-sub { font-size: 10px; color: var(--muted); margin-bottom: 8px; }
.kc-ctrl { display: flex; align-items: center; justify-content: space-between; }
.kc-btn { width: 44px; height: 44px; border-radius: var(--r-sm); border: 1.5px solid var(--border2); background: var(--bg4); color: var(--text); font-size: 24px; font-weight: 300; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.kc-btn:active { transform: scale(0.92); background: var(--bg2); }
.kc-val { font-size: 30px; font-weight: 900; min-width: 40px; text-align: center; font-variant-numeric: tabular-nums; }

/* Win / Loss toggle */
.wl-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.wl-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 14px 10px; border-radius: var(--r); border: 2px solid var(--border); background: var(--bg3); cursor: pointer; transition: all 0.1s; -webkit-user-select: none; user-select: none; }
.wl-btn:active { transform: scale(0.97); }
.wl-icon { font-size: 22px; font-weight: 900; color: var(--muted); line-height: 1; }
.wl-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--muted); }
.wl-btn.win.on { border-color: var(--green); background: var(--green-dim); }
.wl-btn.win.on .wl-icon, .wl-btn.win.on .wl-label { color: var(--green); }
.wl-btn.loss.on { border-color: var(--red); background: var(--red-dim); }
.wl-btn.loss.on .wl-icon, .wl-btn.loss.on .wl-label { color: var(--red); }
body.mobile .wl-btn { padding: 18px 10px; }
body.mobile .wl-icon { font-size: 26px; }

/* Log button */
.log-btn { width: 100%; padding: 18px; border-radius: var(--r); border: 1px solid rgba(196,60,60,0.6); background: rgba(196,60,60,0.12); color: var(--text); font-size: 16px; font-weight: 700; cursor: pointer; letter-spacing: 0.4px; text-transform: uppercase; margin-bottom: 8px; transition: all 0.12s; }
.log-btn:hover { background: rgba(196,60,60,0.18); }
.log-btn:active { opacity: 0.9; }
.log-btn:disabled { background: var(--bg3); color: var(--muted); cursor: default; border-color: var(--border2); }

/* SCOREBOARD */
.hero-card { background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--r); padding: 16px; margin-bottom: 14px; }
.hero-top { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.hero-av { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 900; flex-shrink: 0; }
.hero-name { font-size: 18px; font-weight: 900; }
.hero-sub { font-size: 12px; color: var(--muted2); margin-top: 1px; }
.hero-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-bottom: 10px; }
@media(max-width:600px){ .hero-grid { grid-template-columns: repeat(3,1fr); } }
@media(max-width:380px){ .hero-grid { grid-template-columns: repeat(2,1fr); } }
.hstat { background: var(--bg3); border-radius: var(--r-sm); padding: 10px 12px; }
.hstat-l { font-size: 10px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.hstat-v { font-size: 20px; font-weight: 900; font-variant-numeric: tabular-nums; }
.hstat-v.g { color: var(--green); } .hstat-v.m { color: var(--amber); } .hstat-v.b { color: var(--red); }
.hstat-s { font-size: 10px; color: var(--muted); margin-top: 2px; }
.ir-bar { background: var(--bg3); border-radius: var(--r-sm); padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; }
.ir-bar-l { font-size: 12px; font-weight: 700; color: var(--muted2); }
.ir-bar-n { font-size: 11px; color: var(--muted); margin-top: 2px; }
.ir-big { font-size: 26px; font-weight: 900; }
.ir-big.g { color: var(--green); } .ir-big.m { color: var(--amber); } .ir-big.b { color: var(--red); }
.sec-head { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--muted); margin: 14px 0 8px; }
.t-table { width: 100%; border-collapse: collapse; font-size: 13px; table-layout: fixed; }
.t-table th { padding: 7px 10px; text-align: right; color: var(--muted); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid var(--border); white-space: nowrap; }
.t-table th:first-child { text-align: left; width: 32%; }
.t-table td { padding: 9px 10px; text-align: right; border-bottom: 1px solid var(--border); font-variant-numeric: tabular-nums; }
.t-table td:first-child { text-align: left; }
.t-table tr:last-child td { border-bottom: none; }
.t-table tr.hl td { background: rgba(196,60,60,0.05); }
.pnc { display: flex; align-items: center; gap: 7px; font-weight: 700; }
.pm-av { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 900; flex-shrink: 0; }
.irv { font-weight: 900; } .irv.g { color: var(--green); } .irv.m { color: var(--amber); } .irv.b { color: var(--red); }
.ir-bench { display:flex; flex-direction:column; align-items:flex-end; gap:3px; }
.ir-bench-bar-wrap { width:48px; height:4px; background:var(--bg4); border-radius:4px; overflow:hidden; }
.ir-bench-bar-fill { height:100%; border-radius:4px; transition:width 0.3s; }
.ir-bench-avg { font-size:9px; color:var(--muted); white-space:nowrap; }
.cb { display: inline-flex; align-items: center; justify-content: center; background: var(--amber-dim); border: 1px solid rgba(240,160,48,0.3); border-radius: 4px; padding: 1px 6px; font-size: 11px; font-weight: 900; color: var(--amber); }

/* HISTORY */
.h-filters { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.hf-btn { padding: 6px 12px; border-radius: 20px; border: 1px solid var(--border2); background: var(--bg3); color: var(--muted2); font-size: 12px; font-weight: 700; cursor: pointer; }
.hf-btn.on { border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }
.h-round { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 8px; overflow: hidden; }
.h-rhead { display: flex; align-items: center; justify-content: space-between; padding: 8px 14px; background: var(--bg3); border-bottom: 1px solid var(--border); }
.h-rnum { font-size: 12px; font-weight: 800; color: var(--muted2); }
.h-rpips { display: flex; gap: 3px; }
.hpip { width: 18px; height: 18px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 8px; font-weight: 900; }
.hpip.done { background: var(--green-dim); color: var(--green); border: 1px solid rgba(62,201,126,0.3); }
.hpip.pend { background: var(--bg4); color: var(--muted); border: 1px solid var(--border); }
.h-colhead { display: grid; grid-template-columns: 110px repeat(9,1fr) 28px; }
.h-row { display: grid; grid-template-columns: 110px repeat(9,1fr) 28px; border-top: 1px solid var(--border); }
.h-row.me { background: rgba(79,142,247,0.05); }
.hc { padding: 7px 4px; display: flex; align-items: center; justify-content: center; font-size: 11px; }
.hc:first-child { justify-content: flex-start; padding-left: 12px; font-size: 12px; }
.hc-head { padding: 5px 4px; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.hc-head:first-child { justify-content: flex-start; padding-left: 12px; }
.chip-atk { background: var(--atk-dim); color: var(--atk); border-radius: 3px; padding: 2px 5px; font-size: 9px; font-weight: 900; }
.chip-def { background: var(--def-dim); color: var(--def); border-radius: 3px; padding: 2px 5px; font-size: 9px; font-weight: 900; }
.ck-on { color: var(--green); font-size: 12px; }
.ck-off { color: var(--border2); font-size: 11px; }
.ck-died { color: var(--red); font-size: 12px; }
.ck-clutch { color: var(--amber); font-size: 13px; }

/* TOAST */
.toast { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%) translateY(10px); background: var(--bg2); border: 1px solid var(--border2); border-radius: 20px; padding: 8px 16px; font-size: 13px; font-weight: 700; z-index: 500; opacity: 0; transition: all 0.2s; white-space: nowrap; pointer-events: none; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.ok { border-color: rgba(62,201,126,0.4); color: var(--green); }
.toast.err { border-color: rgba(224,85,85,0.4); color: var(--red); }
.toast.info { border-color: rgba(216,162,58,0.4); color: var(--amber); }
.empty { text-align: center; padding: 40px 16px; color: var(--muted); }

/* TOOLTIPS */
.tip {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  cursor: help;
  border-bottom: 1px dashed var(--muted);
}
.tip::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 400;
  color: var(--text);
  white-space: pre-line;
  width: 220px;
  line-height: 1.5;
  text-align: left;
  text-transform: none;
  letter-spacing: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s;
  z-index: 200;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
/* flip up tooltip if near bottom of viewport — handled via .tip-up modifier */
.tip.tip-left::after { left: 0; transform: translateX(0); }
.tip.tip-right::after { left: auto; right: 0; transform: translateX(0); }
.tip:hover::after { opacity: 1; }
/* th tooltips need special z-index and positioning */
th .tip::after { bottom: calc(100% + 6px); }


/* ABOUT VIEW */
.about-wrap { max-width: 680px; margin: 0 auto; padding-bottom: 40px; }
.about-hero { background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--r); padding: 24px 22px; margin-bottom: 20px; }
.about-hero-title { font-size: 22px; font-weight: 900; margin-bottom: 6px; }
.about-hero-sub { font-size: 14px; color: var(--muted2); line-height: 1.6; }
.about-section { margin-bottom: 20px; }
.about-section-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--muted2); margin-bottom: 12px; padding-bottom: 6px; border-bottom: 1px solid var(--border2); }
.about-body { font-size: 14px; color: var(--muted2); line-height: 1.75; }
.about-body p { margin-bottom: 12px; }
.about-body p:last-child { margin-bottom: 0; }
.about-body strong { color: var(--text); font-weight: 700; }
.stat-explainer { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; margin-bottom: 20px; }
.stat-row { display: grid; grid-template-columns: 100px 1fr; border-bottom: 1px solid var(--border); }
.stat-row:last-child { border-bottom: none; }
.stat-name { padding: 12px 14px; font-size: 13px; font-weight: 800; color: var(--text); background: var(--bg3); display: flex; align-items: flex-start; border-right: 1px solid var(--border); }
.stat-desc { padding: 12px 16px; font-size: 13px; color: var(--muted2); line-height: 1.6; }
.stat-desc strong { color: var(--text); }
.rank-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 8px; }
.rank-table th { text-align: left; padding: 7px 12px; color: var(--muted); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid var(--border); }
.rank-table td { padding: 9px 12px; border-bottom: 1px solid var(--border); color: var(--muted2); }
.rank-table tr:last-child td { border-bottom: none; }
.rank-table td:first-child { font-weight: 800; color: var(--text); }
.rank-copper   { color: #b07030; }
.rank-bronze   { color: #cd7f32; }
.rank-silver   { color: #a8a9ad; }
.rank-gold     { color: #f0c030; }
.rank-plat     { color: #4fb6f7; }
.rank-diamond  { color: #b07ef0; }
.rank-elite    { color: #f7854f; }
.about-callout { background: var(--accent-dim); border: 1px solid rgba(79,142,247,0.25); border-radius: var(--r-sm); padding: 12px 16px; font-size: 13px; color: var(--muted2); line-height: 1.6; margin-bottom: 16px; }
.about-callout strong { color: var(--accent); }
.about-warn { background: var(--amber-dim); border: 1px solid rgba(240,160,48,0.25); border-radius: var(--r-sm); padding: 12px 16px; font-size: 13px; color: var(--muted2); line-height: 1.6; margin-bottom: 16px; }
.about-warn strong { color: var(--amber); }
@media(max-width:480px){ .stat-row { grid-template-columns: 80px 1fr; } .stat-name { font-size:12px; padding: 10px; } .stat-desc { font-size:12px; padding: 10px 12px; } }

/* EDIT MODE */
.edit-toggle { display:flex; align-items:center; gap:8px; padding:6px 12px; border-radius:20px; border:1px solid var(--border2); background:var(--bg3); color:var(--muted2); font-size:12px; font-weight:700; cursor:pointer; transition:all 0.15s; user-select:none; }
.edit-toggle:hover { border-color:var(--amber); color:var(--amber); }
.edit-toggle.on { border-color:var(--amber); background:var(--amber-dim); color:var(--amber); }
.edit-toggle .edit-dot { width:7px; height:7px; border-radius:50%; background:var(--muted); transition:background 0.15s; }
.edit-toggle.on .edit-dot { background:var(--amber); }

.h-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; flex-wrap:wrap; gap:8px; }
.h-filter-group { display:flex; gap:6px; flex-wrap:wrap; }

/* Edit row — replaces normal h-row in edit mode */
.h-row-edit { border-top:1px solid var(--border); background:rgba(240,160,48,0.04); }
.h-row-edit .hc { padding:6px 3px; }
.edit-field { display:flex; flex-direction:column; align-items:center; gap:2px; }
.edit-bool { width:28px; height:28px; border-radius:var(--r-xs); border:1.5px solid var(--border2); background:var(--bg4); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--muted); transition:all 0.1s; }
.edit-bool:active { transform:scale(0.9); }
.edit-bool.on-kill  { border-color:var(--green); background:var(--green-dim); color:var(--green); }
.edit-bool.on-died  { border-color:var(--red); background:var(--red-dim); color:var(--red); }
.edit-bool.on-clutch{ border-color:var(--amber); background:var(--amber-dim); color:var(--amber); }
.edit-bool.on-yes   { border-color:var(--green); background:var(--green-dim); color:var(--green); }
.edit-num { display:flex; align-items:center; gap:2px; }
.edit-num-btn { width:20px; height:20px; border-radius:3px; border:1px solid var(--border2); background:var(--bg3); color:var(--muted2); font-size:14px; cursor:pointer; display:flex; align-items:center; justify-content:center; line-height:1; }
.edit-num-btn:active { background:var(--bg2); }
.edit-num-val { font-size:13px; font-weight:700; min-width:16px; text-align:center; font-variant-numeric:tabular-nums; }
.edit-side-btn { padding:2px 6px; border-radius:3px; border:1px solid var(--border); background:var(--bg4); font-size:9px; font-weight:800; cursor:pointer; color:var(--muted); }
.edit-side-btn.on-atk { background:var(--atk-dim); border-color:var(--atk); color:var(--atk); }
.edit-side-btn.on-def { background:var(--def-dim); border-color:var(--def); color:var(--def); }
.edit-result-btn { padding:2px 6px; border-radius:3px; border:1px solid var(--border); background:var(--bg4); font-size:9px; font-weight:800; cursor:pointer; color:var(--muted); }
.edit-result-btn.on-win  { background:var(--green-dim); border-color:var(--green); color:var(--green); }
.edit-result-btn.on-loss { background:var(--red-dim); border-color:var(--red); color:var(--red); }
.edit-saved-flash { animation: editFlash 0.4s ease; }
@keyframes editFlash { 0%{background:rgba(240,160,48,0.2)} 100%{background:transparent} }

/* RANK & MMR */
.rank-copper  { color: #b07030; } .rank-bronze { color: #cd7f32; }
.rank-silver  { color: #a8a9ad; } .rank-gold   { color: #D8A23A; }
.rank-plat    { color: #4fb6f7; } .rank-diamond{ color: #b07ef0; }
.rank-elite   { color: #C43C3C; }
.mmr-badge { display:inline-flex; flex-direction:column; align-items:flex-end; gap:1px; }
.mmr-val { font-size:26px; font-weight:700; font-variant-numeric:tabular-nums; }
.mmr-tier { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.6px; }
.mmr-delta { display:inline-flex; align-items:center; gap:4px; font-size:12px; font-weight:700; font-variant-numeric:tabular-nums; }
.mmr-delta.pos { color: var(--green); }
.mmr-delta.neg { color: var(--red); }
.mmr-theoretical { font-size:10px; color:var(--muted); font-style:italic; margin-top:2px; }

/* PLAYER MODAL */
.pmodal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.8); z-index:400; display:flex; align-items:center; justify-content:center; padding:16px; }
.pmodal { background:var(--bg2); border:1px solid var(--border2); border-radius:var(--r); padding:22px; width:100%; max-width:750px; max-height:90vh; overflow-y:auto; overflow-x:hidden; }
.pmodal-close { position:absolute; top:12px; right:14px; background:none; border:none; color:var(--muted2); font-size:18px; cursor:pointer; padding:4px 8px; }
.clickable-player { cursor:pointer; text-decoration:underline; text-underline-offset:2px; text-decoration-color:var(--border2); transition:color 0.1s; }
.clickable-player:hover { color:var(--text); text-decoration-color:var(--muted2); }
.hidden { display: none !important; }

/* MATCH ACTION BUTTONS */
.match-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 10px; }
.action-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; padding: 16px 10px; border-radius: var(--r); border: 2px solid var(--border2); background: var(--bg3); cursor: pointer; transition: all 0.12s; }
.action-btn:active { transform: scale(0.97); }
.action-icon { font-size: 20px; line-height: 1; }
.action-label { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted2); }
.action-btn.end-action { border-color: rgba(224,85,85,0.35); }
.action-btn.end-action:hover { background: var(--red-dim); border-color: var(--red); }
.action-btn.end-action:hover .action-label { color: var(--red); }
.action-btn.end-action.confirm { background: var(--red-dim); border-color: var(--red); }
.action-btn.end-action.confirm .action-label { color: var(--red); }
.action-btn.new-action { border-color: var(--border2); }
.action-btn.new-action:hover { background: var(--bg4); border-color: var(--muted2); }
.action-btn.new-action:hover .action-label { color: var(--text); }
.action-btn.new-action.confirm { border-color: rgba(196,60,60,0.6); background: rgba(196,60,60,0.10); }
.action-btn.new-action.confirm .action-label { color: var(--red); }

/* ARCHIVE SECTION */
.arch-section { margin-top: 20px; border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.arch-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: var(--bg3); cursor: pointer; user-select: none; }
.arch-title { font-size: 12px; font-weight: 800; color: var(--muted2); text-transform: uppercase; letter-spacing: 0.06em; }
.arch-arrow { color: var(--muted); font-size: 11px; transition: transform 0.2s; }
.arch-section.open > .arch-header .arch-arrow { transform: rotate(90deg); }
.arch-body { display: none; }
.arch-section.open > .arch-body { display: block; }
.arch-match { border-top: 1px solid var(--border); }
.arch-match-hdr { display: flex; align-items: center; gap: 10px; padding: 9px 14px; cursor: pointer; background: var(--bg2); user-select: none; }
.arch-match-title { font-size: 13px; font-weight: 700; color: var(--text); flex: 1; }
.arch-match-body { display: none; padding: 0; }
.arch-match.open > .arch-match-body { display: block; }
.arch-match.open > .arch-match-hdr .arch-arrow { transform: rotate(90deg); }

.site-legal {
  max-width: 1120px;
  margin: 0 auto 20px;
  padding: 14px 16px 0;
  opacity: 0.54;
}

.legal-line,
.legal-caveat {
  color: var(--muted);
  line-height: 1.6;
}

.legal-line {
  font-size: 11px;
  letter-spacing: 0.2px;
}

.legal-caveat {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid var(--border2);
  font-size: 10px;
}


/* ── MOBILE MODE ─────────────────────────────────────────────────── */
.mob-toggle { background: none; border: 1px solid var(--border2); border-radius: var(--r-xs); padding: 4px 8px; color: var(--muted2); font-size: 14px; cursor: pointer; line-height: 1; transition: background 0.1s; }
.mob-toggle:hover { background: var(--bg3); }
.mob-toggle.on { border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }

body.mobile { font-size: 16px; }

/* Constrain to phone-width in desktop browser */
body.mobile main-wrap { max-width: 420px; margin: 0 auto; }

body.mobile header { padding: 8px 10px; gap: 6px; }
body.mobile .logo { font-size: 11px; }
body.mobile .sadj-btn { width: 30px; height: 30px; font-size: 18px; }
body.mobile .score-nums span { font-size: 22px; }
body.mobile .r-badge { font-size: 13px; padding: 3px 10px; }
body.mobile .rdots { display: none; }
body.mobile .ctx-tag { display: none; }
body.mobile .new-btn { font-size: 11px; padding: 4px 8px; }

body.mobile .tabs { padding: 0 8px; }
body.mobile .tab { padding: 12px 12px; font-size: 14px; }

body.mobile .view { padding: 10px; max-width: 420px; margin: 0 auto; }

/* Status bar */
body.mobile .r-status { padding: 10px 12px; }
body.mobile .spip { width: 28px; height: 28px; font-size: 10px; }

/* Player strip */
body.mobile .ps-av { width: 36px; height: 36px; font-size: 13px; }
body.mobile .ps-name { font-size: 11px; }

/* Side buttons */
body.mobile .side-btn { padding: 20px 10px; font-size: 20px; }

/* Toggle grid — bigger touch targets */
body.mobile .tog { min-height: 90px; padding: 16px 14px; }
body.mobile .tog-label { font-size: 17px; }
body.mobile .tog-dot { width: 14px; height: 14px; }
body.mobile .tog-sub { font-size: 12px; }

/* Kill counters */
body.mobile .kc-btn { width: 52px; height: 52px; font-size: 28px; }
body.mobile .kc-val { font-size: 36px; }
body.mobile .kc-label { font-size: 13px; }

/* Log button */
body.mobile .log-btn { padding: 24px; font-size: 20px; border-radius: 14px; }

/* Scoreboard hero */
body.mobile .hero-grid { grid-template-columns: repeat(3, 1fr); }
body.mobile .hstat-v { font-size: 22px; }
body.mobile .ir-big { font-size: 30px; }

/* Tables — hide less important cols on small */
body.mobile .t-table th:nth-child(3),
body.mobile .t-table td:nth-child(3),
body.mobile .t-table th:nth-child(4),
body.mobile .t-table td:nth-child(4) { display: none; }

/* History rows — tighter */
body.mobile .h-colhead,
body.mobile .h-row { grid-template-columns: 90px repeat(9,1fr) 28px; }
body.mobile .hc { padding: 8px 3px; font-size: 12px; }
body.mobile .hc:first-child { padding-left: 10px; font-size: 12px; }
