:root{
  --bg:#0a0f1e; --bg2:#111a2e; --card:#16213a; --card2:#1d2a47;
  --line:#27375c; --text:#e8eefc; --muted:#9fb0d0; --green:#22c55e;
  --green2:#16a34a; --gold:#f4c84a; --red:#ef4444; --accent:#3b82f6;
  --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 600px at 70% -10%,#16305a 0%,var(--bg) 55%) fixed;
  color:var(--text); min-height:100vh; line-height:1.5;
}
a{color:var(--gold)}
.topbar{
  display:flex; flex-direction:column; align-items:stretch; gap:12px;
  padding:16px 26px; flex-wrap:wrap;
  background:linear-gradient(180deg,rgba(10,15,30,.9),rgba(10,15,30,.5));
  border-bottom:1px solid var(--line); position:sticky; top:0; z-index:30; backdrop-filter:blur(8px);
}
.topbar-row{display:flex; align-items:center; justify-content:space-between; gap:12px}
.brand{display:flex; align-items:center; gap:14px; min-width:0}
.btn-share-icon{
  flex:none; width:42px; height:42px; padding:0; border-radius:12px;
  border:1px solid var(--line); background:var(--card2); color:var(--text);
  cursor:pointer; display:grid; place-items:center; transition:.15s ease;
}
.btn-share-icon:hover{transform:translateY(-1px); border-color:var(--green); background:rgba(34,197,94,.12); color:var(--green)}
.btn-share-icon svg{width:20px; height:20px}
.logo{font-size:34px; filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}
.brand h1{font-size:20px; margin:0}
.tagline{margin:2px 0 0; color:var(--muted); font-size:13px}
.actions{display:flex; gap:8px; flex-wrap:wrap}
.btn{
  border:1px solid var(--line); background:var(--card2); color:var(--text);
  padding:9px 14px; border-radius:10px; cursor:pointer; font-size:14px; font-weight:600;
  transition:.15s ease; white-space:nowrap;
}
.btn:hover{transform:translateY(-1px); border-color:#3a5288}
.btn-primary{background:linear-gradient(135deg,var(--green),var(--green2)); border-color:transparent; color:#04150a}
.btn-ghost{background:rgba(255,255,255,.04)}
.btn-danger{background:transparent; border-color:#5a2230; color:#ff9aa5}
.btn-danger:hover{background:rgba(239,68,68,.12)}

/* ---------- Hero / 预测总览 ---------- */
.hero{position:relative; overflow:hidden; border-bottom:1px solid var(--line)}
.hero-bg{position:absolute; inset:0; background:
  radial-gradient(700px 320px at 20% -20%,rgba(244,200,74,.18),transparent 60%),
  radial-gradient(800px 360px at 90% 0%,rgba(34,197,94,.16),transparent 60%);
  pointer-events:none}
.hero-inner{position:relative; max-width:1240px; margin:0 auto; padding:28px 26px 30px}
.hero-head{margin-bottom:20px}
.hero-kicker{margin:0; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); font-size:12px; font-weight:700}
.hero-title{margin:8px 0 4px; font-size:24px; font-weight:800; line-height:1.2}
.hero-desc{margin:0; color:var(--muted); font-size:13px}
.favorites-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(248px,1fr)); gap:14px}
.fav-card{background:linear-gradient(160deg,rgba(29,42,71,.82),rgba(16,24,42,.72)); border:1px solid var(--line);
  border-radius:16px; padding:14px 15px; box-shadow:0 12px 30px rgba(0,0,0,.28); transition:transform .18s ease, border-color .18s ease}
