/* GameRanker web — Material You tokens distilled from the legacy app */
:root{
  --bg:#f6f8fc; --panel:#ffffff; --muted:#5f6368; --text:#202124;
  --accent:#1a73e8; --accent2:#1967d2; --on-accent:#ffffff;
  --accent-soft:rgba(26,115,232,0.08);
  --ok:#1e8e3e; --bad:#d93025;
  --card:#ffffff; --border:#dadce0; --container-bg:#eef3fb;
  --chip:#f1f3f4; --chipOn:#e8f0fe;
  --a-bg:#e8f0fe; --a-border:#aecbfa; --b-bg:#fef7e0; --b-border:#fde293;
  --win-bg:#e6f4ea; --loss-bg:#fce8e6;
  --shadow:0 1px 2px 0 rgba(60,64,67,.30), 0 1px 3px 1px rgba(60,64,67,.15);
  --shadow-lg:0 1px 3px 0 rgba(60,64,67,.30), 0 4px 8px 3px rgba(60,64,67,.15);
  --topbar-bg:rgba(232,240,254,0.85); --topbar-border:#d2e3fc;
  --hero-gradient:linear-gradient(120deg,#1967d2 0%,#4285f4 45%,#12b5cb 100%);
  --hero-bg:linear-gradient(135deg, rgba(66,133,244,0.06), rgba(18,181,203,0.05), rgba(26,115,232,0.04));
}
[data-theme="dark"]{
  --bg:#131314; --panel:#1e1f20; --muted:#9aa0a6; --text:#e8eaed;
  --accent:#8ab4f8; --accent2:#aecbfa; --on-accent:#202124;
  --accent-soft:rgba(138,180,248,0.12);
  --ok:#81c995; --bad:#f28b82;
  --card:#1e1f20; --border:#3c4043; --container-bg:#282a2e;
  --chip:#28292a; --chipOn:#283142;
  --a-bg:#1c2a42; --a-border:#3c5278; --b-bg:#2e2a1a; --b-border:#5c5230;
  --win-bg:#1e3a26; --loss-bg:#3a1f1d;
  --shadow:0 1px 2px 0 rgba(0,0,0,.30), 0 1px 3px 1px rgba(0,0,0,.15);
  --shadow-lg:0 1px 3px 0 rgba(0,0,0,.30), 0 4px 8px 3px rgba(0,0,0,.15);
  --topbar-bg:rgba(26,33,48,0.85); --topbar-border:#2d3c54;
  --hero-gradient:linear-gradient(120deg,#8ab4f8 0%,#a8c7fa 45%,#4dd0e1 100%);
  --hero-bg:linear-gradient(135deg, rgba(138,180,248,0.10), rgba(77,208,225,0.06), rgba(138,180,248,0.05));
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;color:var(--text);background:var(--bg);min-height:100vh;
  font-family:'Roboto','Inter',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  -webkit-font-smoothing:antialiased;transition:background .3s ease,color .3s ease}
a{color:var(--accent);text-decoration:none}
h2{font-size:20px;font-weight:700;letter-spacing:-.3px;margin:14px 0 10px}
h3{font-size:15px;font-weight:600;margin:18px 0 8px;position:relative;padding-left:13px}
h3::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:5px;height:1.1em;border-radius:3px;background:var(--hero-gradient)}
.wrap{max-width:720px;margin:0 auto;padding:16px}
.center{max-width:460px;margin-left:auto;margin-right:auto}
.mut{color:var(--muted);font-size:13.5px}
.sm{font-size:12px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em}
[hidden]{display:none!important}

.topbar{position:sticky;top:0;z-index:40;background:var(--topbar-bg);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--topbar-border)}
.toprow{display:flex;gap:12px;align-items:center;padding:10px 16px}
.brand-main{font-weight:900;font-size:20px;letter-spacing:-.3px;
  background:var(--hero-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.topspacer{flex:1}
.theme-toggle{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);
  background:var(--card);color:var(--text);cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0}

.pill{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;
  background:var(--accent-soft);border:1px solid var(--border);font-size:12px;font-weight:600}
.pill.gold{background:var(--b-bg);border-color:var(--b-border)}

.btn{background:var(--accent);color:var(--on-accent);border:none;padding:10px 22px;
  border-radius:999px;font-weight:500;cursor:pointer;font-size:14px;font-family:inherit;
  transition:box-shadow .2s ease,filter .2s ease}
.btn:hover{box-shadow:var(--shadow);filter:brightness(.96)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.secondary{background:var(--chipOn);color:var(--accent2)}
.btn.sm{padding:6px 14px;font-size:12px}
.btn.wide{width:100%;margin-top:12px}
.btn-gradient{background:var(--accent);color:var(--on-accent);border:none;padding:13px 32px;
  border-radius:999px;font-weight:500;cursor:pointer;font-size:15px;font-family:inherit;box-shadow:var(--shadow)}
.btn-gradient:disabled{opacity:.45;cursor:not-allowed}

label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin:8px 0 4px}
input,select{width:100%;padding:11px 14px;border-radius:12px;border:1px solid var(--border);
  background:var(--panel);color:var(--text);font-size:15px;font-family:inherit}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}

