: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}
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}
.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 ── */
.footer{background:var(--primary);color:rgba(255,255,255,0.65);padding:32px 16px;margin-top:48px;text-align:center;font-size:0.82rem}
.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-group-pill{display:inline-block;padding:5px 14px;border-radius:16px;font-size:0.75rem;font-weight:600;white-space:nowrap;text-decoration:none;border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.55);transition:all 0.2s}
.data-group-pill:hover{border-color:rgba(255,255,255,0.3);color:rgba(255,255,255,0.8)}
.data-group-pill.active{background:var(--highlight);color:#fff;border-color:var(--highlight)}
.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:20px;height:20px;border-radius:50%;object-fit:contain;flex-shrink:0}
.data-badge-lg{width:48px;height:48px;object-fit:contain;margin-bottom:6px}
.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}

/* Data module responsive */
@media(max-width:768px){
  .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}
}
@media(max-width:480px){
  .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}
}
