/* ============================================================
 * 2026世界杯模拟器 — 视觉样式 v2 (深色体育/电竞风)
 * ============================================================ */
:root{
  --bg:#0a0e1a;--bg2:#11182b;--panel:#151d33;--panel2:#1c2740;--line:#27324f;
  --txt:#e8eefc;--txt2:#8fa0c4;--txt3:#5e6e92;--gold:#ffd23f;--green:#2ee6a0;
  --red:#ff5470;--blue:#4d8dff;--home:#2ee6a0;--away:#ff7a45;--draw:#7d8aa8;
  --grass1:#1f7a3d;--grass2:#1a6b35;--shadow:0 8px 32px rgba(0,0,0,.45);--radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,"PingFang SC","Microsoft YaHei","Segoe UI",system-ui,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%,#16213d 0%,var(--bg) 55%);color:var(--txt);
  line-height:1.5;-webkit-font-smoothing:antialiased;padding-bottom:40px}
.wrap{max-width:1240px;margin:0 auto;padding:0 20px}

header.top{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(10,14,26,.92),rgba(10,14,26,.7));border-bottom:1px solid var(--line)}
.top-in{max-width:1240px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:16px}
.logo{font-weight:900;font-size:20px;display:flex;align-items:center;gap:10px}
.logo .badge{background:linear-gradient(135deg,var(--gold),#ff9e2f);color:#1a1205;font-size:11px;font-weight:900;padding:3px 9px;border-radius:20px;letter-spacing:1px}
.logo small{color:var(--txt2);font-weight:600;font-size:12px;margin-left:4px}
.top-sub{margin-left:auto;color:var(--txt3);font-size:12px;text-align:right;line-height:1.4}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.ph{font-size:13px;font-weight:800;color:var(--txt2);letter-spacing:1px;margin-bottom:12px}
.section-title{font-size:13px;font-weight:800;color:var(--txt2);letter-spacing:2px;text-transform:uppercase;margin:30px 4px 12px;display:flex;align-items:center;gap:10px}
.section-title::before{content:'';width:4px;height:16px;background:var(--gold);border-radius:2px}

/* ---------- 赛程筛选 ---------- */
.filters{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:8px 4px 14px}
.filter-group{display:flex;gap:6px;flex-wrap:wrap}
.fbtn{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--txt2);
  font-size:12px;font-weight:700;padding:6px 13px;border-radius:20px;transition:.15s;font-family:inherit}
.fbtn:hover{border-color:var(--txt2)}
.fbtn.on{background:var(--gold);color:#1a1205;border-color:var(--gold)}
.sched-count{margin-left:auto;color:var(--txt3);font-size:12px;font-weight:700}

/* ---------- 赛程卡网格 ---------- */
.schedule{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
.fxcard{position:relative;cursor:pointer;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 14px 12px;transition:.18s;overflow:hidden}
.fxcard:hover{transform:translateY(-2px);border-color:var(--gold)}
.fxcard.active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.fxhead{font-size:10px;color:var(--txt3);font-weight:700;letter-spacing:.5px;margin-bottom:10px}
.fxteams{display:flex;align-items:center;justify-content:space-between;gap:6px}
.fxt{display:flex;align-items:center;gap:6px;flex:1;min-width:0}
.fxt.away{flex-direction:row-reverse}
.fxflag{font-size:20px}.fxn{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fvs{font-size:11px;color:var(--txt3);font-weight:800}
.fscore{font-size:16px;font-weight:900;color:var(--gold);font-variant-numeric:tabular-nums}
.tag{position:absolute;top:8px;right:8px;font-size:8px;font-weight:800;padding:2px 6px;border-radius:8px;letter-spacing:.5px}
.tag.val{background:rgba(46,230,160,.16);color:var(--green);border:1px solid rgba(46,230,160,.4)}
.tag.pred{background:rgba(77,141,255,.16);color:var(--blue);border:1px solid rgba(77,141,255,.4)}

/* ---------- 主分析双栏 ---------- */
.analysis{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;margin-top:8px;align-items:start}
@media(max-width:980px){.analysis{grid-template-columns:1fr}}

.infobar{display:flex;gap:14px;flex-wrap:wrap;padding:14px 18px;font-size:12px;color:var(--txt2)}
.infobar .chip{display:flex;align-items:center;gap:6px;background:var(--panel2);padding:6px 12px;border-radius:20px}
.infobar .chip b{color:var(--txt)}

/* ---------- 球场演出 ---------- */
.pitch-wrap{padding:18px}
.scoreboard{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sb-team{display:flex;align-items:center;gap:10px;flex:1}.sb-team.away{flex-direction:row-reverse;text-align:right}
.sb-flag{font-size:34px;line-height:1}.sb-name{font-weight:800;font-size:16px}.sb-elo{font-size:11px;color:var(--txt2)}
.sb-score{font-size:42px;font-weight:900;font-variant-numeric:tabular-nums;padding:0 18px;min-width:120px;text-align:center}
.sb-score .sep{color:var(--txt3);margin:0 4px}
.clock{text-align:center;font-size:12px;color:var(--gold);font-weight:800;letter-spacing:1px;margin-bottom:10px;height:16px}
svg.pitch{width:100%;height:auto;display:block;border-radius:12px;background:linear-gradient(160deg,var(--grass1),var(--grass2))}
.ball{filter:drop-shadow(0 2px 3px rgba(0,0,0,.5));transition:cx .25s linear,cy .25s linear}
.controls{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap;align-items:center}
.btn{border:none;cursor:pointer;font-weight:800;font-size:13px;padding:11px 20px;border-radius:10px;transition:.15s;font-family:inherit}
.btn:active{transform:scale(.96)}
.btn-primary{background:linear-gradient(135deg,var(--gold),#ff9e2f);color:#1a1205}
.btn-ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.speed{display:flex;align-items:center;gap:6px;margin-left:auto;color:var(--txt2);font-size:12px}
.speed select{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-family:inherit;font-size:12px}

.feed{max-height:300px;overflow-y:auto;padding:4px}
.feed::-webkit-scrollbar{width:6px}.feed::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.ev{display:flex;gap:10px;align-items:flex-start;padding:8px 10px;border-radius:9px;margin-bottom:5px;font-size:13px;animation:slideIn .35s ease;border-left:3px solid transparent}
@keyframes slideIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.ev .min{font-weight:800;color:var(--gold);min-width:34px}
.ev.goal{background:rgba(255,210,63,.1);border-left-color:var(--gold);font-weight:700}
.ev.sub{background:rgba(77,141,255,.08);border-left-color:var(--blue);font-size:12px}
.ev.shot,.ev.corner{color:var(--txt2)}.ev.yellow{background:rgba(255,210,63,.06)}
.ev.halftime,.ev.fulltime,.ev.kickoff{background:var(--panel2);color:var(--txt2);font-weight:700;justify-content:center}

/* ---------- 概率/实力/热力 ---------- */
.prob-bar{display:flex;height:38px;border-radius:10px;overflow:hidden;font-weight:800;font-size:13px}
.prob-seg{display:flex;align-items:center;justify-content:center;color:#0a0e1a;transition:width .6s cubic-bezier(.4,0,.2,1);min-width:30px}
.prob-seg.h{background:linear-gradient(135deg,var(--home),#26c98c)}.prob-seg.d{background:var(--draw)}.prob-seg.a{background:linear-gradient(135deg,var(--away),#ff6a2f)}
.prob-legend{display:flex;justify-content:space-between;font-size:11px;color:var(--txt2);margin-top:6px}
.chip{display:inline-flex;align-items:center;gap:4px;background:var(--panel2);padding:5px 10px;border-radius:14px}
.stat-grid{display:grid;grid-template-columns:1fr 80px 1fr;gap:10px 10px;align-items:center;padding:14px 0}
.stat-label{text-align:center;font-size:11px;color:var(--txt3);font-weight:700}
.stat-val{font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}.stat-val.l{text-align:right}.stat-val.r{text-align:left}
.heat{display:grid;gap:2px}.heat-cell{aspect-ratio:1;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:rgba(255,255,255,.85)}

/* ---------- 自动因素 ---------- */
.factors{font-size:13px}
.facrow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--line)}
.facrow:last-of-type{border:none}.facrow b.pos{color:var(--green)}.facrow b.neg{color:var(--red)}
.fac-note{font-size:11px;color:var(--txt3);margin-top:10px;padding:10px;background:rgba(46,230,160,.06);border-radius:8px;border:1px solid rgba(46,230,160,.2);line-height:1.5}
.fac-note b{color:var(--green)}

/* ---------- 阵型站位 ---------- */
.formations{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:860px){.formations{grid-template-columns:1fr}}
.fmpanel{padding:16px}
.fmtitle{font-size:14px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fmtag{font-size:11px;background:var(--gold);color:#1a1205;padding:2px 8px;border-radius:8px;font-weight:800}
.fmcoach{font-size:11px;color:var(--txt3);font-weight:600}
.fmpitch{position:relative;aspect-ratio:16/10;background:linear-gradient(160deg,var(--grass1),var(--grass2));border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.15)}
.fmpitch::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:rgba(255,255,255,.2)}
.fmpitch::after{content:'';position:absolute;left:50%;top:50%;width:60px;height:60px;border:2px solid rgba(255,255,255,.2);border-radius:50%;transform:translate(-50%,-50%)}
.formation{position:absolute;inset:0}
.pl{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:2}
.pl-num{width:28px;height:28px;border-radius:50%;background:var(--blue);color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.6)}
.pl.key .pl-num{background:var(--gold);color:#1a1205}
.pl.gk .pl-num{background:var(--red)}
.pl-name{font-size:9px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9);white-space:nowrap;background:rgba(10,14,26,.5);padding:0 4px;border-radius:4px}
.noxi{position:absolute;top:10px;left:0;right:0;text-align:center;font-size:12px;color:rgba(255,255,255,.7);z-index:3;line-height:1.5}
.noxi span{font-size:10px;color:rgba(255,255,255,.5)}

/* ---------- 换人预测 ---------- */
.subpred{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.subpred{grid-template-columns:1fr}}
.subcol h5{font-size:13px;margin-bottom:12px;color:var(--txt)}
.nosub{font-size:12px;color:var(--txt3);padding:14px;background:var(--panel2);border-radius:10px}
.subitem{display:flex;gap:12px;padding:11px;background:var(--panel2);border-radius:10px;margin-bottom:8px;border-left:3px solid var(--blue)}
.submin{font-size:16px;font-weight:900;color:var(--gold);min-width:36px}
.subbody{flex:1}
.subswap{font-size:13px;font-weight:700;margin-bottom:3px}
.subswap .out{color:var(--red)}.subswap .in{color:var(--green)}
.subreason{font-size:11px;color:var(--txt2);margin-bottom:4px}
.subdelta{font-size:11px;color:var(--txt3)}
.subdelta b.pos{color:var(--green)}.subdelta b.neg{color:var(--red)}

/* ---------- 验证 ---------- */
.valid-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:760px){.valid-grid{grid-template-columns:1fr}}
.valid-card{padding:16px}
.valid-card .vh{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:800;font-size:14px}
.hit{font-size:11px;font-weight:800;padding:3px 10px;border-radius:12px}
.hit.yes{background:rgba(46,230,160,.16);color:var(--green)}.hit.no{background:rgba(255,84,112,.16);color:var(--red)}
.vrow{display:flex;justify-content:space-between;font-size:12px;padding:5px 0;color:var(--txt2)}.vrow b{color:var(--txt);font-variant-numeric:tabular-nums}
.vreal{font-size:20px;font-weight:900;color:var(--gold);text-align:center;margin:8px 0;letter-spacing:2px}

.disclaimer{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-top:18px;font-size:12px;color:var(--txt2);line-height:1.7}
.disclaimer b{color:var(--gold)}
footer{text-align:center;color:var(--txt3);font-size:11px;margin-top:24px;line-height:1.7}