.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.row>input{flex:1;min-width:120px}
.row.spread{justify-content:space-between}
.stack{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.slugrow{display:flex;gap:6px;align-items:center}
.divider{display:flex;align-items:center;gap:14px;font-size:11px;color:var(--muted);
  font-weight:600;text-transform:uppercase;letter-spacing:1px;margin:4px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

.card{background:var(--card);border:1px solid var(--border);border-radius:22px;
  padding:20px;margin:14px 0;box-shadow:var(--shadow)}
.hero-card{background:var(--card);border:1px solid var(--border);border-radius:24px;
  padding:36px 28px;margin:24px auto;box-shadow:var(--shadow-lg);text-align:center;
  position:relative;overflow:hidden;animation:fadeUp .4s ease both}
.hero-card::before{content:'';position:absolute;top:-60%;left:-20%;width:140%;height:120%;
  background:var(--hero-bg);border-radius:50%;filter:blur(40px);pointer-events:none}
.hero-card>*{position:relative}
.hero-icon{width:64px;height:64px;border-radius:18px;margin:0 auto 16px;background:var(--hero-gradient);
  display:flex;align-items:center;justify-content:center;font-size:32px}
.hero-title{font-size:26px;font-weight:900;letter-spacing:-.5px;margin:0 0 6px}
.hero-subtitle{font-size:14.5px;color:var(--muted);margin:0 0 8px;line-height:1.5}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin:10px 0 14px;overflow-x:auto;scrollbar-width:none}
.tab{flex:0 0 auto;padding:12px 16px 11px;font-size:14px;font-weight:500;color:var(--muted);
  cursor:pointer;white-space:nowrap;position:relative;border-radius:8px 8px 0 0}
.tab:hover{color:var(--text);background:var(--accent-soft)}
.tab.active{color:var(--accent);font-weight:600}
.tab.active::after{content:'';position:absolute;left:8px;right:8px;bottom:-1px;height:3px;
  background:var(--accent);border-radius:3px 3px 0 0}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0}
.chip{padding:8px 14px;border-radius:999px;font-weight:600;font-size:13.5px;cursor:pointer;
  user-select:none;border:1px solid var(--border);background:var(--chip);color:var(--text);
  transition:all .15s ease}
.chip.on{background:var(--chipOn);border-color:var(--accent);color:var(--accent2)}
.chip.dis{opacity:.4;cursor:default}
.chipA,.chipB{padding:8px 14px;border-radius:999px;font-weight:600;font-size:13.5px;cursor:pointer;
  user-select:none;border:1px solid var(--border);background:var(--chip);color:var(--text);display:inline-block}
.chipA.on{background:var(--a-bg);border-color:var(--a-border)}
.chipB.on{background:var(--b-bg);border-color:var(--b-border)}