.fav-card:hover{transform:translateY(-3px); border-color:#3a5288}
.fav-card.lead{border-color:rgba(244,200,74,.55); box-shadow:0 14px 34px rgba(244,200,74,.16)}
.fav-head{display:flex; align-items:center; gap:9px; padding-bottom:11px; margin-bottom:11px; border-bottom:1px solid rgba(255,255,255,.08)}
.fav-rank{flex:none; display:grid; place-items:center; width:24px; height:24px; border-radius:7px;
  background:var(--card2); color:var(--gold); font-weight:900; font-size:13px}
.fav-card.lead .fav-rank{background:linear-gradient(135deg,var(--gold),#f59e0b); color:#1f1600}
.fav-flag{font-size:24px; line-height:1}
.fav-name{font-size:16px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.fav-fifa{margin-left:auto; flex:none; color:var(--muted); font-size:11px; font-weight:700}
.fav-models{display:flex; flex-direction:column; gap:7px}
.fav-model{display:grid; grid-template-columns:88px 1fr 46px; align-items:center; gap:8px}
.fav-model-name{font-size:12px; color:var(--muted); font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.fav-bar{position:relative; height:7px; border-radius:999px; background:rgba(255,255,255,.08); overflow:hidden}
.fav-bar-fill{position:absolute; left:0; top:0; bottom:0; border-radius:999px; background:linear-gradient(90deg,var(--green2),var(--green)); min-width:2px; transition:width .3s ease}
.fav-bar-fill.forced{background:linear-gradient(90deg,#b91c1c,#ef4444)}
.fav-model-pct{font-size:12px; font-weight:800; color:var(--text); text-align:right; font-variant-numeric:tabular-nums}

.tabs{display:flex; gap:6px; padding:0; flex-wrap:wrap; width:100%}
.tab{border:none; background:transparent; color:var(--muted); padding:10px 16px;
  border-radius:999px; cursor:pointer; font-size:15px; font-weight:600}
.tab:hover{background:rgba(255,255,255,.05); color:var(--text)}
.tab.active{color:var(--text); background:var(--card); box-shadow:inset 0 0 0 1px var(--line),0 8px 20px rgba(0,0,0,.18)}
main{padding:18px 26px 60px; max-width:1240px; margin:0 auto}
.tab-panel{display:none; animation:fade .25s ease}
.tab-panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.hint{color:var(--muted); font-size:14px; margin:4px 0 18px; max-width:900px}
.tab-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:-4px 0 18px}
.groups-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:18px}
.group-card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow)}
.group-head{display:flex; align-items:center; gap:10px; padding:12px 16px; background:var(--card2); border-bottom:1px solid var(--line)}
.group-head .badge{background:var(--green); color:#04150a; font-weight:800; width:30px; height:30px; border-radius:8px; display:grid; place-items:center}
.group-head h3{margin:0; font-size:16px}
.matches{padding:8px 12px}
.match{display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:8px; padding:8px 4px; border-bottom:1px dashed rgba(255,255,255,.06)}
.match:last-child{border-bottom:none}
.match.locked{opacity:.78}
.match-lock{grid-column:1/-1;justify-self:center;color:var(--gold);font-size:11px;font-weight:700;background:rgba(244,200,74,.08);border:1px solid rgba(244,200,74,.2);border-radius:999px;padding:2px 8px}
.team{display:flex; align-items:center; gap:7px; font-size:14px}
.team.home{justify-content:flex-end; text-align:right}
.team .fl{font-size:18px}
.score{display:flex; align-items:center; gap:6px}
.score input{width:42px; height:36px; text-align:center; font-size:16px; font-weight:700;
  background:var(--bg2); color:var(--text); border:1px solid var(--line); border-radius:8px}
.score input:focus{outline:none; border-color:var(--green); box-shadow:0 0 0 2px rgba(34,197,94,.25)}
.score input:disabled{cursor:not-allowed;opacity:.72;background:rgba(15,23,42,.75);color:var(--muted)}
.score .sep{color:var(--muted)}
.standings{padding:6px 12px 14px}
.standings table{width:100%; border-collapse:collapse; font-size:13px}
.standings th,.standings td{padding:6px 6px; text-align:center}
.standings th{color:var(--muted); font-weight:600; border-bottom:1px solid var(--line)}
.standings td.name{text-align:left; white-space:nowrap}
.standings tr.q1 td{background:rgba(34,197,94,.14)}
.standings tr.q2 td{background:rgba(34,197,94,.07)}
.standings tr.q3 td{background:rgba(244,200,74,.08)}
.pos{display:inline-block; width:18px; color:var(--muted)}

/* ---------- 球队收藏卡 ---------- */
.team-card-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.team-filter{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:600}
.team-filter select{background:var(--bg2);color:var(--text);border:1px solid var(--line);border-radius:10px;padding:9px 12px}
.team-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.team-card-model{
  position:relative;overflow:hidden;border-radius:24px;padding:18px;min-height:430px;
  display:flex;flex-direction:column;
  background:
    radial-gradient(280px 190px at 18% -6%,color-mix(in srgb,var(--team-c3) 32%,transparent),transparent 72%),
    linear-gradient(155deg,color-mix(in srgb,var(--team-c1) 60%,#0d1424),#0c1426 56%,color-mix(in srgb,var(--team-c2) 46%,#0a0f1e));
  border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 50px rgba(0,0,0,.38);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.team-card-model:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--team-c3) 55%,rgba(255,255,255,.2));box-shadow:0 26px 60px rgba(0,0,0,.46)}
.team-card-model:before{content:"";position:absolute;inset:0;background:linear-gradient(118deg,transparent 18%,rgba(255,255,255,.1),transparent 50%);pointer-events:none}
.team-card-model.is-champion{border-color:rgba(244,200,74,.6);box-shadow:0 22px 56px rgba(244,200,74,.2)}
.team-card-glow{position:absolute;right:-80px;top:-80px;width:200px;height:200px;border-radius:50%;background:var(--team-c3);opacity:.2;filter:blur(10px)}
.team-card-top{position:relative;display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,.82);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.team-card-group,.team-card-rank{background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:5px 11px;backdrop-filter:blur(4px)}
.team-card-hero{position:relative;display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:center;margin:20px 0 14px}
.team-card-id{min-width:0}
.team-card-flag{font-size:34px;line-height:1;margin-bottom:4px}
.team-card-hero h3{font-size:25px;line-height:1.1;margin:0;letter-spacing:-.01em;text-shadow:0 2px 10px rgba(0,0,0,.4)}
.team-card-hero p{margin:5px 0 0;color:rgba(232,238,252,.7);font-size:13px}
.kit-mini{position:relative;width:96px;height:118px;border-radius:18px 18px 24px 24px;background:var(--team-c1);box-shadow:inset 0 0 0 2px rgba(255,255,255,.24),0 14px 30px rgba(0,0,0,.28);display:grid;place-items:center;font-size:22px;font-weight:900;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.45)}
.kit-mini:before,.kit-mini:after{content:"";position:absolute;top:17px;width:28px;height:48px;background:inherit;border-radius:12px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.16)}
.kit-mini:before{left:-14px;transform:rotate(22deg)}.kit-mini:after{right:-14px;transform:rotate(-22deg)}
.kit-stripes{background:repeating-linear-gradient(90deg,var(--team-c1) 0 14px,var(--team-c2) 14px 28px)}
.kit-checks{background:conic-gradient(var(--team-c1) 25%,var(--team-c2) 0 50%,var(--team-c1) 0 75%,var(--team-c2) 0) 0/34px 34px}
.kit-cross{background:linear-gradient(90deg,transparent 38%,var(--team-c2) 38% 58%,transparent 58%),linear-gradient(0deg,transparent 39%,var(--team-c2) 39% 56%,transparent 56%),var(--team-c1)}
.kit-split{background:linear-gradient(90deg,var(--team-c1) 50%,var(--team-c2) 50%)}
.kit-diagonal,.kit-sash{background:linear-gradient(135deg,var(--team-c1) 0 43%,var(--team-c2) 43% 57%,var(--team-c1) 57%)}
.kit-bands{background:linear-gradient(180deg,var(--team-c1) 0 42%,var(--team-c2) 42% 58%,var(--team-c3) 58% 70%,var(--team-c1) 70%)}
.kit-chevron,.kit-waves{background:linear-gradient(135deg,transparent 38%,var(--team-c2) 38% 48%,transparent 48%),linear-gradient(225deg,transparent 38%,var(--team-c2) 38% 48%,transparent 48%),var(--team-c1)}
.kit-star,.kit-stars,.kit-leaf,.kit-palm,.kit-eagle,.kit-fern,.kit-serrated,.kit-quarters,.kit-tiger,.kit-yoke,.kit-circle,.kit-triangle{background:radial-gradient(circle at 50% 35%,var(--team-c3) 0 16%,transparent 17%),linear-gradient(135deg,var(--team-c1),var(--team-c2))}
.team-card-status{position:relative;display:inline-flex;align-items:center;gap:6px;border:1px solid color-mix(in srgb,var(--team-c3) 60%,rgba(255,255,255,.2));background:linear-gradient(135deg,color-mix(in srgb,var(--team-c3) 26%,rgba(0,0,0,.28)),rgba(0,0,0,.24));border-radius:999px;padding:7px 13px;color:#fff;font-weight:800;font-size:13px}
.team-card-model.is-champion .team-card-status{border-color:rgba(244,200,74,.7);background:linear-gradient(135deg,rgba(244,200,74,.3),rgba(0,0,0,.26));color:#fff}
.team-card-players-head{position:relative;margin:18px 0 9px;color:rgba(255,255,255,.78);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.team-card-players-head:after{content:"";display:inline-block;height:1px;width:46%;margin-left:10px;vertical-align:middle;background:linear-gradient(90deg,rgba(255,255,255,.22),transparent)}
.team-card-players{position:relative;list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px;flex:1}
.team-card-players li{display:flex;align-items:center;gap:11px;padding:9px 11px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);border-radius:12px;transition:background .15s ease}
.team-card-players li:hover{background:rgba(255,255,255,.12)}
.player-no{flex:none;display:grid;place-items:center;width:30px;height:30px;border-radius:9px;background:color-mix(in srgb,var(--team-c3) 36%,rgba(0,0,0,.4));color:#fff;font-size:14px;font-weight:900;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.player-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.player-main b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-meta{font-size:12px;color:rgba(232,238,252,.66);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team-card-foot{position:relative;display:flex;justify-content:space-between;gap:10px;align-items:center;margin-top:16px;padding-top:13px;border-top:1px solid rgba(255,255,255,.1)}
.team-card-foot a{font-size:12px;color:rgba(244,200,74,.9);text-decoration:none}
.team-card-foot a:hover{text-decoration:underline}
.team-card-actions{display:flex;gap:8px}

.bracket-toolbar{display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:18px}
.champion-banner{font-weight:800; color:var(--gold); font-size:16px}
.bracket{display:flex; gap:30px; overflow-x:auto; padding-bottom:16px}
.round{display:flex; flex-direction:column; gap:14px; min-width:210px; justify-content:space-around}
.round h4{position:sticky; top:0; margin:0 0 4px; color:var(--muted); font-size:13px; text-transform:uppercase; letter-spacing:.06em}
.ko-match{background:var(--card); border:1px solid var(--line); border-radius:10px; overflow:hidden}
.ko-team{display:flex; align-items:center; gap:8px; padding:8px 10px; cursor:pointer; font-size:14px; border-bottom:1px solid rgba(255,255,255,.06)}
.ko-team:last-child{border-bottom:none}
.ko-team:hover{background:var(--card2)}
.ko-team.win{background:rgba(34,197,94,.18); font-weight:700}
.ko-team.empty{color:var(--muted); cursor:default; font-style:italic}
.ko-team .seed{margin-left:auto; color:var(--muted); font-size:12px}
.model-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.model-tab{border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);padding:10px 14px;border-radius:999px;cursor:pointer;font-weight:800}
.model-tab.active{color:#04150a;background:linear-gradient(135deg,var(--gold),#f59e0b);border-color:transparent;box-shadow:0 8px 22px rgba(244,200,74,.2)}
.model-prediction{display:flex;flex-direction:column;gap:18px}
.model-hero-card{position:relative;overflow:hidden;display:flex;justify-content:space-between;gap:18px;align-items:center;background:linear-gradient(135deg,rgba(244,200,74,.16),rgba(22,33,58,.88));border:1px solid rgba(244,200,74,.34);border-radius:22px;padding:22px 24px;box-shadow:var(--shadow)}
.model-hero-card:before{content:"";position:absolute;right:70px;top:-90px;width:210px;height:210px;border-radius:50%;background:rgba(244,200,74,.18);filter:blur(10px)}
.model-hero-card h3{position:relative;margin:4px 0 8px;font-size:26px;line-height:1.25}
.model-hero-card p{position:relative;margin:0;color:var(--muted);max-width:720px}
.model-kicker{position:relative;color:var(--gold);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.model-hero-card.is-forced{background:linear-gradient(135deg,rgba(222,23,38,.22),rgba(22,33,58,.9));border-color:rgba(222,23,38,.5)}
.model-forced-badge{position:relative;display:inline-block;margin-top:10px;padding:5px 12px;border-radius:999px;background:rgba(222,23,38,.2);border:1px solid rgba(222,23,38,.5);color:#ffd7dc;font-size:12px;font-weight:800}
.model-trophy{position:relative;font-size:74px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.4))}
.model-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.model-summary-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.model-summary-card span{display:block;color:var(--muted);font-size:12px;font-weight:700;margin-bottom:6px}
.model-summary-card strong{font-size:15px;line-height:1.5}
.model-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:4px}
.model-section-head h3{margin:0;font-size:17px}
.model-section-head span{color:var(--muted);font-size:12px}
.model-bracket{display:flex;gap:18px;overflow-x:auto;padding-bottom:12px}
.model-round{min-width:220px;display:flex;flex-direction:column;gap:10px}
.model-round h4{margin:0;color:var(--gold);font-size:13px;letter-spacing:.06em}
.model-ko-match{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.model-ko-team{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;color:var(--muted)}
.model-ko-team:last-child{border-bottom:none}
.model-ko-team.win{color:var(--text);background:rgba(34,197,94,.14);font-weight:800}
.model-ko-team em{font-style:normal;color:var(--gold);font-weight:900}
.model-groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.model-group-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.model-group-head{display:flex;align-items:center;gap:10px;background:var(--card2);border-bottom:1px solid var(--line);padding:11px 14px}
.model-group-head span{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:var(--gold);color:#1f1600;font-weight:900}
.model-group-matches{padding:8px 12px}
.model-group-match{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;padding:7px 0;border-bottom:1px dashed rgba(255,255,255,.06);font-size:13px}
.model-group-match span:first-child{text-align:right}
.model-group-match b{color:var(--gold);background:var(--bg2);border:1px solid var(--line);border-radius:7px;padding:2px 8px}
.model-standings{width:100%;border-collapse:collapse;font-size:13px;margin:0 0 10px}
.model-standings th,.model-standings td{padding:6px 10px;text-align:left;border-top:1px solid rgba(255,255,255,.05)}
.model-standings th{color:var(--muted);font-size:12px;font-weight:700}
.model-standings tr.q td{background:rgba(34,197,94,.08)}

/* ---------- 预测 MVP ---------- */
.mvp-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.mvp-tab{border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);padding:10px 14px;border-radius:999px;cursor:pointer;font-weight:800}
.mvp-tab.active{color:#1f1600;background:linear-gradient(135deg,var(--gold),#f59e0b);border-color:transparent;box-shadow:0 8px 22px rgba(244,200,74,.2)}
.mvp-content{display:flex;flex-direction:column;gap:18px}
.mvp-hero{position:relative;overflow:hidden;border-radius:22px;border:1px solid rgba(244,200,74,.34);
  background:linear-gradient(135deg,rgba(244,200,74,.18),rgba(22,33,58,.9));box-shadow:var(--shadow);padding:20px 24px}
.mvp-hero:before{content:"";position:absolute;right:40px;top:-100px;width:240px;height:240px;border-radius:50%;background:rgba(244,200,74,.16);filter:blur(12px)}
.mvp-hero-badge{position:relative;display:inline-block;margin-bottom:14px;padding:5px 12px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(244,200,74,.4);color:var(--gold);font-size:12px;font-weight:900;letter-spacing:.1em}
.mvp-hero-body{position:relative;display:flex;align-items:center;gap:20px}
.mvp-hero-medal{font-size:72px;line-height:1;filter:drop-shadow(0 10px 22px rgba(0,0,0,.45))}
.mvp-hero-info{min-width:0}
.mvp-hero-model{color:var(--gold);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.mvp-hero-info h3{margin:6px 0 6px;font-size:30px;line-height:1.15}
.mvp-hero-info p{margin:0 0 8px;color:rgba(232,238,252,.78);font-size:14px}
.mvp-hero-team{color:var(--muted);font-size:13px;font-weight:600}
.mvp-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.mvp-section-head h3{margin:0;font-size:17px}
.mvp-section-head span{color:var(--muted);font-size:12px}
.mvp-list{display:flex;flex-direction:column;gap:9px}
.mvp-cand{display:grid;grid-template-columns:28px 26px 1fr 130px 52px;align-items:center;gap:11px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 14px;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.mvp-cand-rk{display:grid;place-items:center;width:24px;height:24px;border-radius:7px;background:var(--card2);color:var(--gold);font-weight:900;font-size:13px}
.mvp-cand-flag{font-size:22px;line-height:1}
.mvp-cand-main{min-width:0;display:flex;flex-direction:column;gap:2px}
.mvp-cand-main b{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mvp-cand-meta{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mvp-cand-bar{position:relative;height:7px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.mvp-cand-fill{position:absolute;left:0;top:0;bottom:0;border-radius:999px;background:linear-gradient(90deg,#f59e0b,var(--gold));min-width:2px}
.mvp-cand-pct{font-size:13px;font-weight:800;text-align:right;font-variant-numeric:tabular-nums}

/* ---------- 赛程时间线 ---------- */
.timeline-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.timeline-filters{display:flex;gap:6px;flex-wrap:wrap}
.timeline-filter{border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);padding:7px 14px;border-radius:999px;cursor:pointer;font-weight:700;font-size:13px}
.timeline-filter.active{color:#04150a;background:linear-gradient(135deg,var(--green),var(--green2));border-color:transparent}
.timeline{position:relative;padding-left:22px}
.timeline:before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,rgba(244,200,74,.5),rgba(39,55,92,.6))}
.timeline-day{position:relative;display:flex;align-items:center;gap:10px;margin:20px 0 12px}
.timeline-day:first-child{margin-top:4px}
.timeline-day-dot{position:absolute;left:-22px;width:14px;height:14px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(244,200,74,.18)}
.timeline-day-label{color:var(--gold);font-weight:800;font-size:14px;letter-spacing:.03em}
.timeline-item{position:relative;margin:0 0 12px}
.tl-marker{position:absolute;left:-22px;top:20px;width:10px;height:10px;border-radius:50%;background:var(--card2);border:2px solid var(--line)}
.timeline-item.finished .tl-marker{background:var(--green);border-color:var(--green)}
.timeline-item.upcoming .tl-marker{background:var(--accent);border-color:var(--accent)}
.tl-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 15px;box-shadow:0 8px 22px rgba(0,0,0,.2);transition:border-color .15s ease,transform .15s ease}
.tl-card:hover{transform:translateY(-2px);border-color:#3a5288}
.timeline-item.finished .tl-card{border-left:3px solid var(--green)}
.timeline-item.upcoming .tl-card{border-left:3px solid var(--accent)}
.tl-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.tl-round{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.03em}
.tl-time{font-size:12px;font-weight:700;color:var(--text);background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:3px 10px}
.timeline-item.finished .tl-time{color:var(--green)}
.tl-main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}
.tl-team{font-size:15px;font-weight:700}
.tl-team.home{text-align:right}
.tl-team.away{text-align:left}
.tl-center{display:flex;justify-content:center;min-width:80px}
.tl-score{font-size:20px;font-weight:900;font-variant-numeric:tabular-nums}
.tl-score.actual{color:var(--gold)}
.tl-score.pred{color:var(--muted);font-size:16px}
.tl-winner{color:var(--green);font-weight:800;font-size:14px;text-align:center}
.tl-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.07)}
.tl-venue{color:var(--muted);font-size:12px}
.tl-pred-info{color:var(--muted);font-size:12px}
.tl-source{display:inline-block;color:rgba(244,200,74,.9)}
.tl-pts{font-weight:800}
.tl-pts.hit-exact{color:var(--green)}
.tl-pts.hit-outcome{color:var(--accent)}
.tl-pts.miss{color:#ff9aa5}
.footer{border-top:1px solid var(--line); padding:18px 26px; color:var(--muted); font-size:12px; text-align:center}
.footer p{margin:4px 0}
.toast{position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); background:var(--card2); border:1px solid var(--line); color:var(--text); padding:11px 18px; border-radius:10px; box-shadow:var(--shadow); opacity:0; pointer-events:none; transition:.25s ease; z-index:50}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
@media (max-width:780px){
  .hero-title{font-size:20px}
  .favorites-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px}
  .model-summary-grid{grid-template-columns:1fr}
  .model-hero-card{align-items:flex-start}
  .model-trophy{font-size:54px}
}
@media (max-width:560px){
  .topbar{padding:14px}
  .tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}
  .tab{flex:0 0 auto}
  main{padding:14px 14px 50px}
  .groups-grid{grid-template-columns:1fr}
  .team-cards-grid{grid-template-columns:1fr}
  .team-card-foot{align-items:flex-start;flex-direction:column}
  .favorites-grid{grid-template-columns:1fr}
  .fav-model{grid-template-columns:74px 1fr 44px}
  .model-hero-card{padding:18px;flex-direction:column}
  .model-hero-card h3{font-size:22px}
  .model-groups-grid{grid-template-columns:1fr}
  .model-group-match{font-size:12px}
  .tl-main{grid-template-columns:1fr;gap:4px;text-align:center}
  .tl-team.home,.tl-team.away{text-align:center}
  .tl-foot{flex-direction:column;align-items:flex-start;gap:3px}
  .mvp-hero-body{flex-direction:column;align-items:flex-start;gap:12px}
  .mvp-hero-info h3{font-size:24px}
  .mvp-cand{grid-template-columns:24px 22px 1fr 46px;gap:9px}
  .mvp-cand-bar{display:none}
}

/* ---------- 排行榜 ---------- */
.lb-submit-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:22px;box-shadow:var(--shadow)}
.lb-submit-card h3{margin:0 0 8px;font-size:17px}
.lb-submit-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px}
.lb-input{flex:1;min-width:180px;padding:10px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg2);color:var(--text);font-size:15px}
.lb-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 2px rgba(34,197,94,.25)}
.submit-status{margin-top:10px;font-size:13px;color:var(--muted);min-height:20px}
.lb-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.lb-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.lb-card h3{margin:0 0 6px;font-size:16px}
.lb-meta{font-size:12px;color:var(--muted);margin:0 0 12px;line-height:1.5}
.lb-subtitle{margin:16px 0 8px;font-size:13px;color:var(--muted);font-weight:600}
.lb-table-wrap{overflow-x:auto}
.lb-table{width:100%;border-collapse:collapse;font-size:13px}
.lb-table th,.lb-table td{padding:8px 8px;text-align:left;border-bottom:1px solid rgba(255,255,255,.06)}
.lb-table th{color:var(--muted);font-weight:600;font-size:12px}
.lb-table tr.me td{background:rgba(34,197,94,.12);font-weight:600}
.lb-table .empty{text-align:center;color:var(--muted);padding:20px}
.lb-champions{display:flex;flex-direction:column;gap:8px}
.lb-champ-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--card2);border-radius:10px;border:1px solid var(--line);font-size:14px}
.lb-champ-item.top{border-color:rgba(244,200,74,.5);background:rgba(244,200,74,.08)}
.lb-champ-item .rk{color:var(--gold);font-weight:800;width:20px}
.lb-champ-item .fl{font-size:18px}
.lb-champ-item .cnt{margin-left:auto;color:var(--muted);font-size:12px}
.lb-scores{display:flex;flex-direction:column;gap:6px}
.lb-score-item{display:flex;align-items:center;gap:10px;padding:7px 10px;background:var(--card2);border-radius:8px;font-size:13px}
.lb-score-item .match{flex:1;color:var(--muted)}
.lb-score-item .score-pill{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:2px 8px;font-weight:700;color:var(--gold)}
.lb-score-item .cnt{color:var(--muted);font-size:12px;white-space:nowrap}
.empty{color:var(--muted);font-size:13px;margin:8px 0}
.btn-sm{padding:6px 12px;font-size:13px}
.lb-review-wrap,.lb-share-wrap{margin-top:18px}
.lb-review-list{display:flex;flex-direction:column;gap:8px}
.lb-review-item{display:grid;grid-template-columns:1fr auto;gap:4px 12px;padding:10px 12px;background:var(--card2);border-radius:10px;border:1px solid var(--line);font-size:13px}
.lb-review-item.hit-exact{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.08)}
.lb-review-item.hit-outcome{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.06)}
.lb-review-item.miss{border-color:rgba(239,68,68,.25)}
.lb-review-match{grid-column:1/-1;font-weight:600}
.lb-review-scores{color:var(--muted)}
.lb-review-pts{color:var(--gold);font-weight:700;white-space:nowrap}
.lb-share-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:12px}
.lb-share-card{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:12px}
.lb-share-card-head{display:flex;flex-direction:column;gap:4px}
.lb-share-card-head strong{font-size:15px}
.lb-share-card-head span{font-size:13px;color:var(--muted)}
.lb-share-card-actions{display:flex;gap:8px}
.card-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.card-modal[hidden]{display:none}
.card-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
.card-modal-panel{position:relative;z-index:1;width:min(420px,100%);max-height:90vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.card-modal-close{position:absolute;top:8px;right:10px;border:none;background:transparent;color:var(--muted);font-size:28px;cursor:pointer;line-height:1;padding:4px 8px}
.card-modal-close:hover{color:var(--text)}
.card-modal-preview{display:flex;justify-content:center;margin:28px 0 12px}
.card-modal-actions{display:flex;justify-content:center}

.share-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.share-modal[hidden]{display:none}
.share-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
.share-modal-panel{position:relative;z-index:1;width:min(520px,100%);max-height:90vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px 20px 18px;box-shadow:var(--shadow)}
.share-modal-close{position:absolute;top:8px;right:10px;border:none;background:transparent;color:var(--muted);font-size:28px;cursor:pointer;line-height:1;padding:4px 8px}
.share-modal-close:hover{color:var(--text)}
.share-modal-title{margin:0 0 6px;font-size:18px}
.share-modal-hint{margin:0 0 14px;font-size:13px}
.share-preview{margin:0 0 14px;padding:12px 14px;background:var(--card2);border:1px solid var(--line);border-radius:12px;font-family:inherit;font-size:13px;line-height:1.55;color:var(--text);white-space:pre-wrap;word-break:break-word;max-height:180px;overflow:auto}
.share-url-label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.share-url-input{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--bg2);color:var(--text);font-size:13px;margin-bottom:14px}
.share-modal-actions{display:flex;gap:8px;flex-wrap:wrap}
@media (max-width:900px){.lb-grid{grid-template-columns:1fr}}
