:root{
  --bg:#0b1220; --card:#141d2e; --card2:#1b2740; --line:#27314a;
  --text:#eef2fb; --muted:#9aa7c2; --accent:#3b82f6; --accent2:#2563eb;
  --green:#22c55e; --amber:#f59e0b; --red:#ef4444; --gold:#facc15;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:linear-gradient(180deg,#0b1220 0%, #0e1626 100%);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; min-height:100vh;
}
.wrap{max-width:680px;margin:0 auto;padding:16px 16px 64px}

header.top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 2px 14px}
.title{font-size:18px;font-weight:800;letter-spacing:.2px;line-height:1.1}
.title small{display:block;font-weight:600;color:var(--muted);font-size:11px;letter-spacing:.6px;text-transform:uppercase;margin-top:3px}
.who{font-size:12px;color:var(--muted);text-align:right;line-height:1.5}
.who b{color:var(--text)}
.who a{color:var(--accent);cursor:pointer;text-decoration:none}

.status{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.pill{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.pill .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.pill .val{font-size:20px;font-weight:800;margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.hearts span{font-size:20px;line-height:1}
.heart-empty{filter:grayscale(1);opacity:.35}

.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:16px;margin-bottom:14px}
.roundhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.roundhead h2{margin:0;font-size:16px;font-weight:800}
.tag{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:3px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.tag.group{color:#a5b4fc;border-color:#3b3f7a;background:#1c1f3a}
.tag.knockout{color:#fcd34d;border-color:#6b551a;background:#2a2410}
.sub{color:var(--muted);font-size:12.5px;margin:2px 0 14px;line-height:1.5}

.match{display:grid;grid-template-columns:1fr auto 1fr;align-items:stretch;gap:8px;margin-bottom:6px}
.match .ko{grid-column:1 / -1;text-align:center;font-size:11px;color:var(--muted);margin:2px 0 8px;letter-spacing:.3px}
.team{appearance:none;cursor:pointer;text-align:center;background:var(--card2);border:1.5px solid var(--line);color:var(--text);border-radius:12px;padding:13px 8px;font-size:14px;font-weight:700;transition:.12s ease;line-height:1.15}
.team:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px)}
.team .flag{font-size:18px;display:block;margin-bottom:3px}
.team.selected{border-color:var(--accent);background:#16315e;box-shadow:0 0 0 2px rgba(59,130,246,.35) inset}
.team.used{opacity:.32;cursor:not-allowed}
.team.used .tn{text-decoration:line-through}
.team:disabled{cursor:not-allowed}
.vs{display:flex;align-items:flex-start;justify-content:center;color:var(--muted);font-size:11px;font-weight:700;padding-top:18px}

.actions{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
button.btn{appearance:none;cursor:pointer;border:none;border-radius:12px;padding:13px 18px;font-size:14px;font-weight:800;letter-spacing:.2px}
.btn.primary{background:var(--accent2);color:#fff;flex:1}
.btn.primary:hover{background:var(--accent)}
.btn.primary:disabled{background:#2b3550;color:#7f8aa6;cursor:not-allowed}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
.btn.ghost:hover{color:var(--text);border-color:var(--accent)}
.confirmline{font-size:13px;color:var(--muted);margin-top:10px;min-height:18px}
.confirmline b{color:var(--text)}

.result-row{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.res{flex:1;min-width:90px;border-radius:12px;padding:11px;font-weight:800;font-size:13px;cursor:pointer;border:1.5px solid var(--line);background:var(--card2);color:var(--text)}
.res.win:hover,.res.win.on{border-color:var(--green);background:#0f2c1c;color:#5ef0a0}
.res.draw:hover,.res.draw.on{border-color:var(--amber);background:#2c230f;color:#fbd07a}
.res.loss:hover,.res.loss.on{border-color:var(--red);background:#2c1212;color:#ff8a8a}

.rounds-list{display:flex;flex-direction:column;gap:8px}
.rl-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--card2)}
.rl-num{width:26px;height:26px;flex:0 0 26px;border-radius:8px;background:#0e1730;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:var(--muted)}
.rl-main{flex:1;min-width:0}
.rl-main .n{font-size:13px;font-weight:700}
.rl-main .p{font-size:12px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rl-badge{font-size:11px;font-weight:800;padding:4px 9px;border-radius:999px;white-space:nowrap}
.b-win{background:#0f2c1c;color:#5ef0a0}
.b-draw{background:#2c230f;color:#fbd07a}
.b-loss{background:#2c1212;color:#ff8a8a}
.b-pending{background:#1b2336;color:var(--muted)}
.b-locked{background:#15192a;color:var(--muted)}
.rl-item.current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.rl-item.locked{opacity:.5}
.rl-item.clickable{cursor:pointer}
.rl-item.clickable:hover{border-color:var(--accent)}

.banner{border-radius:16px;padding:18px;margin-bottom:14px;text-align:center}
.banner.out{background:linear-gradient(180deg,#3a1118,#250a0e);border:1px solid #6b1d28}
.banner.out h2{margin:0 0 6px;font-size:20px;color:#ff8a8a}
.banner.win{background:linear-gradient(180deg,#1c2c12,#0f1c0c);border:1px solid #2f6b1d}
.banner.win h2{margin:0 0 6px;font-size:20px;color:var(--gold)}
.banner p{margin:0;color:var(--muted);font-size:13px}

.teampool{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.chip{font-size:11.5px;padding:5px 9px;border-radius:999px;border:1px solid var(--line);background:var(--card2);color:var(--text)}
.chip.used{opacity:.34;text-decoration:line-through}

.gate{max-width:420px;margin:8vh auto 0;text-align:center}
.gate .card{padding:26px}
.gate h1{font-size:22px;margin:0 0 6px;line-height:1.15}
.gate p{color:var(--muted);font-size:13.5px;margin:0 0 18px;line-height:1.5}
.gate input{width:100%;padding:14px;border-radius:12px;border:1px solid var(--line);background:var(--card2);color:var(--text);font-size:16px;text-align:center;margin-bottom:12px}
.gate input:focus{outline:none;border-color:var(--accent)}

.foot{text-align:center;font-size:11px;color:var(--muted);margin-top:24px;opacity:.7}
.foot a{color:var(--muted);cursor:pointer}
details.rules{margin-top:6px}
details.rules summary{cursor:pointer;color:var(--muted);font-size:12px}
details.rules ul{color:var(--muted);font-size:12.5px;line-height:1.6;padding-left:18px}
details.card>summary{cursor:pointer;font-weight:800;font-size:14px;list-style:none}
details.card>summary::-webkit-details-marker{display:none}
.rules-card{padding:14px 16px;margin-bottom:14px}
.rules-card>summary{color:var(--text)}
.ruleslist{color:var(--muted);font-size:12.5px;line-height:1.6;padding-left:18px;margin:10px 0 2px}

.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#0f1830;border:1px solid var(--accent);color:#fff;padding:11px 16px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.4);z-index:50;opacity:0;transition:.2s;pointer-events:none}
.toast.show{opacity:1}

/* status grid: allow up to 4 pills wrapping */
.status{grid-template-columns:repeat(2,1fr)}
.muted{color:var(--muted)}

/* gameweek pills */
.pills{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;-webkit-overflow-scrolling:touch}
.gwpill{flex:0 0 auto;min-width:62px;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:9px 12px;border-radius:13px;border:1.5px solid var(--line);background:var(--card2);color:var(--text);cursor:pointer;transition:.12s}
.gwpill:hover{border-color:var(--accent)}
.gwpill .gwn{font-size:12px;font-weight:800;letter-spacing:.3px;white-space:nowrap}
.gwpill .gws{font-size:13px;font-weight:700;line-height:1}
.gwpill.on{border-color:var(--accent);background:#16315e}
.gwpill.todo{border-color:var(--amber)}
.gwpill.todo .gwn{color:var(--amber)}
.gwpill.done .gws{color:#5ef0a0}
.gwpill.locked{opacity:.7}
.gwpill.locked .gwn{color:var(--muted)}

/* social table */
.thead{display:grid;grid-template-columns:1fr auto 1.2fr;gap:10px;padding:4px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.tbody{display:flex;flex-direction:column;gap:2px}
.trow{display:grid;grid-template-columns:1fr auto 1.2fr;gap:10px;align-items:center;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--card2);cursor:pointer;transition:.12s}
.trow:hover{border-color:var(--accent)}
.trow.me{border-color:#2f5bbf;background:#16203a}
.trow.outrow{opacity:.55}
.tname{font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.youtag{font-size:10px;font-weight:800;color:var(--accent);border:1px solid #2f5bbf;border-radius:999px;padding:1px 6px;margin-left:2px}
.tlives .heart-empty{font-size:15px}
.tlives span{font-size:15px}
.tpick{text-align:right;font-size:12.5px}
.tbteam{font-weight:700}
.thist{padding:6px 10px 10px}
.hrow{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--line);font-size:12.5px}
.hrow:last-child{border-bottom:none}
.hr-n{flex:0 0 34px;color:var(--muted);font-weight:800;font-size:11px}
.hr-t{flex:1;min-width:0}