.teamBox{border:1px solid var(--border);border-radius:16px;padding:12px;margin-top:8px}
.teamBox.A{background:var(--a-bg);border-color:var(--a-border)}
.teamBox.B{background:var(--b-bg);border-color:var(--b-border)}
.teamBox.winner{border-color:var(--ok)!important;box-shadow:inset 0 0 0 1px var(--ok)}
.teamLabel{font-weight:700;font-size:13.5px;margin-bottom:6px}
.winFlag{font-size:11px;font-weight:600;color:var(--muted);cursor:pointer}
.teamBox.winner .winFlag{color:var(--ok)}
.vsMid{text-align:center;font-size:12px;font-weight:800;letter-spacing:1px;color:var(--muted);
  padding:8px 0;user-select:none}

.seg{display:flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;margin-top:12px}
.seg span{flex:1;text-align:center;padding:12px 6px;font-size:13.5px;font-weight:600;color:var(--muted);
  cursor:pointer;user-select:none;transition:background .15s,color .15s}
.seg span.on{background:var(--win-bg);color:var(--ok)}
.seg span+span{border-left:1px solid var(--border)}
.datepill{font-size:12px;color:var(--muted);border:1px solid var(--border);border-radius:999px;
  padding:8px 14px;background:var(--card);cursor:pointer;font-family:inherit;white-space:nowrap}
.datepill:hover{border-color:var(--accent);color:var(--accent2)}

.lg-row{display:flex;align-items:center;gap:10px;padding:11px 6px;border-bottom:1px solid var(--border);font-size:14.5px}
.lg-row:last-child{border-bottom:none}
.lg-row .rk{width:22px;text-align:center;color:var(--muted);font-size:12.5px}
.lg-row .nm{flex:1;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis}
.lg-row .sub{font-size:11.5px;color:var(--muted);font-weight:400}
.lg-row .el{font-weight:700;font-variant-numeric:tabular-nums}
.lg-row .el.neg{color:var(--bad)} .lg-row .el.pos{color:var(--ok)}

.league-tile{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);
  border-radius:18px;padding:16px;cursor:pointer;box-shadow:var(--shadow);transition:box-shadow .2s}
