:root{--primary:#101827;--accent:#123442;--highlight:#D91F3C;--gold:#D7A537;--green:#0F9F6E;--blue:#2563EB;--turquoise:#1BB7A8;--pitch:#0D6B46;--bg:#F6F8F5;--card-bg:#fff;--text:#1E293B;--text-light:#64748B;--border:#DDE5E0;--live:#10B981;--radius:12px;--shadow:0 1px 3px rgba(15,23,42,0.08),0 1px 2px rgba(15,23,42,0.05);--shadow-hover:0 14px 30px rgba(15,23,42,0.12)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:radial-gradient(circle at 15% 0%,rgba(215,165,55,0.14),transparent 28%),radial-gradient(circle at 88% 8%,rgba(27,183,168,0.12),transparent 26%),linear-gradient(180deg,#F7FAF6 0%,#EFF5F1 55%,#F8FAFC 100%);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;min-height:100vh;display:flex;flex-direction:column}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:linear-gradient(rgba(13,107,70,0.045) 1px,transparent 1px),linear-gradient(90deg,rgba(13,107,70,0.045) 1px,transparent 1px),radial-gradient(circle at 50% 12%,rgba(255,255,255,0.8),transparent 18%);background-size:72px 72px,72px 72px,100% 100%;mask-image:linear-gradient(180deg,#000 0%,rgba(0,0,0,0.65) 45%,transparent 92%)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}

/* ── Header ── */
.header{background:linear-gradient(135deg,#09131F 0%,#0F3F3A 58%,#123442 100%);color:#fff;padding:0 16px;position:sticky;top:0;z-index:100;box-shadow:0 8px 28px rgba(9,19,31,0.18)}
.header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--highlight),var(--gold),var(--turquoise),var(--blue));opacity:0.95}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px;gap:12px}
.logo{font-size:1.25rem;font-weight:800;white-space:nowrap;flex-shrink:0;display:flex;align-items:center}.logo img{height:40px;width:auto;display:block}
.member-badge{display:inline-block;padding:3px 10px;border-radius:10px;font-size:0.72rem;font-weight:700;white-space:nowrap}
.member-gold{background:linear-gradient(135deg,#FFD700,#F59E0B);color:#7C2D12}
.member-diamond{background:linear-gradient(135deg,#93C5FD,#3B82F6);color:#1E3A5F}
.member-group{background:linear-gradient(135deg,#A78BFA,#7C3AED);color:#fff}
.upgrade-btn{display:inline-block;padding:3px 10px;border-radius:10px;font-size:0.75rem;font-weight:700;background:linear-gradient(135deg,#F59E0B,#D97706);color:#fff;text-decoration:none;white-space:nowrap}
/* ── Bottom Mobile Nav ── */
.mb-nav{display:none}
@media(max-width:767px){
.mb-nav{display:block;position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1a1a2e,#16213e);z-index:200;height:60px;border-top:1px solid rgba(255,255,255,0.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.mb-nav-inner{display:flex;height:100%;max-width:500px;margin:0 auto}
.mb-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);font-size:0.6rem;font-weight:500;text-decoration:none;gap:3px;transition:color 0.2s;-webkit-tap-highlight-color:transparent}
.mb-nav-item.active{color:#e94560}
.mb-nav-item:hover{color:rgba(255,255,255,0.8)}
.mb-nav-item .icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.mb-nav-item .icon svg{width:20px;height:20px;stroke-width:1.8}
.mb-nav-item.active .icon svg{stroke-width:2.2}
.mb-nav-item .label{font-size:0.6rem;letter-spacing:0.3px;line-height:1}
body{padding-bottom:60px}
.footer{padding-bottom:72px}
}

/* ── Dark Page Theme ── */
.dark-page{background:linear-gradient(180deg,#0a0e1a 0%,#0f1628 50%,#1a1a2e 100%);color:#fff;min-height:100vh}
.dark-page .header{background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom:1px solid rgba(255,255,255,0.08)}
.dark-page .container{max-width:680px}
.page-data .container{max-width:940px}
.dark-page .card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:#fff}
.dark-page .card-header{border-bottom:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.85)}
.dark-page .card-body{color:rgba(255,255,255,0.8)}
.dark-page .footer{background:#0a0e1a;border-top:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.4)}
.dark-page .footer a{color:rgba(255,255,255,0.6)}
.dark-page .footer-links a{color:rgba(255,255,255,0.6)}
.dark-page .match-row{border-bottom:1px solid rgba(255,255,255,0.06);color:rgba(255,255,255,0.8)}
.dark-page .match-row:hover{background:rgba(255,255,255,0.04)}
.dark-page .form-input{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.15);color:#fff}
.dark-page .form-input:focus{border-color:var(--highlight);box-shadow:0 0 0 3px rgba(233,69,96,0.2)}
.dark-page .error-msg{background:rgba(233,69,96,0.15);color:#e94560;border-color:rgba(233,69,96,0.3)}
.dark-page .success-msg{background:rgba(16,185,129,0.15);color:#10B981;border-color:rgba(16,185,129,0.3)}
.dark-page .pts-history-table th{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5)}
.dark-page .pts-history-table td{border-bottom:1px solid rgba(255,255,255,0.06);color:rgba(255,255,255,0.8)}
.dark-page .pts-history-table tr:hover td{background:rgba(255,255,255,0.04)}

/* ── Layout ── */
.container{max-width:1200px;margin:0 auto;padding:16px}
@media(min-width:768px){
.container{max-width:960px;padding:24px}
}
.section-title{font-size:1.25rem;font-weight:800;margin:20px 0 12px;color:var(--primary)}
.group-title{font-size:1.05rem;font-weight:700;padding:10px 0;color:var(--primary);border-bottom:2px solid var(--highlight);margin-bottom:10px}

/* ── Cards ── */
.card{background:linear-gradient(180deg,#fff 0%,#FBFDFB 100%);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:14px;border:1px solid var(--border);overflow:hidden}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border);font-weight:700;display:flex;align-items:center;justify-content:space-between;font-size:0.95rem;color:var(--primary)}
.card-body{padding:16px 18px}

/* ── Match row ── */
.match-row{display:flex;align-items:center;padding:12px 18px;border-bottom:1px solid var(--border);gap:10px;transition:background 0.15s}
.match-row:last-child{border-bottom:none}
.match-row:hover{background:#F1F5F9}
.match-time{width:75px;text-align:center;font-size:0.8rem;color:var(--text-light);flex-shrink:0}
.match-time .date{font-size:0.7rem}
.match-time .time{font-weight:700;font-size:0.95rem;color:var(--text)}
.match-teams{flex:1;display:flex;align-items:center;gap:10px;min-width:0}
.match-teams span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.match-teams .team-side,.mc-team{display:inline-flex;align-items:center;gap:6px;min-width:0}
.match-teams .team-side a,.mc-team-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-badge{width:34px;height:24px;border-radius:3px;object-fit:contain;background:transparent;flex-shrink:0}
.match-score{font-size:1.2rem;font-weight:800;margin:0 12px;min-width:45px;text-align:center;flex-shrink:0}
.match-vs{color:var(--text-light);font-size:0.8rem;font-weight:500;text-transform:uppercase;flex-shrink:0}

/* ── Buttons ── */
.btn{display:inline-block;padding:9px 20px;border-radius:8px;font-size:0.88rem;font-weight:600;cursor:pointer;border:none;text-align:center;transition:all 0.2s;white-space:nowrap}
.btn-primary{background:var(--highlight);color:#fff;box-shadow:0 2px 8px rgba(233,69,96,0.3)}
.btn-primary:hover{background:#D6384E;transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;border:2px solid var(--highlight);color:var(--highlight)}
.btn-sm{padding:6px 14px;font-size:0.8rem}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none!important}

/* ── Banner ── */
.banner{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;border-radius:var(--radius);padding:36px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;overflow:hidden}
.banner h2{font-size:1.7rem;margin-bottom:8px;font-weight:800}
.banner p{font-size:0.95rem;opacity:0.85;max-width:500px}

/* ── Footer ── */
body>.container{flex:1 0 auto;width:100%}
.footer{background:var(--primary);color:rgba(255,255,255,0.65);padding:32px 16px;margin-top:auto;text-align:center;font-size:0.82rem;flex-shrink:0}
.footer-links{display:flex;gap:20px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}
.footer a{color:rgba(255,255,255,0.85);font-weight:500}

/* ── Forum ── */
.hot-post{padding:12px 18px;border-bottom:1px solid var(--border);display:block;transition:background 0.15s}
.hot-post:hover{background:#F8FAFC}
.hot-post:last-child{border-bottom:none}
.hot-post .meta{font-size:0.78rem;color:var(--text-light);margin-bottom:2px}
.hot-post .text{font-size:0.88rem;margin-bottom:4px}
.hot-post .reactions{display:flex;gap:12px;font-size:0.78rem;color:var(--text-light)}

/* ── Forms ── */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-weight:600;margin-bottom:5px;font-size:0.88rem}
.form-input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:0.92rem;transition:border-color 0.2s;background:#fff}
.form-input:focus{border-color:var(--highlight);box-shadow:0 0 0 3px rgba(233,69,96,0.1);outline:none}
textarea.form-input{resize:vertical;min-height:100px}

/* ── Auth pages: sticky footer layout ── */
body.page-login,body.page-register,body.page-forgot{
  display:flex;flex-direction:column;min-height:100vh;
}
body.page-login .container,body.page-register .container,body.page-forgot .container{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:40px;padding-bottom:40px;
}
body.page-login .footer,body.page-register .footer,body.page-forgot .footer{
  margin-top:0;
}

/* ── Auth cards ── */
.auth-card{max-width:420px;width:100%;margin:0 auto;border-radius:14px;box-shadow:0 4px 24px rgba(0,0,0,0.08);border:1px solid var(--border);background:#fff}
.auth-header{text-align:center;padding:28px 20px 0;font-size:1.4rem;font-weight:800;color:var(--primary)}
.auth-sub{text-align:center;padding:4px 20px 20px;color:var(--text-light);font-size:0.88rem}
.auth-body{padding:0 28px 24px}
.auth-footer{text-align:center;padding:0 28px 22px;font-size:0.85rem;color:var(--text-light);border-top:1px solid var(--border);margin-top:6px;padding-top:18px}
.auth-footer a{color:var(--highlight);font-weight:700}
/* Social login (Google OAuth) */
.social-login{margin-top:20px}
.social-login .divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:#64748b;font-size:0.8rem}
.social-login .divider::before,.social-login .divider::after{content:'';flex:1;height:1px;background:rgba(0,0,0,0.1)}
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;border-radius:8px;background:#fff;color:#333;font-weight:500;font-size:0.9rem;text-decoration:none;transition:all 0.2s;border:1px solid #dadce0}
.google-btn:hover{background:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.08)}
/* Auth responsive: ensure touch-friendly inputs on mobile */
@media(max-width:768px){
  body.page-login .container,body.page-register .container,body.page-forgot .container{
    align-items:flex-start;padding-top:20px;
  }
  .auth-card{max-width:100%;margin:8px auto}
  .auth-card .form-input{min-height:44px;font-size:1rem;padding:12px 14px}
  .auth-card .btn{min-height:44px;font-size:1rem}
  .auth-body{padding:0 20px 18px}
}
@media(max-width:480px){
  .auth-card{margin:4px auto;border-radius:10px}
  .auth-card .form-input{padding:11px 12px;font-size:1rem;min-height:44px}
  .auth-body{padding:0 14px 14px}
}

/* ── Messages ── */
.empty{text-align:center;padding:48px 16px;color:var(--text-light)}
.error-msg{background:#FEF2F2;color:#991B1B;padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:0.88rem;border:1px solid #FECACA}
.success-msg{background:#ECFDF5;color:#065F46;padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:0.88rem;border:1px solid #A7F3D0}

/* ── Trust bar ── */
.trust-bar{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:16px 0;font-size:0.82rem;color:var(--text-light)}
.trust-bar span{display:flex;align-items:center;gap:4px}

/* ── World Cup Home Theme ── */
.page-home .container{position:relative}
.page-home .container::before{content:"WORLD CUP 2026";position:absolute;top:18px;right:18px;color:rgba(16,24,39,0.045);font-weight:900;font-size:clamp(2.2rem,9vw,8rem);line-height:0.9;letter-spacing:0;pointer-events:none;z-index:-1}
.wc-kicker{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,0.13);border:1px solid rgba(255,255,255,0.22);font-size:0.72rem;font-weight:800;text-transform:uppercase;color:#fff;white-space:nowrap}
.wc-kicker::before{content:"";width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#fff,var(--highlight));box-shadow:0 0 0 4px rgba(255,255,255,0.08)}
.world-cup-hero{position:relative;overflow:hidden;border-radius:var(--radius);margin-bottom:14px;min-height:380px;display:flex;align-items:center;color:#fff;background:#07101d;box-shadow:0 18px 44px rgba(7,16,29,0.22)}
.wc-hero-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.wc-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(5,11,21,0.9) 0%,rgba(5,11,21,0.72) 42%,rgba(5,11,21,0.18) 78%),linear-gradient(0deg,rgba(5,11,21,0.72) 0%,rgba(5,11,21,0.08) 45%)}
.world-cup-hero .hero-content{z-index:2;padding:32px 40px 104px;max-width:540px;position:relative}
.world-cup-hero h2{font-size:2rem;font-weight:800;margin-bottom:10px;line-height:1.15;letter-spacing:0}
.world-cup-hero h2 .accent{color:var(--highlight)}
.world-cup-hero p{font-size:0.92rem;opacity:0.82;margin-bottom:20px;line-height:1.55;max-width:420px}
.world-cup-hero .hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.world-cup-hero .hero-btns .btn-white{background:#fff;color:#0a1628;font-weight:700;padding:12px 24px}
.world-cup-hero .hero-btns .btn-white:hover{background:#f0f0f0;transform:translateY(-2px)}
.world-cup-hero .hero-btns .btn-ghost{border:2px solid rgba(255,255,255,0.35);color:#fff;padding:12px 24px}
.world-cup-hero .hero-btns .btn-ghost:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.6)}
.world-cup-hero .hero-stats-strip{position:absolute;bottom:0;left:0;right:0;z-index:3;display:flex;background:rgba(0,0,0,0.44);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,0.08)}
.world-cup-hero .hero-stat-item{flex:1;text-align:center;padding:14px 8px;border-right:1px solid rgba(255,255,255,0.06)}
.world-cup-hero .hero-stat-item:last-child{border-right:none}
.world-cup-hero .hero-stat-item .val{font-size:1.4rem;font-weight:800;line-height:1}
.world-cup-hero .hero-stat-item .val.red{color:var(--highlight)}
.world-cup-hero .hero-stat-item .val.gold{color:var(--gold)}
.world-cup-hero .hero-stat-item .val.blue{color:var(--blue)}
.world-cup-hero .hero-stat-item .val.green{color:var(--green)}
.world-cup-hero .hero-stat-item .lbl{font-size:0.65rem;opacity:0.62;margin-top:3px;text-transform:uppercase;letter-spacing:0.5px}
.wc-schedule-banner{position:relative;display:block;overflow:hidden;border-radius:var(--radius);margin:0 0 16px;min-height:132px;background:#0b1320;color:#fff;box-shadow:var(--shadow);border:1px solid rgba(13,107,70,0.16)}
.wc-schedule-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 0.25s ease}
.wc-schedule-banner:hover img{transform:scale(1.025)}
.wc-schedule-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,11,21,0.78),rgba(5,11,21,0.2) 70%)}
.wc-schedule-banner__copy{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;min-height:132px;max-width:520px;padding:22px 28px}
.wc-schedule-banner__copy strong{font-size:1.25rem;line-height:1.2;font-weight:900}
.wc-schedule-banner__copy span{margin-top:6px;font-size:0.86rem;line-height:1.45;color:rgba(255,255,255,0.82)}
.wc-host-strip{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 20px}
.wc-host-chip{display:inline-flex;align-items:center;height:28px;padding:0 11px;border-radius:999px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.16);font-size:0.72rem;font-weight:800;color:rgba(255,255,255,0.86)}
.wc-cup-mark{position:absolute;right:24%;top:34px;width:118px;height:150px;z-index:3;opacity:0.22;filter:drop-shadow(0 18px 26px rgba(0,0,0,0.35))}
.wc-cup-mark::before{content:"";position:absolute;left:28px;top:0;width:62px;height:86px;border-radius:28px 28px 18px 18px;background:linear-gradient(135deg,#FCE8A7 0%,#D7A537 52%,#8D6424 100%)}
.wc-cup-mark::after{content:"";position:absolute;left:40px;top:78px;width:38px;height:74px;background:linear-gradient(180deg,#D7A537,#8D6424);clip-path:polygon(34% 0,66% 0,78% 56%,100% 56%,100% 74%,0 74%,0 56%,22% 56%)}
.wc-stage-card{position:relative;border-left:4px solid var(--turquoise)}
.wc-stage-card::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,107,70,0.04),transparent 38%);pointer-events:none}
.wc-section-head{display:flex;align-items:center;justify-content:space-between;margin:18px 0 10px;gap:12px}
.wc-section-title{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:900;color:var(--primary);letter-spacing:0}
.wc-section-title::before{content:"";width:26px;height:26px;flex:0 0 26px;border:2px solid #fff;box-shadow:0 2px 10px rgba(15,23,42,0.14)}
.wc-section-title--matches::before{border-radius:8px;background:linear-gradient(180deg,var(--highlight) 0 30%,#fff 30% 100%),linear-gradient(90deg,transparent 0 22%,rgba(16,24,39,0.14) 22% 25%,transparent 25% 47%,rgba(16,24,39,0.14) 47% 50%,transparent 50% 72%,rgba(16,24,39,0.14) 72% 75%,transparent 75%),linear-gradient(180deg,transparent 0 52%,rgba(16,24,39,0.14) 52% 56%,transparent 56%);background-blend-mode:normal,multiply,multiply}
.wc-section-title--discussions::before{border-radius:9px 9px 9px 3px;background:radial-gradient(circle at 34% 50%,#fff 0 2px,transparent 2.5px),radial-gradient(circle at 50% 50%,#fff 0 2px,transparent 2.5px),radial-gradient(circle at 66% 50%,#fff 0 2px,transparent 2.5px),linear-gradient(135deg,var(--turquoise),var(--blue));clip-path:polygon(0 0,100% 0,100% 76%,66% 76%,52% 100%,48% 76%,0 76%)}
.wc-view-link{font-size:0.8rem;color:var(--highlight);font-weight:800;white-space:nowrap}
.wc-match-list{border:1px solid rgba(13,107,70,0.14)}
.ml-group{background:linear-gradient(90deg,#0D6B46,#123442)!important;color:#fff!important;border-bottom:0!important;top:0}
.ml-group::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);margin-right:8px;vertical-align:1px}
.ml-compact{position:relative;background:#fff}
.ml-compact .team-badge{width:34px;height:24px}
.ml-compact .mc-team{flex:1;overflow:hidden}
.ml-compact::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background 0.2s}
.ml-compact:hover::after{background:linear-gradient(180deg,var(--highlight),var(--gold))}
.wc-today-card .card-header{background:linear-gradient(90deg,rgba(217,31,60,0.08),rgba(27,183,168,0.08));color:var(--primary)}
.wc-today-card .match-row{background:#fff}
.wc-today-card .match-row:hover{background:#F4FBF7}

/* ── Grid helpers ── */
.grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:768px){.grid-2col{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════ */
/* ── RESPONSIVE: Tablet (≤1024px) ── */
/* ══════════════════════════════════════════════════ */
@media(max-width:1024px){
  .header-inner{height:52px}
  .container{padding:14px 12px}
  .banner{padding:28px}
  .banner h2{font-size:1.5rem}
  .card-header{padding:12px 14px;font-size:0.9rem}
  .card-body{padding:14px}
  .match-row{padding:10px 14px;gap:8px}
  .match-time{width:65px}
  .section-title{font-size:1.15rem}
  .auth-card{margin:8px auto}
  .banner{flex-direction:column;text-align:center;gap:16px}
}

/* ══════════════════════════════════════════════════ */
/* ── RESPONSIVE: Mobile (≤768px) ── */
/* ══════════════════════════════════════════════════ */
@media(max-width:768px){
  .page-home .container::before{top:8px;right:8px;font-size:3rem}
  .world-cup-hero{min-height:320px;border-radius:10px}
  .wc-hero-image{object-position:61% center}
  .wc-hero-overlay{background:linear-gradient(90deg,rgba(5,11,21,0.92),rgba(5,11,21,0.62) 70%,rgba(5,11,21,0.22)),linear-gradient(0deg,rgba(5,11,21,0.78),rgba(5,11,21,0.05) 50%)}
  .world-cup-hero .hero-content{padding:20px 18px 82px;max-width:82%}
  .world-cup-hero h2{font-size:1.35rem}
  .world-cup-hero p{font-size:0.82rem;margin-bottom:14px}
  .world-cup-hero .hero-btns{gap:8px}
  .world-cup-hero .hero-btns .btn-white,.world-cup-hero .hero-btns .btn-ghost{padding:9px 14px}
  .world-cup-hero .hero-stat-item{padding:11px 6px}
  .world-cup-hero .hero-stat-item .val{font-size:1.05rem}
  .world-cup-hero .hero-stat-item .lbl{font-size:0.58rem}
  .wc-schedule-banner{min-height:112px;border-radius:10px;margin-bottom:12px}
  .wc-schedule-banner img{object-position:62% center}
  .wc-schedule-banner__copy{min-height:112px;padding:16px 18px;max-width:78%}
  .wc-schedule-banner__copy strong{font-size:1.02rem}
  .wc-schedule-banner__copy span{font-size:0.76rem}
  .wc-cup-mark{right:8px;top:18px;width:78px;height:100px;opacity:0.16}
  .wc-cup-mark::before{left:18px;width:42px;height:58px}
  .wc-cup-mark::after{left:26px;top:52px;width:26px;height:50px}
  .wc-host-strip{gap:6px;margin:10px 0 14px}
  .wc-host-chip{height:24px;padding:0 9px;font-size:0.66rem}
  .wc-section-head{margin:14px 0 8px}
  .wc-section-title{font-size:0.96rem}
  .wc-section-title::before{width:22px;height:22px}
  .header{padding:0 12px}
  .header-inner{height:48px;gap:8px}
  .logo img{height:36px}

  .container{padding:10px 8px}
  .section-title{font-size:1.1rem;margin:14px 0 8px}
  .card{margin-bottom:12px;border-radius:10px}
  .card-header{padding:12px 14px;font-size:0.9rem}
  .card-body{padding:12px 14px}

  .banner{padding:24px 16px;border-radius:10px}
  .banner h2{font-size:1.35rem}
  .banner p{font-size:0.88rem}

  .match-row{padding:10px 12px;gap:8px;flex-wrap:wrap}
  .match-time{width:60px;font-size:0.75rem}
  .match-time .time{font-size:0.85rem}
  .match-teams{flex:1;gap:6px;min-width:140px}
  .match-teams span{font-size:0.85rem}
  .match-vs{font-size:0.7rem}

  .odds-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr))!important;gap:4px!important}
  .odds-cell{padding:5px 3px!important;font-size:0.7rem!important}
  .odds-cell .bk{font-size:0.65rem!important}
  .odds-cell .v{font-size:0.8rem!important}

  .auth-card{margin:8px auto;border-radius:12px}
  .auth-header{padding:22px 16px 0;font-size:1.25rem}

  .btn{padding:8px 16px;font-size:0.85rem}
  .btn-sm{padding:6px 12px;font-size:0.78rem}

  .pred-hero{padding:16px 10px!important;border-radius:10px!important}
  .pred-hero img{width:56px!important;height:56px!important}
  .pred-team{min-width:80px!important}
  .pred-team .tname{font-size:0.85rem!important}
  .pred-vs{font-size:1.2rem!important;margin:0 6px!important}
  .pred-info{font-size:0.78rem!important}

  .prob-bar{height:6px!important;margin:6px 0!important}
  .form-dot{min-width:40px!important;padding:4px 6px!important;font-size:0.72rem!important}
  .form-dot .fteam{max-width:36px!important;font-size:0.6rem!important}
  .form-list{gap:3px!important}
  .agree-box{padding:12px!important;gap:10px!important;flex-direction:column!important}
  .agree-col{min-width:auto!important;padding:8px!important}
  .agree-col+.agree-col{border-left:none!important;border-top:1px solid #ddd;padding-left:8px!important}

  .footer{padding:24px 12px;font-size:0.78rem}
  .footer-links{gap:14px}
  .trust-bar{gap:10px;font-size:0.75rem}
}

/* ══════════════════════════════════════════════════ */
/* ── RESPONSIVE: Small Phone (≤480px) ── */
/* ══════════════════════════════════════════════════ */
@media(max-width:480px){
  .world-cup-hero{min-height:292px}
  .world-cup-hero .hero-content{padding:16px 14px 72px;max-width:92%}
  .world-cup-hero h2{font-size:1.15rem}
  .world-cup-hero p{max-width:300px}
  .wc-schedule-banner__copy{max-width:92%;padding:14px}
  .wc-cup-mark{right:-8px;top:22px;opacity:0.12}
  .wc-host-chip{font-size:0.62rem}
  .wc-section-head{align-items:flex-start}
  .header-inner{height:44px}
  .logo img{height:32px}
  .container{padding:8px 4px}
  .section-title{font-size:1rem}
  .card-header{padding:10px 12px;font-size:0.85rem}
  .card-body{padding:10px 12px}

  .banner{padding:20px 12px}
  .banner h2{font-size:1.2rem}
  .banner p{font-size:0.82rem}

  .match-row{padding:8px 10px;gap:6px}
  .match-time{width:50px;font-size:0.7rem}
  .match-time .time{font-size:0.8rem}
  .match-teams{gap:4px}
  .match-teams span{font-size:0.8rem}

  .btn{padding:7px 14px;font-size:0.82rem}
  .auth-card{border-radius:10px}
  .auth-header{padding:18px 14px 0;font-size:1.15rem}

  .pred-hero{padding:12px 8px!important}
  .pred-hero img{width:42px!important;height:42px!important}
  .pred-hero .tname{font-size:0.78rem!important}
  .pred-team{min-width:65px!important}
  .pred-vs{font-size:1rem!important;margin:0 4px!important}
  .pred-info{font-size:0.72rem!important}
  div[style*="font-size:2.2rem"]{font-size:1.2rem!important}
  div[style*="font-size:1.6rem"]{font-size:1rem!important}
  div[style*="font-size:3rem"]{font-size:1.5rem!important}

  .odds-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))!important}
  .odds-cell{padding:4px 2px!important;font-size:0.65rem!important}

  .compare-bar{gap:2px!important}
  .compare-bar .cmodel,.compare-bar .cos{font-size:0.65rem!important;flex:0.4!important}
  .compare-bar .cbar{flex:1.5!important;height:4px!important
  }
  .stat-row{font-size:0.78rem!important;padding:3px 0!important}
  .comm-row{padding:6px 10px!important;gap:4px!important}
  .comm-avatar{width:22px!important;height:22px!important;font-size:0.6rem!important}
  .score-bar{gap:4px!important;margin-bottom:2px!important}
  .score-bar .slabel{width:30px!important;font-size:0.7rem!important}
  .score-bar .sbar-bg{height:12px!important}
  .score-bar .sbar-fill{font-size:0.65rem!important}
  .form-dot{padding:3px 5px!important;min-width:36px!important;font-size:0.68rem!important}
  .form-dot .fteam{max-width:30px!important;font-size:0.55rem!important}

  .footer{padding:20px 8px;font-size:0.72rem}
  .footer-links{gap:10px;font-size:0.75rem}
}

/* ══════════════════════════════════════════════════ */
/* ── Settings button ── */
/* ══════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════ */
/* ── Language & Timezone Modal (1xBet-style) ── */
/* ══════════════════════════════════════════════════ */
.lang-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.lang-modal{background:#fff;border-radius:16px;width:100%;max-width:700px;max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,0.25)}
.lang-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #E2E8F0}
.lang-modal-title{font-size:1.1rem;font-weight:700;color:#1a1a2e}
.lang-modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#64748B;padding:4px 8px;border-radius:6px;transition:all 0.2s}
.lang-modal-close:hover{background:#F1F5F9;color:#1E293B}
.lang-modal-body{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}
.lang-modal-col{padding:24px}
.lang-modal-col:first-child{border-right:1px solid #E2E8F0}
.lang-modal-section-title{font-size:0.95rem;font-weight:700;color:#1a1a2e;margin-bottom:16px}
.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:320px;overflow-y:auto}
.lang-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:all 0.15s;font-size:0.85rem;position:relative}
.lang-item:hover{background:#F1F5F9;border-color:#CBD5E1}
.lang-item.selected{background:#EFF6FF;border-color:#3B82F6}
.lang-flag{font-size:1.2rem;flex-shrink:0}
.lang-name{font-weight:500;color:#1E293B}
.lang-check{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#3B82F6;font-weight:700;font-size:0.9rem}
.tz-select-wrapper{margin-bottom:12px}
.tz-select{width:100%;padding:12px 14px;border:2px solid #E2E8F0;border-radius:8px;font-size:0.85rem;color:#1E293B;background:#fff;appearance:none;cursor:pointer;transition:border-color 0.2s}
.tz-select:focus{outline:none;border-color:#3B82F6;box-shadow:0 0 0 3px rgba(59,130,246,0.1)}
.tz-current{margin-top:12px;padding:10px 14px;background:#F8FAFC;border-radius:8px;font-size:0.82rem;display:flex;align-items:center;gap:6px}
.tz-browser-label{color:var(--text-light)}
.tz-browser-value{font-weight:600;color:#3B82F6}
.lang-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #E2E8F0;background:#F8FAFC;border-radius:0 0 16px 16px}

@media(max-width:640px){
  .lang-modal-body{grid-template-columns:1fr}
  .lang-modal-col:first-child{border-right:none;border-bottom:1px solid #E2E8F0}
  .lang-modal-col{padding:16px}
  .lang-modal{max-width:95vw;border-radius:12px}
  .lang-modal-header{padding:14px 16px}
  .lang-modal-footer{padding:12px 16px}
  .lang-grid{grid-template-columns:1fr 1fr;max-height:200px}
  .lang-item{padding:8px 10px;font-size:0.8rem}
}

/* ── Data Module ── */
.data-page-title{font-size:1.4rem;font-weight:800;margin:20px 0 16px;color:#fff}
.data-tournament-shell{overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 16px 50px rgba(2,8,23,0.22);margin:18px auto 14px}
.data-tournament-hero{position:relative;display:flex;align-items:center;gap:18px;min-height:118px;padding:24px 30px;color:#fff;background:radial-gradient(circle at 6% 18%,rgba(255,255,255,0.24) 0 2px,transparent 3px) 0 0/14px 14px,linear-gradient(155deg,#2386d9 0%,#3a98e9 39%,#303ef1 40%,#2638d6 100%)}
.data-tournament-hero:after{content:"";position:absolute;right:-120px;top:-130px;width:520px;height:250px;border-radius:50%;background:#b6ec00;transform:rotate(12deg);opacity:0.95}
.data-tournament-mark{position:relative;z-index:1;width:54px;height:54px;border-radius:12px;background:rgba(2,8,23,0.26);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.18);font-size:0.72rem;font-weight:900;letter-spacing:0.5px;flex-shrink:0}
.data-tournament-copy{position:relative;z-index:1;min-width:0}
.data-tournament-copy h1{font-size:1.4rem;line-height:1.15;margin:0 0 5px;font-weight:800;letter-spacing:0}
.data-tournament-copy p{margin:0;color:rgba(255,255,255,0.82);font-size:0.86rem;font-weight:600}
.data-year-menu{position:relative;z-index:1;margin-left:auto;text-align:right;display:flex;flex-direction:column;gap:8px;align-items:flex-end;min-width:150px}
.data-year-menu>span{font-size:0.8rem;font-weight:800;color:#fff}
.data-year-list{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.data-year-list a{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:14px;color:#fff;text-decoration:none;background:rgba(255,255,255,0.14);font-size:0.72rem;font-weight:800;border:1px solid rgba(255,255,255,0.18)}
.data-year-list a.active{background:#fff;color:#2852de;border-color:#fff}
.data-rank-switch{margin:12px 18px 16px;padding:4px;border:1px solid #eef1f6;background:#f4f6fa;border-radius:12px;display:grid;grid-template-columns:1fr 1fr}
.data-rank-switch button{height:36px;border:0;background:transparent;border-radius:9px;color:#101827;font-weight:800;font-size:0.84rem;cursor:pointer}
.data-rank-switch button.active{background:#fff;color:#2852de;box-shadow:0 2px 10px rgba(15,23,42,0.08)}
.data-rank-pane{display:none}
.data-rank-pane.active{display:block}
.data-group-filter{display:flex;gap:7px;align-items:center;margin:0 0 14px;overflow-x:auto;padding:2px 0 6px;scrollbar-width:none}
.data-group-pill{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:5px 14px;border-radius:16px;font-size:0.75rem;font-weight:800;white-space:nowrap;text-decoration:none;border:1px solid rgba(255,255,255,0.14);color:rgba(255,255,255,0.62);transition:all 0.2s;background:rgba(255,255,255,0.04);cursor:pointer;font-family:inherit}
.data-group-pill:hover{border-color:rgba(255,255,255,0.28);color:rgba(255,255,255,0.9)}
.data-group-pill.active{background:#fff;color:#2852de;border-color:#fff}
.baidu-rank-group{--rank-team-col:minmax(240px,1fr);--rank-stat-col:96px;background:#fff;border-radius:8px;overflow:hidden;margin-bottom:12px;box-shadow:0 10px 30px rgba(2,8,23,0.16)}
.baidu-rank-header{display:grid;grid-template-columns:var(--rank-team-col) repeat(4,var(--rank-stat-col));align-items:center;padding:14px 18px 8px;color:#6b7280;font-size:0.82rem}
.baidu-rank-title{color:#6b7280;text-decoration:none;font-weight:800}
.baidu-rank-cols{display:contents}
.baidu-rank-cols span{text-align:center}
.baidu-rank-table{border-top:1px solid #e9edf5}
.baidu-rank-row{position:relative;display:grid;grid-template-columns:var(--rank-team-col) repeat(4,var(--rank-stat-col));align-items:center;min-height:58px;border-bottom:1px solid #e2e7f0;color:#0f172a;padding:0 18px}
.baidu-rank-row:last-child{border-bottom:none}
.baidu-rank-row.qualify{background:#e9edff}
.baidu-rank-row.pending{background:#f7f7f7}
.baidu-status-tag{position:absolute;left:18px;top:0;transform:translateY(-1px);display:inline-flex;align-items:center;height:18px;padding:0 7px;background:#2563eb;color:#fff;border-radius:0 0 4px 4px;font-size:0.66rem;font-weight:800;z-index:1}
.baidu-status-tag.muted{background:#6b7280}
.baidu-team-cell{display:flex;align-items:center;gap:10px;min-width:0;color:#101827;text-decoration:none;font-weight:800;padding:16px 18px}
.baidu-pos{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;background:#fff;color:#667085;font-size:0.78rem;font-weight:900;flex-shrink:0;box-shadow:0 1px 5px rgba(15,23,42,0.07)}
.baidu-rank-row.qualify .baidu-pos{background:#ef4444;color:#fff}
.baidu-team-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.baidu-stat{text-align:center;font-weight:800;color:#111827;font-size:0.86rem}
.baidu-points{color:#0f172a}
.knockout-board{background:#fff;border-radius:8px;box-shadow:0 10px 30px rgba(2,8,23,0.16);overflow:hidden;color:#111827}
.knockout-empty-state{display:flex;gap:18px;align-items:center;padding:26px 28px;background:linear-gradient(135deg,#f8fafc,#eef4ff);border:1px solid #e4eaf5;border-radius:8px}
.knockout-empty-mark{width:54px;height:54px;border-radius:12px;background:#456cff;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;letter-spacing:0}
.knockout-empty-state h3{margin:0 0 4px;font-size:1rem;color:#111827}
.knockout-empty-state p{margin:0 0 8px;color:#667085;font-weight:700;font-size:0.82rem}
.knockout-empty-state code{display:inline-flex;padding:4px 8px;border-radius:6px;background:#111827;color:#fff;font-size:0.72rem}
.knockout-board-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid #edf0f5;background:#fbfcff}
.knockout-board-head h2{margin:0;font-size:1rem;font-weight:900;color:#111827}
.knockout-board-head p{margin:2px 0 0;color:#667085;font-size:0.76rem;font-weight:800}
.knockout-board-head span{padding:5px 10px;border-radius:14px;background:#eef3ff;color:#456cff;font-size:0.72rem;font-weight:900;white-space:nowrap}
.knockout-round-tabs{position:sticky;top:0;z-index:3;display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px 12px;background:#fff;border-bottom:1px solid #edf0f5;min-width:900px}
.knockout-round-tabs button{height:38px;border:0;border-radius:7px;background:#f3f5fa;color:#111827;font-size:0.86rem;font-weight:900;cursor:pointer;font-family:inherit;letter-spacing:0}
.knockout-round-tabs button.active{background:#eaf0ff;color:#456cff;box-shadow:inset 0 0 0 1px rgba(69,108,255,0.16)}
.knockout-scroll{overflow:auto;background:#fff;max-height:760px;padding:14px 12px 18px;scrollbar-width:thin;scrollbar-color:#cfd6e5 transparent}
.knockout-grid{--ko-card-w:220px;--ko-card-h:106px;--ko-gap:40px;--ko-line:#dfe5ef;position:relative;display:grid;grid-auto-flow:column;grid-auto-columns:var(--ko-card-w);gap:var(--ko-gap);align-items:start;min-width:max-content;padding-right:20px}
.knockout-round{position:relative;display:flex;flex-direction:column;gap:14px;padding:0}
.knockout-round:after{display:none}
.knockout-grid.has-r32 .knockout-round-16{gap:14px;--ko-merge:120px}
.knockout-grid.has-r32 .knockout-round-8{padding-top:60px;gap:134px;--ko-merge:240px}
.knockout-grid.has-r32 .knockout-round-4{padding-top:180px;gap:374px;--ko-merge:480px}
.knockout-grid.has-r32 .knockout-round-2{padding-top:420px;gap:854px;--ko-merge:960px}
.knockout-grid.has-r32 .knockout-round-final{padding-top:900px}
.knockout-grid.has-r32 .knockout-round-third{padding-top:900px}
.knockout-grid.no-r32 .knockout-round-8{gap:14px;--ko-merge:120px}
.knockout-grid.no-r32 .knockout-round-4{padding-top:60px;gap:134px;--ko-merge:240px}
.knockout-grid.no-r32 .knockout-round-2{padding-top:180px;gap:374px;--ko-merge:480px}
.knockout-grid.no-r32 .knockout-round-final{padding-top:420px}
.knockout-grid.no-r32 .knockout-round-third{padding-top:420px}
.ko-match-card{position:relative;z-index:1;width:var(--ko-card-w);height:var(--ko-card-h);padding:10px 11px;border-radius:8px;background:#f6f8fc;border:1px solid #edf0f5;color:#080d1a;box-shadow:0 1px 0 rgba(15,23,42,0.04)}
.ko-match-card.is-placeholder{opacity:0.64;background:#fafbfe}
.ko-match-card.is-schedule-slot{opacity:1;background:#f5f7fc;border-color:#e6ebf4}
.ko-line{position:absolute;display:block;pointer-events:none;background:var(--ko-line);z-index:0}
.ko-line-in{left:-20px;top:50%;width:20px;height:1px}
.knockout-round-third .ko-match-card.is-placeholder.is-schedule-slot .ko-line-in{display:none}
.ko-line-out{right:-20px;top:50%;width:20px;height:1px}
.ko-line-merge{right:-20px;top:50%;width:1px;height:var(--ko-merge);display:none}
.knockout-round:first-child .ko-line-in{display:none}
.knockout-round-final .ko-line-out,.knockout-round-final .ko-line-merge,.knockout-round-third .ko-line-out,.knockout-round-third .ko-line-merge{display:none}
.knockout-round .ko-match-card:nth-child(odd) .ko-line-merge{display:block}
.knockout-round-final .ko-match-card:nth-child(odd) .ko-line-merge,.knockout-round-third .ko-match-card:nth-child(odd) .ko-line-merge{display:none}
.ko-match-time{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;white-space:nowrap}
.ko-match-time span{font-size:0.76rem;font-weight:900;color:#111827}
.ko-match-time strong{font-size:0.68rem;color:#456cff;font-weight:900;background:#eaf0ff;border-radius:10px;padding:2px 7px}
.ko-team-row{display:grid;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:7px;margin-top:7px;color:#8c94a5;font-weight:900;min-width:0;font-size:0.78rem}
.ko-team-icon{width:16px;height:16px;border-radius:50%;border:2px solid #d2d6de;display:inline-flex;align-items:center;justify-content:center;position:relative;opacity:0.9}
.ko-team-icon:after{content:"";width:6px;height:6px;border-radius:50%;border:1px solid #d2d6de}
.ko-team-icon.shield{border-radius:6px 6px 8px 8px}
.ko-team-icon.shield:after{width:5px;height:5px;border-radius:1px;transform:rotate(45deg)}
.ko-team-badge{width:18px;height:14px;border-radius:0;object-fit:contain;display:block;background:transparent}
.ko-team-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ko-score{color:#111827;font-weight:900;min-width:10px;text-align:right}
.data-teams-panel{margin-top:18px;padding:18px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:8px}
.data-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;color:#fff}
.data-section-head h2{margin:0;font-size:1rem;font-weight:800}
.data-section-head span{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:24px;padding:0 8px;border-radius:12px;background:#fff;color:#2852de;font-weight:900;font-size:0.78rem}
.data-glass-card{background:rgba(255,255,255,0.06)!important;border:1px solid rgba(255,255,255,0.1)!important;color:#fff!important}
.data-glass-card .card-header{border-bottom:1px solid rgba(255,255,255,0.08)!important;color:rgba(255,255,255,0.85)!important}
.data-glass-card .card-body{color:rgba(255,255,255,0.8)!important}

/* Standings Table */
.data-standings-table{width:100%;border-collapse:collapse;font-size:0.82rem}
.data-standings-table thead th{padding:8px 6px;text-align:left;color:rgba(255,255,255,0.45);font-weight:600;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid rgba(255,255,255,0.08)}
.data-standings-table tbody td{padding:8px 6px;border-bottom:1px solid rgba(255,255,255,0.05);color:rgba(255,255,255,0.8)}
.data-standings-table tbody tr:hover{background:rgba(255,255,255,0.04)}
.data-standings-table .col-pos{width:30px;text-align:center}
.data-standings-table .col-num{width:36px;text-align:center}
.data-standings-table .col-team{min-width:120px}
.data-standings-table .col-pts{font-weight:700;color:#3B82F6}

/* Squad Table */
.data-squad-table{width:100%;border-collapse:collapse;font-size:0.82rem}
.data-squad-table thead th{padding:8px 10px;text-align:left;color:rgba(255,255,255,0.45);font-weight:600;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid rgba(255,255,255,0.08)}
.data-squad-table tbody td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.05);color:rgba(255,255,255,0.8)}
.data-squad-table tbody tr:hover{background:rgba(255,255,255,0.04)}
.data-squad-table .col-num{text-align:center;width:40px}
.data-pos-cell{color:var(--highlight)!important;font-weight:600;font-size:0.75rem}

/* Team badges */
.data-badge-sm{width:30px;height:20px;border-radius:0;object-fit:contain;flex-shrink:0;background:transparent}
.data-badge-lg{width:48px;height:36px;border-radius:0;object-fit:contain;margin-bottom:6px;background:transparent}
.data-badge-xl{width:72px;height:72px;object-fit:contain;margin-right:16px;flex-shrink:0}

/* Teams Grid */
.data-teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}
.data-team-tile{display:flex;flex-direction:column;align-items:center;padding:12px 6px;border-radius:10px;text-decoration:none;transition:background 0.15s}
.data-team-tile:hover{background:rgba(255,255,255,0.06)}
.data-team-name{font-size:0.72rem;color:rgba(255,255,255,0.7);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:80px}

/* Team Hero */
.data-team-hero{display:flex;align-items:center;gap:16px;padding:24px;background:linear-gradient(135deg,rgba(233,69,96,0.15),rgba(59,130,246,0.1));border:1px solid rgba(255,255,255,0.1);border-radius:12px;margin-bottom:16px;flex-wrap:wrap}
.data-team-hero-name{font-size:1.5rem;font-weight:800;color:#fff;margin:0}
.data-team-hero-meta{color:rgba(255,255,255,0.55);font-size:0.85rem;margin-top:4px}

/* Player Hero */
.data-player-hero{display:flex;align-items:center;justify-content:space-between;padding:24px;background:linear-gradient(135deg,rgba(59,130,246,0.15),rgba(16,185,129,0.1));border:1px solid rgba(255,255,255,0.1);border-radius:12px;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.data-player-hero-name{font-size:1.5rem;font-weight:800;color:#fff;margin:0}
.data-player-fullname{color:rgba(255,255,255,0.5);font-size:0.9rem;margin-top:2px}
.data-player-team-link{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:8px;color:rgba(255,255,255,0.8);text-decoration:none;font-size:0.85rem;font-weight:600;transition:all 0.2s}
.data-player-team-link:hover{background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.25)}

/* Info Row */
.data-info-row{display:flex;gap:24px;padding:16px 0;flex-wrap:wrap}
.data-info-item{display:flex;flex-direction:column;gap:2px}
.data-info-label{font-size:0.72rem;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.data-info-value{font-size:0.95rem;color:rgba(255,255,255,0.85);font-weight:600}

/* Stats Row */
.data-stats-row{display:flex;gap:8px;flex-wrap:wrap}
.data-stat-card{flex:1;min-width:60px;text-align:center;padding:14px 8px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:10px}
.data-stat-value{font-size:1.35rem;font-weight:800;color:#fff}
.data-stat-label{font-size:0.65rem;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:0.5px;font-weight:600;margin-top:4px}

/* Player Avatars */
.player-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#1E293B}
.player-avatar-lg{width:88px;height:88px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#1E293B;border:3px solid rgba(255,255,255,0.15)}

/* Injury Banner */
.data-injury-banner{padding:10px 16px;background:rgba(233,69,96,0.15);border:1px solid rgba(233,69,96,0.3);border-radius:8px;color:#e94560;font-weight:700;font-size:0.9rem;text-align:center;margin-bottom:8px}

/* Form Row (Recent Form) */
.data-form-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,0.05);font-size:0.85rem}
.data-form-row:last-child{border-bottom:none}
.data-form-date{min-width:40px;color:rgba(255,255,255,0.45);font-size:0.78rem}
.data-form-opp{flex:1;color:rgba(255,255,255,0.8);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.data-form-result{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:0.8rem;flex-shrink:0}
.data-form-score{min-width:32px;text-align:center;font-weight:700;color:rgba(255,255,255,0.9)}
.data-form-ha{min-width:20px;text-align:center;color:rgba(255,255,255,0.35);font-size:0.75rem;font-weight:600}

/* Team profile page */
.team-profile-shell{max-width:980px;margin:0 auto 28px;color:#101827}
.team-profile-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.team-profile-back{display:inline-flex;align-items:center;color:rgba(255,255,255,0.68);text-decoration:none;font-size:0.84rem;font-weight:800}
.team-profile-share{height:34px;padding:0 14px;border-radius:6px;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.08);color:#fff;font-size:0.8rem;font-weight:800;cursor:pointer;font-family:inherit}
.team-profile-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:28px 30px;background:linear-gradient(135deg,#f8fbff,#edf3ff);border-radius:8px 8px 0 0;border:1px solid #e7edf6;border-bottom:0}
.team-profile-identity{display:flex;align-items:center;gap:18px;min-width:0}
.team-profile-flag-wrap{width:82px;height:58px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.team-profile-flag{width:82px;height:58px;object-fit:contain;display:block;background:transparent;border-radius:0}
.team-profile-title{min-width:0}
.team-profile-title h1{margin:0;color:#111827;font-size:1.7rem;font-weight:900;letter-spacing:0;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-profile-title p{margin:6px 0 0;color:#8a94a6;font-size:0.88rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-profile-ranks{display:grid;grid-template-columns:repeat(2,86px);gap:12px;flex-shrink:0}
.team-profile-ranks div{height:68px;border-radius:8px;background:#fff;border:1px solid #e6ebf4;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(15,23,42,0.06)}
.team-profile-ranks span{color:#8a94a6;font-size:0.72rem;font-weight:800}
.team-profile-ranks strong{margin-top:4px;color:#1d4ed8;font-size:1.18rem;font-weight:900}
.team-profile-tabs{display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border:1px solid #e7edf6;border-top:0;border-bottom:0}
.team-profile-tabs button{height:46px;display:flex;align-items:center;justify-content:center;color:#4b5563;text-decoration:none;font-size:0.86rem;font-weight:900;position:relative;border:0;background:#fff;font-family:inherit;cursor:pointer}
.team-profile-tabs button.active{color:#2852de}
.team-profile-tabs button.active:after{content:"";position:absolute;left:50%;bottom:0;width:30px;height:3px;border-radius:3px;background:#2852de;transform:translateX(-50%)}
.team-tab-panel{display:none}
.team-tab-panel.active{display:block}
.team-schedule-panel{background:#fff;border:1px solid #e7edf6;border-radius:0 0 8px 8px;overflow:hidden;box-shadow:0 12px 34px rgba(2,8,23,0.16)}
.team-match-list{background:#fff}
.team-match-day{display:block;border-bottom:0}
.team-match-day:last-child{border-bottom:0}
.team-match-date{position:relative;height:34px;padding:0 18px;color:#111827;font-size:0.8rem;font-weight:800;background:#f3f5fa;border-bottom:0;display:flex;align-items:center;gap:10px}
.team-match-date strong{font-size:0.82rem;font-weight:800;color:#111827}
.team-match-date span{margin-left:auto;font-size:0.76rem;font-weight:800;color:#4b5563}
.team-match-rows{min-width:0}
.team-match-row{min-height:86px;display:grid;grid-template-columns:76px minmax(0,1fr) 44px 76px;align-items:center;gap:10px;padding:12px 18px;color:#111827;text-decoration:none;border-bottom:0;background:#fff}
.team-match-row:last-child{border-bottom:0}
.team-match-row:hover{background:#fbfcff}
.team-match-meta{align-self:stretch;display:flex;flex-direction:column;justify-content:flex-start;gap:9px;padding-top:2px;min-width:0}
.team-match-meta strong{color:#111827;font-size:0.82rem;font-weight:500;line-height:1.1}
.team-match-meta span{color:#8a94a6;font-size:0.78rem;font-weight:700;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.team-match-clubs{display:flex;flex-direction:column;gap:10px;min-width:0}
.team-match-side{display:flex;align-items:center;gap:9px;min-width:0;color:#111827;font-size:0.88rem;font-weight:800}
.team-match-side.home,.team-match-side.away{justify-content:flex-start;text-align:left}
.team-match-side span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-match-flag{width:30px;height:20px;object-fit:contain;border-radius:0;display:block;flex-shrink:0;background:transparent}
.team-match-score-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.team-match-score-stack strong{height:20px;min-width:16px;color:#98a2b3;font-size:1.02rem;font-weight:900;line-height:20px;text-align:center}
.team-match-score-stack strong.winner{color:#111827}
.team-match-state{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:7px;min-width:0}
.team-match-state strong{color:#111827;font-size:0.8rem;font-weight:900;white-space:nowrap}
.team-match-state span{color:#8a94a6;font-size:0.75rem;font-weight:800;white-space:nowrap}
.team-schedule-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:160px;color:#8a94a6;text-align:center;padding:28px}
.team-schedule-empty strong{color:#111827;font-size:1rem}
.team-schedule-empty span{font-size:0.82rem;font-weight:700}
.team-schedule-empty.compact{min-height:90px;background:#fff;border:1px solid #e7edf6;border-radius:8px}
.team-profile-section{margin-top:18px;background:#fff;border:1px solid #e7edf6;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px rgba(2,8,23,0.12)}
.team-profile-section-head{height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid #edf0f5;background:#fbfcff}
.team-profile-section-head h2{margin:0;color:#111827;font-size:0.96rem;font-weight:900}
.team-profile-section-head span{min-width:26px;height:22px;padding:0 8px;border-radius:12px;background:#eaf0ff;color:#2852de;display:inline-flex;align-items:center;justify-content:center;font-size:0.74rem;font-weight:900}
.team-squad-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
.team-squad-row{min-height:58px;display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 16px;color:#111827;text-decoration:none;border-bottom:1px solid #f0f2f6}
.team-squad-row:nth-child(odd){border-right:1px solid #f0f2f6}
.team-squad-row span{font-size:0.86rem;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-squad-row em{font-style:normal;color:#667085;font-size:0.76rem;font-weight:800}
.team-squad-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#eef2f7}
.team-roster-band{height:34px;padding:0 18px;background:#f3f5fa;color:#111827;display:flex;align-items:center;font-size:0.86rem;font-weight:900}
.team-coach-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;background:#fff}
.team-coach-card{min-height:64px;display:flex;align-items:center;gap:10px;padding:10px 18px;border-bottom:1px solid #edf0f5;min-width:0}
.team-coach-card strong,.team-roster-player strong{display:block;color:#111827;font-size:0.86rem;font-weight:900;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-coach-card span,.team-roster-player span{display:block;margin-top:2px;color:#8a94a6;font-size:0.76rem;font-weight:800;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-roster-group{min-width:720px}
.team-roster-head,.team-roster-row{display:grid;grid-template-columns:minmax(280px,1fr) 120px 120px 120px 140px;align-items:center}
.team-roster-head{height:34px;background:#f3f5fa;color:#8a94a6;font-size:0.78rem;font-weight:900}
.team-roster-head strong{padding-left:18px;color:#111827;font-size:0.86rem}
.team-roster-head span,.team-roster-row>span{text-align:center}
.team-roster-row{min-height:72px;color:#111827;text-decoration:none;border-bottom:1px solid #edf0f5;background:#fff;font-size:0.86rem;font-weight:900}
.team-roster-row:hover{background:#fbfcff}
.team-roster-player{display:grid;grid-template-columns:28px 38px minmax(0,1fr);align-items:center;gap:10px;padding:0 18px;min-width:0}
.team-roster-player em{width:26px;height:26px;position:relative;display:flex;align-items:center;justify-content:center;background:#f3f5fa;color:#8a94a6;font-style:normal;font-size:0.76rem;font-weight:900;clip-path:polygon(14% 0,100% 0,100% 100%,14% 100%,0 50%)}
.team-roster-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:#eef2f7;flex-shrink:0}
.team-roster-list{overflow-x:auto;scrollbar-width:thin;scrollbar-color:#cfd6e5 transparent}
.team-data-section{padding-bottom:18px}
.team-data-filters{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:18px 18px 10px}
.team-data-filters select{height:42px;border:1px solid #dfe4ec;border-radius:8px;background:#fff;color:#111827;font-size:0.92rem;font-weight:900;padding:0 36px 0 12px;font-family:inherit;appearance:auto;cursor:pointer}
.team-data-record{margin:14px 18px 18px;min-height:104px;border-radius:8px;background:#f3f5fa;display:grid;grid-template-columns:260px minmax(0,1fr);align-items:center}
.team-data-rank{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.team-data-rank strong{font-size:1.55rem;line-height:1;color:#05070c;font-weight:900}
.team-data-rank span{font-size:0.9rem;color:#8a94a6;font-weight:900}
.team-data-form{padding-right:70px}
.team-data-form>div:not(.team-data-bar){display:inline-flex;align-items:baseline;gap:7px;width:32%;color:#5b7cf4}
.team-data-form strong{font-size:1.55rem;font-weight:900;line-height:1}
.team-data-form span{font-size:0.9rem;font-weight:900}
.team-data-bar{height:6px;display:flex;gap:3px;margin:10px 0 10px;background:#d9deea;border-radius:5px;overflow:hidden}
.team-data-bar span{height:100%;width:var(--w);background:#5578f4;min-width:0}
.team-data-bar span:nth-child(2){background:#9fb2ff}
.team-data-bar span:nth-child(3){background:#c7ccd8}
.team-data-form p{margin:0;color:#111827;font-size:0.9rem;font-weight:900}
.team-data-block{padding:0 18px;margin-top:18px}
.team-data-block h3{margin:0 0 12px;color:#111827;font-size:1.02rem;font-weight:900}
.team-data-card-grid{display:grid;grid-template-columns:repeat(9,minmax(88px,1fr));gap:12px}
.team-data-card{min-height:94px;border-radius:8px;background:#f4f6fa;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;text-align:center}
.team-data-card strong{min-height:24px;color:#111827;font-size:1rem;font-weight:900;line-height:1.1}
.team-data-card span{margin-top:7px;color:#111827;font-size:0.86rem;font-weight:900;line-height:1.25}
.team-data-card em{margin-top:10px;color:#8a94a6;font-style:normal;font-size:0.78rem;font-weight:900}
.team-data-empty{margin:14px 18px 0;min-height:132px;border-radius:8px;background:#f4f6fa;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;color:#111827}
.team-data-empty strong{font-size:1rem;font-weight:900;line-height:1.35}
.team-data-empty span{margin-top:8px;color:#8a94a6;font-size:0.86rem;font-weight:800;line-height:1.5}

/* Data module responsive */
@media(max-width:768px){
  .data-tournament-shell{margin:10px -2px 12px;border-radius:8px}
  .data-tournament-hero{min-height:104px;padding:18px 16px;gap:12px}
  .data-tournament-hero:after{right:-220px;top:-150px}
  .data-tournament-mark{width:44px;height:44px;border-radius:10px}
  .data-tournament-copy h1{font-size:1.08rem}
  .data-tournament-copy p{font-size:0.74rem}
  .data-year-menu{display:none}
  .data-rank-switch{margin:10px 12px 12px}
  .baidu-rank-group{overflow-x:auto}
  .baidu-rank-header{min-width:660px;grid-template-columns:240px repeat(4,105px);padding:12px 14px 8px}
  .baidu-rank-row{min-width:660px;grid-template-columns:240px repeat(4,105px);min-height:54px;padding:0 14px}
  .baidu-team-cell{padding:15px 14px}
  .baidu-status-tag{left:14px}
  .knockout-board{margin:0 -2px}
  .knockout-empty-state{padding:22px 18px;align-items:flex-start}
  .knockout-board-head{padding:14px 12px}
  .knockout-round-tabs{min-width:720px;padding:8px;gap:5px}
  .knockout-round-tabs button{height:34px;font-size:0.76rem}
  .knockout-scroll{max-height:680px;padding:12px 10px 14px}
  .knockout-grid{--ko-card-w:176px;--ko-card-h:92px;--ko-gap:30px;grid-auto-columns:var(--ko-card-w);gap:var(--ko-gap)}
  .knockout-round{gap:12px}
  .knockout-round:after{right:-10px}
  .knockout-grid.has-r32 .knockout-round-16{gap:12px;--ko-merge:104px}
  .knockout-grid.has-r32 .knockout-round-8{padding-top:52px;gap:116px;--ko-merge:208px}
  .knockout-grid.has-r32 .knockout-round-4{padding-top:156px;gap:324px;--ko-merge:416px}
  .knockout-grid.has-r32 .knockout-round-2{padding-top:364px;gap:740px;--ko-merge:832px}
  .knockout-grid.has-r32 .knockout-round-final{padding-top:780px}
  .knockout-grid.has-r32 .knockout-round-third{padding-top:780px}
  .knockout-grid.no-r32 .knockout-round-8{gap:12px;--ko-merge:104px}
  .knockout-grid.no-r32 .knockout-round-4{padding-top:52px;gap:116px;--ko-merge:208px}
  .knockout-grid.no-r32 .knockout-round-2{padding-top:156px;gap:324px;--ko-merge:416px}
  .knockout-grid.no-r32 .knockout-round-final{padding-top:364px}
  .knockout-grid.no-r32 .knockout-round-third{padding-top:364px}
  .ko-match-card{width:var(--ko-card-w);height:var(--ko-card-h);padding:9px}
  .ko-line-in{left:-15px;width:15px}
  .ko-line-out{right:-15px;width:15px}
  .ko-line-merge{right:-15px}
  .ko-match-time{gap:7px;margin-bottom:8px}
  .ko-match-time span{font-size:0.7rem}
  .ko-match-time strong{font-size:0.62rem;padding:2px 5px}
  .ko-team-row{grid-template-columns:16px minmax(0,1fr) auto;gap:5px;margin-top:7px;font-size:0.72rem}
  .ko-team-icon{width:13px;height:13px;border-width:1px}
  .data-standings-table{font-size:0.72rem}
  .data-standings-table thead th{padding:6px 4px;font-size:0.65rem}
  .data-standings-table tbody td{padding:6px 4px}
  .data-squad-table{font-size:0.72rem}
  .data-squad-table thead th{padding:6px 6px;font-size:0.65rem}
  .data-squad-table tbody td{padding:6px 6px}
  .data-badge-lg{width:36px;height:36px}
  .data-badge-xl{width:56px;height:56px}
  .data-team-hero-name{font-size:1.2rem}
  .data-player-hero-name{font-size:1.2rem}
  .player-avatar-lg{width:64px;height:64px}
  .player-avatar{width:28px;height:28px}
  .data-stat-card{padding:10px 4px;min-width:48px}
  .data-stat-value{font-size:1.1rem}
  .data-teams-grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:8px}
  .data-form-row{gap:8px;padding:8px 10px;font-size:0.78rem}
  .team-profile-shell{margin:0 -2px 20px}
  .team-profile-hero{padding:20px 16px;align-items:flex-start}
  .team-profile-flag-wrap,.team-profile-flag{width:66px;height:46px}
  .team-profile-title h1{font-size:1.28rem;white-space:normal}
  .team-profile-title p{font-size:0.78rem}
  .team-profile-ranks{grid-template-columns:repeat(2,72px);gap:8px}
  .team-profile-ranks div{height:58px}
  .team-profile-tabs{overflow-x:auto;display:flex;scrollbar-width:none}
  .team-profile-tabs button{min-width:74px;height:42px;font-size:0.78rem}
  .team-match-date{height:34px;padding:0 14px;text-align:left;border-right:0}
  .team-match-row{grid-template-columns:64px minmax(0,1fr) 34px 62px;gap:8px;min-height:82px;padding:10px 14px}
  .team-match-meta{gap:8px}
  .team-match-meta span{font-size:0.72rem}
  .team-match-side{gap:7px;font-size:0.8rem}
  .team-match-score-stack strong{font-size:0.92rem}
  .team-match-state strong{font-size:0.76rem}
  .team-match-state span{font-size:0.7rem}
  .team-squad-list{grid-template-columns:1fr}
  .team-squad-row:nth-child(odd){border-right:0}
  .team-coach-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team-coach-card{padding:10px 14px}
  .team-roster-band{padding:0 14px}
  .team-roster-head strong{padding-left:14px}
  .team-roster-player{padding:0 14px}
  .team-data-filters{grid-template-columns:1fr;gap:8px;padding:14px}
  .team-data-record{margin:10px 14px 16px;grid-template-columns:120px minmax(0,1fr)}
  .team-data-rank strong{font-size:1.2rem}
  .team-data-form{padding-right:16px}
  .team-data-form strong{font-size:1.2rem}
  .team-data-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .team-data-block{padding:0 14px}
  .team-data-empty{margin:10px 14px 0}
}
@media(max-width:480px){
  .data-group-filter{margin-bottom:10px}
  .data-rank-switch button{font-size:0.78rem}
  .baidu-rank-header{min-width:620px;grid-template-columns:220px repeat(4,100px)}
  .baidu-rank-row{min-width:620px;grid-template-columns:220px repeat(4,100px)}
  .baidu-team-cell{gap:6px}
  .baidu-pos{width:20px;height:20px}
  .data-teams-panel{padding:14px 10px}
  .knockout-empty-state{display:block}
  .knockout-empty-mark{margin-bottom:12px}
  .knockout-board-head{display:block}
  .knockout-board-head span{margin-top:8px;display:inline-flex}
  .knockout-scroll{padding:10px 8px 12px;max-height:620px}
  .knockout-round-tabs{min-width:600px}
  .knockout-round-tabs button{height:32px;font-size:0.7rem}
  .knockout-grid{--ko-card-w:154px;--ko-card-h:88px;--ko-gap:24px;grid-auto-columns:var(--ko-card-w);gap:var(--ko-gap)}
  .knockout-grid.has-r32 .knockout-round-16{gap:12px;--ko-merge:100px}
  .knockout-grid.has-r32 .knockout-round-8{padding-top:50px;gap:112px;--ko-merge:200px}
  .knockout-grid.has-r32 .knockout-round-4{padding-top:150px;gap:312px;--ko-merge:400px}
  .knockout-grid.has-r32 .knockout-round-2{padding-top:350px;gap:712px;--ko-merge:800px}
  .knockout-grid.has-r32 .knockout-round-final{padding-top:750px}
  .knockout-grid.has-r32 .knockout-round-third{padding-top:750px}
  .knockout-grid.no-r32 .knockout-round-8{gap:12px;--ko-merge:100px}
  .knockout-grid.no-r32 .knockout-round-4{padding-top:50px;gap:112px;--ko-merge:200px}
  .knockout-grid.no-r32 .knockout-round-2{padding-top:150px;gap:312px;--ko-merge:400px}
  .knockout-grid.no-r32 .knockout-round-final{padding-top:350px}
  .knockout-grid.no-r32 .knockout-round-third{padding-top:350px}
  .ko-match-card{width:var(--ko-card-w);height:var(--ko-card-h)}
  .ko-line-in{left:-12px;width:12px}
  .ko-line-out{right:-12px;width:12px}
  .ko-line-merge{right:-12px}
  .ko-match-time{display:block}
  .ko-match-time strong{display:inline-block;margin-left:5px}
  .data-standings-table .col-num{width:28px}
  .data-stats-row{gap:4px}
  .data-stat-card{padding:8px 2px;min-width:40px}
  .data-stat-value{font-size:0.95rem}
  .data-stat-label{font-size:0.58rem}
  .data-teams-grid{grid-template-columns:repeat(4,1fr);gap:6px}
  .data-team-name{font-size:0.65rem;max-width:65px}
  .data-badge-lg{width:32px;height:32px}
  .team-profile-topbar{padding:0 2px}
  .team-profile-hero{display:block}
  .team-profile-identity{margin-bottom:14px}
  .team-profile-ranks{grid-template-columns:repeat(2,1fr)}
  .team-match-row{padding:10px 12px}
  .team-match-side{font-size:0.8rem}
  .team-match-flag{width:28px;height:19px}
  .team-coach-grid{grid-template-columns:1fr}
  .team-roster-group{min-width:640px}
  .team-roster-head,.team-roster-row{grid-template-columns:minmax(240px,1fr) 92px 92px 92px 124px}
  .team-data-record{display:block;padding:16px 12px}
  .team-data-rank{margin-bottom:14px}
  .team-data-form{padding:0}
  .team-data-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team-data-card{min-height:88px}
  .team-data-empty{min-height:118px;padding:20px 14px}
}

/* World Cup Intelligence Desk visual system */
:root{
  --primary:#10261f;
  --accent:#0d6b46;
  --highlight:#c91f36;
  --gold:#c99a32;
  --green:#138a62;
  --blue:#255f99;
  --turquoise:#1a9c91;
  --pitch:#0d6b46;
  --bg:#f4f7f1;
  --card-bg:#ffffff;
  --panel:#fbfcf8;
  --text:#132019;
  --text-light:#66746c;
  --border:#dbe5dc;
  --line:#e8eee8;
  --radius:8px;
  --shadow:0 1px 2px rgba(15,35,24,0.06),0 10px 26px rgba(15,35,24,0.06);
  --shadow-hover:0 2px 4px rgba(15,35,24,0.08),0 18px 36px rgba(15,35,24,0.12);
}

body{
  font-family:Aptos,'Segoe UI Variable','Segoe UI',Tahoma,sans-serif;
  background:
    linear-gradient(180deg,rgba(244,247,241,0.96),rgba(248,250,247,0.98)),
    repeating-linear-gradient(90deg,rgba(13,107,70,0.035) 0 1px,transparent 1px 64px),
    repeating-linear-gradient(0deg,rgba(13,107,70,0.03) 0 1px,transparent 1px 64px);
  color:var(--text);
  letter-spacing:0;
}
body::before{
  background:
    linear-gradient(180deg,rgba(255,255,255,0.5),rgba(255,255,255,0)),
    repeating-linear-gradient(90deg,rgba(13,107,70,0.04) 0 1px,transparent 1px 72px);
  mask-image:linear-gradient(180deg,#000 0%,rgba(0,0,0,0.18) 54%,transparent 100%);
}
h1,h2,h3,h4,.section-title,.pred-page-title,.data-tournament-copy h1{
  font-family:Bahnschrift,'Aptos Display','Segoe UI Variable',Aptos,sans-serif;
  letter-spacing:0;
}

.container{max-width:1180px;padding:22px 20px}
@media(min-width:768px){.container{max-width:1180px;padding:28px 24px}}
.page-data .container,.page-pricing .container,.page-prediction .container{max-width:1180px}

.desktop-nav{
  background:rgba(10,23,18,0.96)!important;
  border-bottom:1px solid rgba(215,226,216,0.12)!important;
  box-shadow:0 12px 34px rgba(8,20,15,0.22);
}
.desktop-nav .nav-container{max-width:1180px!important}
.desktop-nav .nav-links{gap:8px!important}
.desktop-nav .nav-links a{
  height:34px;
  display:inline-flex;
  align-items:center;
  padding:0 12px!important;
  border:1px solid transparent!important;
  border-radius:8px;
  color:#b8c6bd!important;
  font-weight:750!important;
}
.desktop-nav .nav-links a:hover{
  color:#fff!important;
  background:rgba(255,255,255,0.07);
  border-color:rgba(255,255,255,0.08)!important;
}
.desktop-nav .nav-links a.active{
  color:#fff!important;
  background:linear-gradient(135deg,rgba(201,154,50,0.28),rgba(19,138,98,0.28));
  border-color:rgba(201,154,50,0.34)!important;
}
.desktop-nav .nav-login-btn{
  border-radius:8px!important;
  background:linear-gradient(135deg,#e2b64d,#b98419)!important;
  color:#10261f!important;
}
.desktop-nav .nav-profile-btn{
  min-height:34px;
  padding:0 10px;
  border-radius:8px;
  background:rgba(255,255,255,0.06);
  color:#eef7ef!important;
}
.header{
  background:linear-gradient(135deg,#0b1d17,#0d4f3a)!important;
  box-shadow:0 10px 26px rgba(13,38,28,0.18);
}
.locale-pill{
  border-radius:8px!important;
  background:rgba(255,255,255,0.09)!important;
  border-color:rgba(255,255,255,0.14)!important;
}
@media(max-width:767px){
  .mb-nav{
    height:64px;
    background:rgba(9,20,16,0.96)!important;
    border-top:1px solid rgba(255,255,255,0.12)!important;
  }
  .mb-nav-inner{max-width:560px;width:100%}
  .mb-nav-item{min-width:0;color:rgba(238,247,239,0.58)!important}
  .mb-nav-item.active{color:#e2b64d!important}
  .mb-nav-item .icon{width:24px;height:24px}
  .mb-nav-item .label{
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
}

.card,.auth-card,.schedule-card,.wdl-card,.data-card,.ai-card,.advanced-card,
.user-pred-section,.community-card,.baidu-rank-group,.knockout-board,
.data-tournament-shell,.team-profile-section,.team-schedule-panel{
  border-radius:8px!important;
  border:1px solid var(--border)!important;
  background:linear-gradient(180deg,#fff,#fbfcf8)!important;
  box-shadow:var(--shadow)!important;
}
.card:hover,.schedule-card:hover,.baidu-rank-row:hover,.team-match-row:hover{
  box-shadow:var(--shadow-hover)!important;
}
.card-header,.team-profile-section-head,.knockout-board-head{
  background:linear-gradient(180deg,#fbfcf8,#f4f8f1)!important;
  border-bottom:1px solid var(--line)!important;
  color:var(--primary)!important;
}
.btn{
  border-radius:8px!important;
  font-weight:800!important;
  letter-spacing:0;
}
.btn-primary{
  background:linear-gradient(135deg,#c91f36,#a7172a)!important;
  box-shadow:0 10px 22px rgba(201,31,54,0.18)!important;
}
.btn-outline{
  border:1px solid rgba(16,38,31,0.18)!important;
  background:#fff!important;
  color:var(--primary)!important;
}
.btn-outline:hover{
  border-color:rgba(201,154,50,0.5)!important;
  color:#8a6418!important;
}
.section-title,.wc-section-title,.pred-page-title{
  color:var(--primary)!important;
}

.page-home .container::before{display:none}
.world-cup-hero{
  border-radius:8px!important;
  min-height:390px;
  box-shadow:0 24px 54px rgba(7,20,14,0.22)!important;
}
.wc-hero-overlay{
  background:
    linear-gradient(90deg,rgba(7,18,14,0.94) 0%,rgba(7,18,14,0.76) 44%,rgba(7,18,14,0.24) 82%),
    linear-gradient(0deg,rgba(7,18,14,0.72),rgba(7,18,14,0.08) 48%)!important;
}
.world-cup-hero h2{
  font-size:clamp(1.7rem,3.3vw,2.7rem)!important;
  font-weight:900!important;
}
.world-cup-hero h2 .accent{color:#e2b64d!important}
.world-cup-hero p{color:rgba(245,251,245,0.84)!important}
.wc-kicker{
  border-radius:8px!important;
  background:rgba(226,182,77,0.14)!important;
  border-color:rgba(226,182,77,0.28)!important;
  color:#f5d37b!important;
}
.world-cup-hero .hero-stats-strip{
  background:rgba(8,18,14,0.78)!important;
  border-top:1px solid rgba(255,255,255,0.12)!important;
}
.world-cup-hero .hero-stat-item .lbl{letter-spacing:0!important}
.wc-host-chip{
  border-radius:8px!important;
  background:rgba(255,255,255,0.09)!important;
}
.wc-schedule-banner{
  border-radius:8px!important;
  border-color:rgba(16,38,31,0.12)!important;
  box-shadow:var(--shadow)!important;
}
.wc-schedule-banner::after{
  background:linear-gradient(90deg,rgba(7,18,14,0.86),rgba(7,18,14,0.34) 74%)!important;
}
.wc-section-head{
  padding:0 2px;
  margin-top:22px!important;
}
.wc-section-title{
  font-size:1.08rem!important;
  font-weight:900!important;
}
.wc-section-title::before{border-radius:8px!important}
.date-tabs,.stage-rail,.data-group-filter{
  padding-bottom:6px!important;
}
.date-tab,.stage-chip,.data-group-pill{
  border-radius:8px!important;
  border:1px solid var(--border)!important;
  background:#fff!important;
  color:var(--text-light)!important;
  font-weight:850!important;
}
.date-tab.active,.stage-chip.active,.data-group-pill.active{
  background:var(--primary)!important;
  color:#fff!important;
  border-color:var(--primary)!important;
  box-shadow:none!important;
}
.match-row-item,.match-row,.schedule-card{
  border-bottom-color:var(--line)!important;
}
.match-row-item .mc-team-name,.sch-team span{
  color:var(--text)!important;
}
.match-center-vs,.sch-vs,.sch-clock,.wc-view-link{
  color:#b98419!important;
}

.page-prediction .pred-page-head{
  padding:18px;
  background:linear-gradient(135deg,#ffffff,#f4f8f1);
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow:var(--shadow);
}
.page-prediction .pred-kicker{
  border-radius:8px!important;
  background:rgba(19,138,98,0.1)!important;
  border-color:rgba(19,138,98,0.18)!important;
  color:#0d6b46!important;
}
.page-prediction .pred-page-title{font-size:clamp(1.55rem,2.2vw,2.1rem)!important}
.page-prediction .mode-note{
  border-radius:8px!important;
  background:#fff!important;
  border-color:var(--border)!important;
  box-shadow:var(--shadow);
}
.page-prediction .guest-login-note{
  background:linear-gradient(135deg,#101827,#123442)!important;
  border-color:transparent!important;
  color:#fff!important;
}
.page-prediction .guest-login-note a{
  color:#fbbf24!important;
  font-weight:900;
}
.page-prediction .schedule-list{gap:12px!important}
.page-prediction .schedule-card{
  grid-template-columns:94px minmax(0,1fr) minmax(150px,190px) 22px!important;
  padding:14px 16px!important;
}
.page-prediction .sch-time{
  border-right-color:var(--line)!important;
}
.page-prediction .pred-pick{
  border-radius:8px!important;
  border:1px solid transparent;
}
.pick-home{background:rgba(201,31,54,0.09)!important;color:#b51b30!important}
.pick-draw{background:rgba(201,154,50,0.14)!important;color:#8a6418!important}
.pick-away{background:rgba(37,95,153,0.1)!important;color:#255f99!important}

.pred-detail .mini-match{
  border-radius:8px!important;
  background:
    linear-gradient(135deg,rgba(7,18,14,0.96),rgba(13,84,60,0.94)),
    repeating-linear-gradient(90deg,rgba(255,255,255,0.05) 0 1px,transparent 1px 42px)!important;
  box-shadow:0 16px 36px rgba(7,20,14,0.18)!important;
}
.pred-detail .wdl-card,.pred-detail .data-card,.pred-detail .ai-card,.pred-detail .advanced-card{
  padding:16px!important;
}
.pred-detail .section-line h2,.pred-detail .section-line h3,.pred-detail .ai-group-head h4{
  color:var(--primary)!important;
}
.pred-detail .wdl-option{
  border-radius:8px!important;
  background:#f7faf5!important;
}
.pred-detail .ai-item,.pred-detail .model-chip,.pred-detail .h2h-row,.pred-detail .form-team,.pred-detail .kpi{
  border-radius:8px!important;
  border-color:var(--line)!important;
}
.pred-detail .guest-banner{
  border-radius:8px!important;
  background:linear-gradient(135deg,#10261f,#0d6b46)!important;
}

.page-data .container{max-width:1220px!important}
.data-tournament-shell{
  overflow:hidden;
  color:var(--text)!important;
}
.data-tournament-hero{
  min-height:124px!important;
  background:
    linear-gradient(135deg,#10261f 0%,#0d6b46 58%,#c99a32 160%)!important;
  color:#fff!important;
}
.data-tournament-hero:after{display:none!important}
.data-tournament-mark{
  border-radius:8px!important;
  background:rgba(255,255,255,0.12)!important;
}
.data-year-list a{
  border-radius:8px!important;
}
.data-rank-switch{
  border-radius:8px!important;
  background:#eef4ed!important;
}
.data-rank-switch button{
  border-radius:8px!important;
}
.data-rank-switch button.active{
  color:var(--primary)!important;
}
.baidu-rank-header,.knockout-board-head,.knockout-round-tabs{
  background:#fbfcf8!important;
}
.baidu-rank-row.qualify{
  background:linear-gradient(90deg,rgba(19,138,98,0.12),rgba(255,255,255,0.94))!important;
}
.baidu-rank-row.pending{
  background:#f7faf5!important;
}
.baidu-status-tag{
  border-radius:0 0 8px 8px!important;
  background:var(--green)!important;
}
.baidu-rank-row.qualify .baidu-pos{
  background:var(--highlight)!important;
}
.knockout-round-tabs button{
  border-radius:8px!important;
}
.knockout-round-tabs button.active{
  background:#eaf3e8!important;
  color:var(--accent)!important;
}
.ko-match-card{
  border-radius:8px!important;
  background:#f7faf5!important;
}

.page-pricing .ph{
  max-width:720px;
  margin:0 auto 18px;
  padding:26px 20px 14px!important;
  color:var(--primary);
}
.page-pricing .ph h1{
  font-size:clamp(1.8rem,3vw,2.7rem)!important;
  font-weight:900!important;
}
.page-pricing .tabs{
  max-width:760px!important;
  border-radius:8px!important;
  background:#eef4ed!important;
  border:1px solid var(--border)!important;
}
.page-pricing .tb{
  border-radius:8px!important;
  color:var(--text-light)!important;
}
.page-pricing .tb.active{
  background:#fff!important;
  color:var(--primary)!important;
  box-shadow:0 8px 18px rgba(15,35,24,0.08)!important;
}
.page-pricing .pc{
  max-width:760px!important;
}
.page-pricing .card{
  padding:30px!important;
  color:var(--text)!important;
}
.page-pricing .card.pop{
  border-color:rgba(201,31,54,0.42)!important;
  box-shadow:0 18px 42px rgba(201,31,54,0.12)!important;
}
.page-pricing .price-box .now{color:var(--highlight)!important}
.page-pricing .fi{
  border-bottom-color:var(--line)!important;
}
.page-pricing .ref-box{
  max-width:760px!important;
  border-radius:8px!important;
  background:linear-gradient(135deg,#10261f,#0d6b46)!important;
}

.dark-page{
  background:
    linear-gradient(180deg,#081411 0%,#0d2019 58%,#111b18 100%)!important;
  color:#eef7ef!important;
}
.dark-page .container{max-width:860px}
.profile-hero-card,.points-card,.checkin-card{
  border-radius:8px!important;
  background:linear-gradient(135deg,#10261f,#0d6b46)!important;
}
.glass-card,.stat-link,.trial-card{
  border-radius:8px!important;
  border-color:rgba(255,255,255,0.12)!important;
  background:rgba(255,255,255,0.07)!important;
}
.account-grid .account-row{
  border-radius:8px!important;
}
.profile-section{margin-bottom:14px!important}

.page-forum .expert-picks-section{
  border-radius:8px!important;
  background:linear-gradient(135deg,rgba(201,154,50,0.12),rgba(255,255,255,0.92))!important;
  border-color:rgba(201,154,50,0.28)!important;
}
.page-forum .tag-pill,.user-badge{
  border-radius:8px!important;
}
.page-forum .forum-filters select{
  border-radius:8px!important;
  background:#fff!important;
}
.static-page{
  max-width:820px;
  margin:0 auto;
  padding:28px;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  box-shadow:var(--shadow);
}
.static-page h1{
  color:var(--primary);
  font-size:clamp(1.6rem,2.4vw,2.2rem);
  margin-bottom:10px;
}
.static-page h2{
  color:var(--accent);
  margin-top:22px;
  margin-bottom:8px;
  font-size:1.05rem;
}

@media(max-width:768px){
  .container{padding:14px 12px!important}
  .world-cup-hero{min-height:330px}
  .world-cup-hero .hero-content{max-width:94%!important}
  .page-prediction .pred-page-head{display:block;padding:14px}
  .page-prediction .pred-stage-control{margin-top:12px}
  .page-prediction .schedule-card{
    grid-template-columns:minmax(0,1fr) 24px!important;
  }
  .page-pricing .card{padding:22px 18px!important}
  .page-pricing .tabs{grid-template-columns:repeat(2,1fr);display:grid!important}
  .data-tournament-hero{min-height:108px!important}
}
@media(max-width:480px){
  .container{padding:10px 8px!important}
  .world-cup-hero{min-height:306px}
  .wc-schedule-banner__copy{max-width:96%!important}
  .static-page{padding:20px 16px}
}