.league-tile:hover{box-shadow:var(--shadow-lg)}
.league-tile .ico{width:42px;height:42px;border-radius:13px;background:var(--hero-gradient);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.league-tile .t{flex:1;min-width:0}
.league-tile .t .n{font-weight:700;font-size:15.5px}
.league-tile .t .s{font-size:12px;color:var(--muted)}

.preview-card{display:flex;gap:12px;align-items:center;background:var(--container-bg);
  border-radius:16px;padding:14px;text-align:left}
.preview-card .ico{width:44px;height:44px;border-radius:13px;background:var(--hero-gradient);
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.preview-card .n{font-weight:700;font-size:15px}
.preview-card .s{font-size:12px;color:var(--muted)}
.target-card{background:var(--container-bg);border-radius:14px;padding:12px 14px;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:8px}
.target-card .ok{color:var(--ok);font-weight:700;font-size:12px;white-space:nowrap}

.logcard{background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:10px 12px;margin:8px 0}
.lgc-row{display:flex;align-items:baseline;gap:8px}
.lgc-row+.lgc-row{margin-top:3px}
.lgc-row.top .lgc-names{font-weight:600}
.lgc-names{flex:1;min-width:0;font-size:13px;color:var(--text)}
.lgc-delta{flex:none;font-size:13px;font-weight:700}
.lgc-pills{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:8px}
.logpill{font-size:11px;color:var(--muted);background:var(--container-bg);border-radius:6px;padding:2px 8px}
.logdel{margin-left:auto;font-size:11px;color:var(--bad);background:transparent;
  border:1px solid var(--border);border-radius:8px;padding:3px 10px;cursor:pointer;font-family:inherit}
.logdel:hover{border-color:var(--bad)}
.logre{font-size:11px;color:var(--accent2);background:var(--chipOn);border:none;
  border-radius:8px;padding:3px 10px;cursor:pointer;font-family:inherit;font-weight:600}

.setcard{background:var(--container-bg);border-radius:14px;padding:11px 14px 9px;margin:8px 0}
.sc-main{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px;font-size:14px}
.sc-side{font-weight:600}
.sc-side.win{color:var(--ok);font-weight:700}
.sc-vs{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.sc-meta{display:flex;justify-content:space-between;align-items:center;margin-top:5px;
  font-size:11.5px;color:var(--muted)}
.sc-rematch{border:none;background:var(--chipOn);color:var(--accent2);font-family:inherit;
  font-size:11.5px;font-weight:600;border-radius:999px;padding:5px 12px;cursor:pointer}
.sc-rematch:hover{filter:brightness(.96)}
.sc-delta{margin-left:auto;font-weight:700;font-size:13px;font-variant-numeric:tabular-nums;flex:none}

.pill.p-win{background:var(--win-bg);border-color:transparent;color:var(--ok)}
.pill.p-draw{background:var(--chip);border-color:transparent;color:var(--muted)}
.pill.p-loss{background:var(--loss-bg);border-color:transparent;color:var(--bad)}
.hcard{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--border);
  border-radius:12px;padding:10px 12px;margin-top:8px;display:flex;align-items:center;gap:10px}
.hcard-l{flex:1;min-width:0}
.hcard-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.hcard-name{font-size:14px;font-weight:600}
.hcard-sub{font-size:11.5px;color:var(--muted);margin-top:3px}
.hcard-meta{font-size:10.5px;color:var(--muted);opacity:.85;margin-top:2px}
.hcard-r{text-align:right;flex:none}
.hcard-del{border:none;background:transparent;color:var(--muted);font-size:12px;cursor:pointer;
  padding:2px 6px;border-radius:8px;font-family:inherit;margin-top:2px}
.hcard-del:hover{color:var(--bad);background:var(--loss-bg)}
.hcard-delta{font-size:18px;font-weight:700}
.hcard-after{font-size:11px;color:var(--muted)}

.bband{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:8px 12px;margin-top:10px;border-left:3px solid var(--border);border-radius:0 10px 10px 0}
.bband-name{font-weight:700;font-size:12.5px}
.bband-range{color:var(--muted);font-size:11.5px}
.bband-range b{color:var(--text);font-weight:600}
.brow{padding:10px 6px 10px 10px;border-bottom:1px solid var(--border);border-left:3px solid transparent}
.brow:last-child{border-bottom:none}
.brow-l1{display:flex;align-items:center;gap:8px}
.brow-rank{width:20px;text-align:center;color:var(--muted);font-size:12.5px;flex:none}
.brow-name{font-size:14.5px;font-weight:600;min-width:0}
.brow-badges{font-size:13px;letter-spacing:1px;white-space:nowrap}
.brow-rating{margin-left:auto;font-size:15.5px;font-weight:700;flex:none}
.brow-l2{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;margin-top:6px;padding-left:28px}
.bgap{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;flex:none;white-space:nowrap}
.bstat{font-size:11.5px;color:var(--muted);flex:none;white-space:nowrap}
.bstat b{color:var(--text);font-weight:600}

#toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:99;
  background:var(--text);color:var(--bg);padding:12px 22px;border-radius:12px;font-size:14px;
  box-shadow:var(--shadow-lg);max-width:90vw}

.metric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:10px 0}
.records-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.records-grid .metric h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--muted);padding:0}
.records-grid .metric h4::before{display:none}
.records-grid .metric .big{font-size:17px;font-weight:800;letter-spacing:-.3px;line-height:1.35}
.records-grid .metric .sub{font-size:12px;color:var(--muted);margin-top:4px}
.metric{background:var(--container-bg);border-radius:14px;padding:13px 14px}
.metric .m-ico{font-size:20px}
.metric .m-label{font-size:11.5px;font-weight:600;color:var(--muted);margin:4px 0 2px}
.metric .m-val{font-size:15px;font-weight:800;letter-spacing:-.2px;line-height:1.35}
.metric .m-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
.h2h-score{display:flex;align-items:center;justify-content:center;gap:16px;font-size:16px;font-weight:600;margin:8px 0 2px}
.h2h-score b{font-size:30px;font-weight:900;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.h2h-bar{height:8px;border-radius:999px;background:var(--b-bg);overflow:hidden;margin:10px 0 14px}
.h2h-bar div{height:100%;background:var(--accent);border-radius:999px}
.pos{color:var(--ok);font-weight:600} .neg{color:var(--bad);font-weight:600}

.elo-chart{width:100%;height:150px;background:var(--container-bg);border-radius:14px;margin:8px 0}
.elo-chart .c-line{fill:none;stroke:var(--accent);stroke-width:2;vector-effect:non-scaling-stroke}
.elo-chart .c-zero{stroke:var(--border);stroke-width:1;stroke-dasharray:4 4;vector-effect:non-scaling-stroke}
.elo-chart .c-dot{fill:var(--accent)}
.form-pills{display:flex;gap:3px;flex-wrap:wrap}
.fp{width:20px;height:20px;border-radius:6px;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.fp.w{background:var(--win-bg);color:var(--ok)}
.fp.l{background:var(--loss-bg);color:var(--bad)}
.fp.d{background:var(--chip);color:var(--muted)}

@media (max-width:480px){
  .wrap{padding:12px 10px}
  .card{padding:14px;border-radius:18px}
  .hero-card{padding:28px 18px}
  .hero-title{font-size:22px}
  h2{font-size:18px}
  .tab{padding:11px 12px 10px;font-size:13px}
  .chip{padding:9px 13px;font-size:13px}
  .btn,.btn-gradient{padding:11px 18px}
  .metric-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .lg-row{font-size:13.5px;padding:10px 4px}
  .logcard{flex-wrap:wrap}
}

.fmt{display:flex;gap:10px;align-items:flex-start;background:var(--card);border:1px solid var(--border);
  border-radius:14px;padding:12px;cursor:pointer;transition:border-color .15s}
.fmt.on{border-color:var(--accent);background:var(--chipOn)}
.fmt .ic{font-size:20px;flex:none}
.fmt .t{font-size:13.5px;font-weight:700}
.fmt .d{font-size:11.5px;color:var(--muted);line-height:1.45}
.tog{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:12.5px;
  background:var(--container-bg);border-radius:12px;padding:10px 12px}
.livechip{font-size:10px;font-weight:800;color:var(--accent2);letter-spacing:.5px;vertical-align:2px}
.bracket{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin:10px 0}
.b-round{flex:none;width:170px;display:flex;flex-direction:column;gap:8px;justify-content:space-around}
.b-title{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);text-align:center}
.b-match{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.b-match.live{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.b-match.live .b-slot{cursor:pointer}
.b-match.live .b-slot:hover{background:var(--accent-soft)}
.b-slot{padding:9px 11px;font-size:12.5px;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.b-slot+.b-slot{border-top:1px solid var(--border)}
.b-slot.w{background:var(--win-bg);color:var(--ok)}
.b-slot.tbd{color:var(--muted);font-weight:400;font-style:italic}

.info-btn{width:18px;height:18px;border-radius:50%;border:1px solid var(--border);
  background:var(--chipOn);color:var(--accent2);font-size:11px;font-weight:700;cursor:pointer;
  vertical-align:1px;margin-left:5px;padding:0;line-height:1;font-family:inherit}
.info-btn:hover{border-color:var(--accent)}
#modal-overlay{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--card);border:1px solid var(--border);border-radius:22px;
  padding:22px;max-width:440px;width:100%;box-shadow:var(--shadow-lg);max-height:85vh;overflow-y:auto}
.modal-item{background:var(--container-bg);border-radius:14px;padding:12px 14px;margin:10px 0}
.modal-item b{font-size:14px}
.modal-item p{margin:6px 0 0;font-size:13px;line-height:1.55}
