*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

/* ── FIFA 2026 DESIGN TOKENS ── */
:root{
  --fifa-red:#E31E24;
  --fifa-green:#00A650;
  --fifa-blue:#004F9F;
  --fifa-yellow:#FFD700;
  --fifa-white:#FFFFFF;

  --gold:#EF9F27;
  --gold-dim:rgba(239,159,39,0.12);
  --gold-glow:rgba(239,159,39,0.35);
  --green:#00A650;
  --green-dim:rgba(0,166,80,0.12);
  --red:#E31E24;
  --blue:#004F9F;

  --bg:#070A10;
  --surface:#0C1019;
  --surface2:#111827;
  --surface3:#161F30;
  --card:#0F1724;

  --border:rgba(255,255,255,0.06);
  --border2:rgba(255,255,255,0.12);
  --border3:rgba(255,255,255,0.2);

  --text:#F0F4FF;
  --muted:rgba(240,244,255,0.45);
  --muted2:rgba(240,244,255,0.25);

  --common-c:#8899AA;
  --rare-c:#5BA4F5;
  --legendary-c:#EF9F27;
  --icon-c:#E535AB;

  --sidebar:248px;
  --topbar:52px;

  --fd:'Bebas Neue',sans-serif;
  --fb:'Barlow Condensed',sans-serif;
  --fs:'Barlow',sans-serif;
  --fm:'JetBrains Mono',monospace;
}

html,body{height:100%;overflow:hidden;}
body{background:var(--bg);color:var(--text);font-family:var(--fb);display:flex;letter-spacing:.01em;}

::-webkit-scrollbar{width:3px;height:3px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}

/* ══════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════ */
#auth-screen{
  position:fixed;inset:0;z-index:1000;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:0;
  overflow-y:auto;
  padding:20px 0;
}
.auth-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.auth-bg-stripe{
  position:absolute;width:200%;height:4px;opacity:0.3;
  animation:stripeDrift 8s linear infinite;
}
@keyframes stripeDrift{from{transform:translateX(-50%)}to{transform:translateX(0%)}}

.auth-card{
  position:relative;z-index:1;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:24px;
  padding:52px 48px;
  text-align:center;
  max-width:460px;
  width:90%;
  box-shadow:0 0 80px rgba(0,79,159,0.3), 0 0 40px rgba(227,30,36,0.1);
}
.auth-logo-wrap{
  display:flex;align-items:center;justify-content:center;
  gap:16px;margin-bottom:32px;
}
.auth-logo-num{
  font-family:var(--fd);font-size:80px;line-height:1;
  color:var(--text);letter-spacing:-4px;
  text-shadow:2px 2px 0 var(--red), -2px -2px 0 var(--blue);
}
.auth-logo-fifa{font-family:var(--fd);font-size:14px;letter-spacing:4px;color:var(--muted);margin-top:4px;}
.auth-title{font-family:var(--fd);font-size:28px;letter-spacing:3px;color:var(--text);margin-bottom:8px;}
.auth-sub{font-family:var(--fs);font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:24px;}
.auth-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:14px 20px;border-radius:10px;
  border:1px solid var(--border3);
  background:rgba(255,255,255,0.04);
  color:var(--text);font-family:var(--fb);font-size:16px;font-weight:600;
  cursor:pointer;transition:all 0.2s;letter-spacing:.5px;
  margin-bottom:12px;
}
.auth-btn:hover{background:rgba(255,255,255,0.08);border-color:var(--border3);transform:translateY(-1px);}
.auth-btn svg{width:20px;height:20px;flex-shrink:0;}
.auth-btn-demo{
  background:linear-gradient(135deg,var(--red),var(--blue));
  border:none;font-size:15px;
}
.auth-btn-demo:hover{opacity:0.9;transform:translateY(-1px);}
.auth-divider{
  display:flex;align-items:center;gap:10px;margin:4px 0 16px;
  color:var(--muted2);font-family:var(--fm);font-size:10px;letter-spacing:2px;
}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border);}

/* Auth form Email/Password */
.auth-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.auth-input{
  width:100%;padding:12px 14px;border-radius:10px;
  border:1px solid var(--border2);
  background:rgba(255,255,255,0.04);
  color:var(--text);font-family:var(--fs);font-size:14px;
  outline:none;transition:all .15s;
}
.auth-input::placeholder{color:var(--muted);}
.auth-input:focus{
  border-color:var(--gold);background:rgba(255,255,255,0.06);
  box-shadow:0 0 0 2px rgba(239,159,39,0.12);
}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.auth-row .auth-btn{margin-bottom:0;padding:12px 14px;}
.auth-link{
  background:none;border:none;color:var(--muted);
  font-family:var(--fs);font-size:12px;cursor:pointer;
  padding:4px;transition:color .15s;
}
.auth-link:hover{color:var(--gold);}

/* ══════════════════════════════════════
   LAYOUT
══════════════════════════════════════ */
#app{display:flex;height:100vh;width:100vw;}
#app.hidden{display:none;}

#sidebar{
  width:var(--sidebar);flex-shrink:0;height:100vh;
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;position:relative;
}
.sb-brand{padding:18px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0;}
.sb-logo{
  font-family:var(--fd);font-size:22px;letter-spacing:3px;
  background:linear-gradient(90deg,var(--text),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.sb-sub{font-size:9px;color:var(--muted);letter-spacing:2px;font-family:var(--fm);margin-top:1px;}

.sb-user{
  display:flex;align-items:center;gap:9px;
  padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.sb-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--red),var(--blue));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden;
}
.sb-avatar img{width:100%;height:100%;object-fit:cover;}
.sb-user-info{flex:1;min-width:0;}
.sb-user-name{font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-user-email{font-size:9px;color:var(--muted);font-family:var(--fm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-logout{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:4px;transition:color .15s;font-size:14px;}
.sb-logout:hover{color:var(--red);}

.sb-scroll{flex:1;overflow-y:auto;padding:6px 0;}
.sb-section{padding:10px 16px 3px;font-size:9px;letter-spacing:2px;color:var(--muted2);font-family:var(--fm);text-transform:uppercase;}
.sb-item{
  display:flex;align-items:center;gap:9px;padding:6px 16px;
  cursor:pointer;transition:background 0.12s;border-left:2px solid transparent;
  font-size:13px;font-weight:500;color:var(--muted);
}
.sb-item:hover{background:rgba(255,255,255,0.03);color:var(--text);}
.sb-item.active{background:rgba(239,159,39,0.07);border-left-color:var(--gold);color:var(--text);}
.sb-flag{font-size:14px;line-height:1;width:18px;text-align:center;flex-shrink:0;}
.sb-flag img{width:18px;height:13px;object-fit:cover;border-radius:2px;display:block;}
.sb-badge{
  margin-left:auto;font-size:8px;font-family:var(--fm);
  background:rgba(255,255,255,0.05);padding:1px 5px;border-radius:2px;color:var(--muted2);
}
.sb-item.active .sb-badge{background:var(--gold-dim);color:var(--gold);}
.sb-progress{flex-shrink:0;padding:12px 16px;border-top:1px solid var(--border);}
.sb-prog-row{display:flex;justify-content:space-between;font-size:9px;color:var(--muted);font-family:var(--fm);letter-spacing:1px;margin-bottom:5px;}
.sb-prog-row span{color:var(--green);}
.sb-bar{height:2px;background:var(--border);border-radius:1px;overflow:hidden;}
.sb-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--blue));border-radius:1px;transition:width 0.6s ease;}

#main{flex:1;height:100vh;overflow:hidden;display:flex;flex-direction:column;}

#topbar{
  height:var(--topbar);flex-shrink:0;border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 28px;gap:16px;background:var(--surface);
}
.tb-crumb{font-size:11px;color:var(--muted);font-family:var(--fm);}
.tb-crumb span{color:var(--text);}
.tb-actions{margin-left:auto;display:flex;gap:8px;}
.tb-btn{
  background:transparent;border:1px solid var(--border2);color:var(--muted);
  padding:5px 14px;border-radius:6px;font-size:12px;cursor:pointer;
  font-family:var(--fb);font-weight:600;transition:all 0.12s;letter-spacing:.5px;
}
.tb-btn:hover{color:var(--text);border-color:var(--border3);}
.tb-btn.primary{background:linear-gradient(135deg,var(--red),var(--fifa-blue));color:#fff;border:none;}
.tb-btn.primary:hover{opacity:0.88;}
.tb-btn.gold{background:var(--gold);color:#1a0a00;border-color:var(--gold);}
.tb-btn.gold:hover{background:#f5b040;}

#page{flex:1;overflow-y:auto;padding:28px 28px 48px;}

.page-enter{animation:fadeSlide 0.25s ease forwards;}
@keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.fifa-strips{height:3px;display:flex;flex-shrink:0;}
.fifa-strips span{flex:1;}

/* ══════════════════════════════════════
   GLOBAL SEARCH
══════════════════════════════════════ */
.gs-trigger{
  display:flex;align-items:center;gap:8px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:8px;padding:5px 10px;cursor:pointer;
  transition:all .15s;flex:1;max-width:340px;
}
.gs-trigger:hover{border-color:var(--border2);}
.gs-trigger-icon{font-size:13px;}
.gs-trigger-text{font-size:12px;color:var(--muted);font-family:var(--fb);flex:1;text-align:left;}
.gs-trigger-kbd{font-size:9px;font-family:var(--fm);color:var(--muted2);
  background:var(--surface3);padding:2px 6px;border-radius:4px;border:1px solid var(--border2);}

.gs-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.7);
  backdrop-filter:blur(8px);z-index:500;
  display:none;align-items:flex-start;justify-content:center;padding-top:80px;
}
.gs-overlay.open{display:flex;}
.gs-modal{
  width:100%;max-width:640px;background:var(--surface);
  border:1px solid var(--border2);border-radius:16px;
  overflow:hidden;animation:gsIn .15s ease;
  display:flex;flex-direction:column;max-height:70vh;
}
@keyframes gsIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.gs-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);}
.gs-input-icon{font-size:16px;color:var(--muted);}
.gs-input{
  flex:1;background:none;border:none;outline:none;
  font-family:var(--fb);font-size:16px;color:var(--text);
}
.gs-input::placeholder{color:var(--muted);}
.gs-close-btn{
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:6px;padding:3px 8px;cursor:pointer;
  font-size:10px;font-family:var(--fm);color:var(--muted);transition:all .12s;
}
.gs-close-btn:hover{border-color:var(--border3);color:var(--text);}
.gs-filters{
  display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border);
  flex-wrap:wrap;
}
.gs-filter-btn{
  padding:3px 10px;border-radius:4px;font-size:10px;font-family:var(--fm);
  border:1px solid var(--border2);background:transparent;color:var(--muted);
  cursor:pointer;transition:all .12s;
}
.gs-filter-btn.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold);}
.gs-filter-btn:hover:not(.active){color:var(--text);}
.gs-results{flex:1;overflow-y:auto;}
.gs-result-item{
  display:flex;align-items:center;gap:12px;padding:10px 16px;
  cursor:pointer;transition:background .1s;border-bottom:1px solid rgba(255,255,255,0.02);
}
.gs-result-item:hover,.gs-result-item.focused{background:rgba(255,255,255,0.03);}
.gs-result-emoji{font-size:20px;width:28px;text-align:center;flex-shrink:0;}
.gs-result-info{flex:1;min-width:0;}
.gs-result-name{font-size:13px;font-weight:700;color:var(--text);font-family:var(--fb);}
.gs-result-meta{font-size:10px;color:var(--muted);font-family:var(--fs);}
.gs-result-badge{font-size:8px;font-family:var(--fm);padding:2px 6px;border-radius:3px;}
.gs-empty-state{padding:40px;text-align:center;color:var(--muted);font-family:var(--fs);font-size:13px;}
.gs-footer{
  display:flex;gap:12px;padding:8px 16px;border-top:1px solid var(--border);
  background:rgba(255,255,255,0.01);
}
.gs-hint{font-size:10px;font-family:var(--fm);color:var(--muted2);display:flex;align-items:center;gap:4px;}
.gs-hint kbd{
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:3px;padding:1px 5px;font-size:9px;font-family:var(--fm);
}

/* ══════════════════════════════════════
   HOME PAGE
══════════════════════════════════════ */
.home-hero{
  position:relative;overflow:hidden;
  border-radius:18px;background:var(--surface2);border:1px solid var(--border);
  margin-bottom:28px;padding:40px 40px 36px;
}
.home-hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 80% 50%,rgba(0,79,159,0.18) 0%,transparent 60%),
             radial-gradient(ellipse at 20% 50%,rgba(227,30,36,0.1) 0%,transparent 60%);
}
.home-hero-stripes{
  position:absolute;right:0;top:0;bottom:0;width:200px;
  background:repeating-linear-gradient(-45deg,transparent,transparent 8px,rgba(255,255,255,0.02) 8px,rgba(255,255,255,0.02) 16px);
}
.home-logo-big{
  font-family:var(--fd);font-size:90px;line-height:0.85;letter-spacing:-2px;
  color:var(--text);position:relative;z-index:1;
  text-shadow:3px 3px 0 var(--red),-3px -3px 0 var(--blue);margin-bottom:16px;
}
.home-logo-big .fifa-tag{display:block;font-size:13px;letter-spacing:6px;color:var(--muted);text-shadow:none;margin-top:4px;}
.home-tagline{font-family:var(--fs);font-size:16px;color:var(--muted);max-width:460px;line-height:1.6;margin-bottom:28px;position:relative;z-index:1;}
.home-stats-row{display:flex;gap:0;position:relative;z-index:1;margin-bottom:28px;}
.home-stat{padding:16px 24px;border-right:1px solid var(--border);}
.home-stat:first-child{padding-left:0;}
.home-stat:last-child{border:none;}
.home-stat .n{font-family:var(--fd);font-size:36px;letter-spacing:1px;}
.home-stat .n.green{color:var(--green);}
.home-stat .l{font-size:11px;color:var(--muted);font-family:var(--fm);letter-spacing:1px;margin-top:1px;}
.home-actions{display:flex;gap:10px;position:relative;z-index:1;}
.home-cta{padding:11px 28px;border-radius:8px;font-family:var(--fb);font-size:15px;font-weight:700;cursor:pointer;transition:all 0.15s;letter-spacing:.5px;border:none;}
.home-cta.primary{background:linear-gradient(135deg,var(--red) 0%,var(--blue) 100%);color:#fff;}
.home-cta.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(227,30,36,0.3);}
.home-cta.secondary{background:transparent;border:1px solid var(--border3);color:var(--text);}
.home-cta.secondary:hover{background:rgba(255,255,255,0.05);}

.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;}
.home-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all 0.15s;}
.home-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.home-card-icon{font-size:28px;margin-bottom:12px;}
.home-card-title{font-family:var(--fd);font-size:20px;letter-spacing:1px;margin-bottom:4px;}
.home-card-desc{font-size:12px;color:var(--muted);font-family:var(--fs);line-height:1.5;}
.home-card-stat{margin-top:12px;font-size:10px;font-family:var(--fm);color:var(--green);padding-top:10px;border-top:1px solid var(--border);}

/* ══════════════════════════════════════
   COUNTRY PAGE
══════════════════════════════════════ */
.country-header{display:flex;align-items:flex-end;gap:24px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border);}
.country-flag-big{width:72px;height:52px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:42px;}
.country-flag-big img{width:100%;height:100%;object-fit:cover;}
.country-title h1{font-family:var(--fd);font-size:42px;letter-spacing:2px;line-height:1;}
.country-title .conf{font-size:10px;letter-spacing:3px;color:var(--muted);font-family:var(--fm);margin-top:3px;}
.country-title .history{font-size:13px;color:var(--muted);margin-top:6px;max-width:480px;line-height:1.6;font-family:var(--fs);}
.country-stats{margin-left:auto;display:flex;flex-direction:column;gap:5px;text-align:right;}
.stat-item{font-size:11px;color:var(--muted);font-family:var(--fm);}
.stat-item strong{color:var(--text);font-weight:500;}

.info-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:20px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.info-stat{border-right:1px solid var(--border);padding-right:16px;}
.info-stat:last-child{border:none;}
.info-stat .label{font-size:9px;color:var(--muted);letter-spacing:2px;font-family:var(--fm);margin-bottom:4px;}
.info-stat .value{font-family:var(--fd);font-size:28px;letter-spacing:1px;}
.info-stat .sub{font-size:10px;color:var(--muted);margin-top:1px;font-family:var(--fs);}

.section-label{font-size:9px;letter-spacing:3px;color:var(--muted);font-family:var(--fm);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.section-label::after{content:'';flex:1;height:1px;background:var(--border);}

.stickers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-bottom:28px;}

.sticker-slot{aspect-ratio:3/4;border-radius:12px;border:1.5px dashed rgba(255,255,255,0.08);background:rgba(255,255,255,0.015);position:relative;display:flex;flex-direction:column;overflow:hidden;transition:border-color 0.15s,transform 0.15s,box-shadow 0.15s;cursor:pointer;}
.sticker-slot:hover{border-color:rgba(255,255,255,0.18);transform:translateY(-3px);}
.sticker-slot.collected{border-style:solid;border-color:var(--border);}
.sticker-slot.rare.collected{border-color:rgba(91,164,245,0.45);box-shadow:0 0 14px rgba(91,164,245,0.12);}
.sticker-slot.legendary.collected{border-color:rgba(239,159,39,0.55);box-shadow:0 0 22px rgba(239,159,39,0.25);background:linear-gradient(160deg,rgba(239,159,39,0.04),transparent);}
.sticker-slot.icon.collected{border-color:rgba(229,53,171,0.55);box-shadow:0 0 22px rgba(229,53,171,0.2);background:linear-gradient(160deg,rgba(229,53,171,0.05),transparent);}

.sticker-slot::before{content:'';display:block;height:3px;width:100%;flex-shrink:0;}
.sticker-slot.common::before{background:var(--common-c);}
.sticker-slot.rare::before{background:var(--rare-c);}
.sticker-slot.legendary::before{background:var(--legendary-c);}
.sticker-slot.icon::before{background:var(--icon-c);}

.slot-number{position:absolute;top:10px;left:7px;font-size:8px;font-family:var(--fm);color:var(--muted2);}
.slot-img{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.slot-img img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.slot-silhouette{flex:1;display:flex;align-items:center;justify-content:center;font-size:52px;background:rgba(255,255,255,0.02);}
.slot-empty-icon{flex:1;display:flex;align-items:center;justify-content:center;opacity:0.06;}
.slot-empty-icon svg{width:44px;height:44px;}
.slot-country-bar{position:absolute;bottom:52px;left:0;right:0;height:3px;}
.slot-info{padding:7px 9px 8px;border-top:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.3);}
.slot-name{font-size:11px;font-weight:700;color:var(--text);line-height:1.2;letter-spacing:.2px;}
.slot-club{font-size:9px;color:var(--muted);margin-top:2px;font-family:var(--fs);}
.slot-pos-row{display:flex;align-items:center;gap:4px;margin-top:3px;}
.slot-pos{padding:2px 6px;border-radius:3px;font-size:8px;font-weight:700;letter-spacing:.5px;font-family:var(--fm);}
.pos-POR{background:rgba(227,30,36,.18);color:#f07070;}
.pos-DEF{background:rgba(91,164,245,.18);color:#7ab4f0;}
.pos-MED{background:rgba(0,166,80,.18);color:#4dc98a;}
.pos-DEL{background:rgba(239,159,39,.18);color:var(--gold);}
.slot-rarity-dot{position:absolute;top:10px;right:7px;width:5px;height:5px;border-radius:50%;}
.common .slot-rarity-dot{background:var(--common-c);}
.rare .slot-rarity-dot{background:var(--rare-c);}
.legendary .slot-rarity-dot{background:var(--legendary-c);box-shadow:0 0 5px var(--gold);}
.icon .slot-rarity-dot{background:var(--icon-c);box-shadow:0 0 5px var(--icon-c);}
.slot-duplicate-badge{position:absolute;top:10px;right:18px;background:rgba(255,255,255,0.15);border-radius:3px;padding:1px 4px;font-size:7px;font-family:var(--fm);color:#fff;}
.legendary.collected::after,.icon.collected::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:2;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,0.04) 50%,transparent 70%);animation:sheen 4s ease-in-out infinite;}
@keyframes sheen{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ══════════════════════════════════════
   TIMELINE
══════════════════════════════════════ */
.timeline-wrap{margin:20px 0 28px;position:relative;}
.timeline-track{position:relative;padding:0 0 0 20px;border-left:2px solid var(--border);display:flex;flex-direction:column;gap:0;}
.timeline-item{position:relative;padding:10px 0 10px 20px;cursor:pointer;transition:opacity .15s;}
.timeline-item::before{content:'';position:absolute;left:-7px;top:17px;width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--border2);transition:border-color .15s,background .15s;}
.timeline-item.champion::before{background:var(--gold);border-color:var(--gold);box-shadow:0 0 8px var(--gold-glow);}
.timeline-item.finalist::before{background:var(--rare-c);border-color:var(--rare-c);}
.timeline-item.third::before{background:rgba(0,166,80,0.8);border-color:var(--green);}
.ti-year{font-family:var(--fd);font-size:16px;letter-spacing:1px;color:var(--text);}
.ti-result{font-size:11px;font-family:var(--fb);font-weight:600;letter-spacing:.5px;}
.ti-result.champion{color:var(--gold);}
.ti-result.finalist{color:var(--rare-c);}
.ti-result.third{color:var(--green);}
.ti-result.other{color:var(--muted);}
.ti-detail{font-size:11px;color:var(--muted);font-family:var(--fs);margin-top:1px;}

/* ══════════════════════════════════════
   PACK OPENING
══════════════════════════════════════ */
#pack-scene{display:flex;flex-direction:column;align-items:center;padding:20px 0 40px;}
.pack-header{text-align:center;margin-bottom:20px;}
.pack-header h2{font-family:var(--fd);font-size:48px;letter-spacing:4px;}
.pack-date{font-size:11px;color:var(--muted);font-family:var(--fm);margin-top:4px;letter-spacing:1px;}

.pack-card-wrap{perspective:800px;cursor:pointer;margin-bottom:32px;position:relative;}
.pack-card{width:200px;height:280px;position:relative;transform-style:preserve-3d;transition:transform 0.7s cubic-bezier(.4,0,.2,1);}
.pack-card.opening{transform:rotateX(-180deg) scale(0.8);}
.pack-card.loading{animation:packLoading 0.6s ease-in-out infinite;}
@keyframes packLoading{0%,100%{opacity:1}50%{opacity:.6}}

.pack-face{position:absolute;inset:0;border-radius:16px;overflow:hidden;backface-visibility:hidden;}
.pack-front{background:linear-gradient(135deg,#0a1a35 0%,#1a0a35 50%,#0a1a35 100%);border:1px solid rgba(239,159,39,0.4);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;box-shadow:0 0 40px rgba(239,159,39,0.2), 0 20px 60px rgba(0,0,0,0.5);}
.pack-front-logo{font-family:var(--fd);font-size:52px;letter-spacing:-2px;text-shadow:2px 2px 0 var(--red),-2px -2px 0 var(--blue);}
.pack-front-tag{font-family:var(--fd);font-size:16px;letter-spacing:4px;color:var(--gold);}
.pack-front-count{font-size:10px;font-family:var(--fm);color:rgba(239,159,39,0.5);letter-spacing:2px;}
.pack-back{transform:rotateX(180deg);background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:40px;}
.pack-shine{position:absolute;inset:0;border-radius:16px;pointer-events:none;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,0.06) 40%,transparent 60%);animation:packShine 3s ease-in-out infinite;}
@keyframes packShine{0%,100%{opacity:0}50%{opacity:1}}
.pack-hint{font-size:12px;color:var(--muted);font-family:var(--fb);letter-spacing:1px;animation:pulse 2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

.pack-reveal{display:none;width:100%;max-width:620px;}
.pack-reveal.show{display:block;}
.pack-reveal-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;}
.pack-sticker-reveal{opacity:0;transform:translateY(30px) scale(0.9);}
.pack-sticker-reveal.shown{animation:cardReveal 0.5s cubic-bezier(.34,1.56,.64,1) forwards;}
@keyframes cardReveal{to{opacity:1;transform:none;}}

/* Pack rate limit UI */
.pack-counter{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:10px 18px;margin-bottom:16px;font-family:var(--fb);}
.pack-counter.admin{background:rgba(239,159,39,0.06);border-color:rgba(239,159,39,0.2);color:var(--gold);}
.pack-counter-num{font-family:var(--fd);font-size:28px;line-height:1;}
.pack-counter-num.low{color:var(--gold);}
.pack-counter-num.zero{color:var(--red);}
.pack-counter-label{font-size:12px;color:var(--muted);font-family:var(--fs);}
.pack-counter-dots{display:flex;gap:5px;margin-left:auto;}
.pack-dot{width:10px;height:10px;border-radius:50%;background:var(--border2);transition:background .2s;}
.pack-dot.used{background:var(--red);}
.pack-limit-msg{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center;background:var(--surface2);border:1px solid var(--border);border-radius:16px;}
.pack-limit-icon{font-size:56px;margin-bottom:12px;}
.pack-limit-title{font-family:var(--fd);font-size:28px;letter-spacing:2px;margin-bottom:8px;}
.pack-limit-sub{font-size:13px;color:var(--muted);font-family:var(--fs);line-height:1.7;}

/* ══════════════════════════════════════
   STANDINGS
══════════════════════════════════════ */
.standings-wrap{margin-bottom:32px;}
.standings-group-title{font-family:var(--fd);font-size:22px;letter-spacing:3px;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.standings-group-title span{font-size:9px;font-family:var(--fm);letter-spacing:2px;color:var(--muted);background:var(--border);padding:2px 8px;border-radius:3px;}
.standings-table{width:100%;border-collapse:collapse;margin-bottom:28px;background:var(--surface2);border-radius:12px;overflow:hidden;border:1px solid var(--border);}
.standings-table th{padding:8px 12px;font-size:9px;letter-spacing:2px;color:var(--muted);font-family:var(--fm);text-transform:uppercase;text-align:center;border-bottom:1px solid var(--border);font-weight:400;background:rgba(255,255,255,0.02);}
.standings-table th:first-child{text-align:left;padding-left:16px;}
.standings-table td{padding:8px 12px;font-size:13px;font-weight:600;text-align:center;border-bottom:1px solid rgba(255,255,255,0.03);font-family:var(--fb);}
.standings-table td:first-child{text-align:left;padding-left:16px;}
.standings-table tr:last-child td{border:none;}
.standings-table tr:hover td{background:rgba(255,255,255,0.02);}
.std-team{display:flex;align-items:center;gap:8px;}
.std-flag{width:18px;height:13px;object-fit:cover;border-radius:2px;display:inline-block;vertical-align:middle;}
.std-flag-emoji{font-size:14px;}
.std-pos{font-family:var(--fm);font-size:11px;color:var(--muted);width:16px;text-align:center;}
.std-pos.qualify{color:var(--green);}
.std-gd{color:var(--muted);}
.std-gd.pos{color:var(--green);}
.std-gd.neg{color:var(--red);}
.std-pts{font-family:var(--fd);font-size:17px;letter-spacing:1px;}
.std-input{width:36px;height:24px;background:var(--surface3);border:1px solid var(--border2);border-radius:4px;color:var(--text);font-family:var(--fm);font-size:11px;text-align:center;outline:none;}
.std-input:focus{border-color:var(--gold);}

/* ══════════════════════════════════════
   GAME / TRIVIA / LINEUP / COMPARADOR
   (ver secciones completas del CSS original)
══════════════════════════════════════ */
.game-scene{display:flex;flex-direction:column;align-items:center;padding:20px 0;}
.game-header{text-align:center;margin-bottom:28px;}
.game-header h2{font-family:var(--fd);font-size:44px;letter-spacing:4px;}
.game-header p{font-size:13px;color:var(--muted);font-family:var(--fs);margin-top:4px;}
.game-score-bar{display:flex;align-items:center;gap:24px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 24px;margin-bottom:28px;font-family:var(--fm);font-size:11px;color:var(--muted);}
.game-score-bar strong{color:var(--text);font-size:16px;}
.game-score-bar .streak{color:var(--gold);}
.mystery-card{width:220px;height:300px;border-radius:16px;overflow:hidden;position:relative;margin-bottom:28px;border:2px solid var(--border2);background:var(--surface2);}
.mystery-img{width:100%;height:220px;object-fit:cover;object-position:top;filter:brightness(0) contrast(1);transition:filter 0.8s ease;}
.mystery-img.revealed{filter:none;}
.mystery-silhouette{width:100%;height:220px;display:flex;align-items:center;justify-content:center;background:var(--surface2);font-size:80px;filter:brightness(0) invert(1) opacity(.12);}
.mystery-bottom{background:var(--surface3);padding:10px 12px;border-top:1px solid var(--border);}
.mystery-pos{font-size:9px;font-family:var(--fm);color:var(--muted);letter-spacing:2px;margin-bottom:3px;}
.mystery-country{font-size:11px;font-family:var(--fb);color:var(--text);font-weight:600;}
.game-clues{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;justify-content:center;}
.clue-tag{background:var(--surface2);border:1px solid var(--border);padding:5px 12px;border-radius:20px;font-size:11px;font-family:var(--fm);color:var(--muted);}
.clue-tag.revealed{color:var(--text);border-color:var(--border2);}
.game-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:460px;margin-bottom:20px;}
.game-option{padding:12px 16px;border-radius:10px;border:1px solid var(--border2);background:var(--surface2);font-family:var(--fb);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;letter-spacing:.3px;}
.game-option:hover{border-color:var(--gold);color:var(--gold);}
.game-option.correct{background:var(--green-dim);border-color:var(--green);color:var(--green);}
.game-option.wrong{background:rgba(227,30,36,.12);border-color:var(--red);color:var(--red);}
.game-option:disabled{cursor:not-allowed;}
.game-result{text-align:center;padding:16px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);margin-bottom:16px;width:100%;max-width:460px;display:none;}
.game-result.show{display:block;}
.game-result .earned{color:var(--gold);font-family:var(--fd);font-size:20px;margin-top:4px;}

/* Exchange */
.exchange-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px;}
.exchange-panel{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:20px;}
.exchange-panel h3{font-family:var(--fd);font-size:20px;letter-spacing:2px;margin-bottom:4px;}
.exchange-panel p{font-size:11px;color:var(--muted);font-family:var(--fs);margin-bottom:16px;}
.dup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;}
.dup-card{aspect-ratio:3/4;border-radius:8px;border:1px solid var(--border);background:var(--surface3);display:flex;flex-direction:column;overflow:hidden;cursor:pointer;transition:all .15s;position:relative;}
.dup-card:hover{border-color:var(--gold);transform:translateY(-2px);}
.dup-card.selected{border-color:var(--gold);box-shadow:0 0 12px var(--gold-glow);}
.dup-card .dup-emoji{flex:1;display:flex;align-items:center;justify-content:center;font-size:24px;}
.dup-card .dup-name{font-size:8px;font-weight:700;padding:4px 5px;border-top:1px solid var(--border);color:var(--text);}
.dup-count{position:absolute;top:4px;right:4px;background:rgba(239,159,39,0.8);color:#1a0a00;font-size:8px;font-family:var(--fm);font-weight:700;padding:1px 4px;border-radius:3px;}
.trade-link-box{background:var(--surface3);border:1px solid var(--border2);border-radius:8px;padding:12px 14px;font-family:var(--fm);font-size:11px;color:var(--text);word-break:break-all;margin-top:16px;}
.trade-link-btn{margin-top:8px;padding:7px 14px;border-radius:6px;border:1px solid var(--gold);background:var(--gold-dim);color:var(--gold);font-family:var(--fb);font-size:12px;cursor:pointer;transition:all .15s;font-weight:700;}
.trade-link-btn:hover{background:var(--gold);color:#1a0a00;}

/* Stadiums */
.stadiums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:32px;}
.stadium-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:all 0.15s;cursor:pointer;position:relative;overflow:hidden;}
.stadium-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.stadium-card.collected{border-color:rgba(91,164,245,0.35);}
.stadium-card.collected::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--rare-c);}
.stad-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;}
.stad-flag{font-size:22px;}
.stad-flag img{width:24px;height:17px;object-fit:cover;border-radius:2px;}
.stad-name{font-family:var(--fd);font-size:19px;letter-spacing:1px;color:var(--text);}
.stad-city{font-size:10px;color:var(--muted);font-family:var(--fm);margin-top:1px;}
.stad-cap{font-family:var(--fm);font-size:10px;color:var(--green);margin-bottom:8px;}
.stad-matches{display:flex;flex-wrap:wrap;gap:4px;}
.stad-tag{font-size:8px;padding:2px 7px;border-radius:3px;font-family:var(--fm);background:rgba(255,255,255,0.05);color:var(--muted);}
.stad-slot{width:44px;height:44px;border-radius:8px;border:1.5px dashed rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;margin-left:auto;transition:all 0.15s;}
.stadium-card.collected .stad-slot{border-style:solid;border-color:rgba(91,164,245,0.4);}

/* Bracket */
.bracket-container{overflow-x:auto;padding-bottom:16px;}
.bracket-wrap{display:flex;gap:0;min-width:860px;}
.bracket-phase{display:flex;flex-direction:column;justify-content:space-around;flex:1;padding:0 6px;}
.bracket-phase-label{font-size:8px;letter-spacing:2px;color:var(--muted);font-family:var(--fm);text-align:center;margin-bottom:10px;text-transform:uppercase;}
.bracket-match{background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;overflow:hidden;cursor:pointer;transition:border-color .15s;}
.bracket-match:hover{border-color:var(--border2);}
.bracket-match.has-winner{border-color:rgba(0,166,80,0.25);}
.bm-team{display:flex;align-items:center;gap:7px;padding:6px 9px;font-size:11px;font-weight:600;min-height:30px;}
.bm-team.winner{background:rgba(0,166,80,0.07);color:var(--green);}
.bm-team.loser{opacity:.38;}
.bm-flag{font-size:12px;}
.bm-score{margin-left:auto;font-family:var(--fm);font-size:10px;color:var(--gold);}
.bm-divider{height:1px;background:var(--border);}

/* Modal */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);z-index:200;display:none;align-items:center;justify-content:center;}
#modal-overlay.open{display:flex;}
.modal-box{background:var(--surface);border:1px solid var(--border2);border-radius:18px;width:360px;max-width:90vw;padding:28px;animation:modalIn .2s ease;}
@keyframes modalIn{from{transform:scale(.95);opacity:0}to{transform:none;opacity:1}}
.modal-title{font-family:var(--fd);font-size:22px;letter-spacing:2px;margin-bottom:20px;text-align:center;}
.modal-teams{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px;}
.modal-team{text-align:center;}
.mflag{font-size:32px;margin-bottom:4px;}
.mflag img{width:40px;height:29px;object-fit:cover;border-radius:4px;}
.mname{font-family:var(--fd);font-size:14px;letter-spacing:1px;}
.modal-vs{font-family:var(--fd);font-size:20px;color:var(--muted);letter-spacing:2px;}
.score-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px;}
.score-input{width:60px;height:50px;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-family:var(--fd);font-size:28px;text-align:center;outline:none;transition:border-color .15s;}
.score-input:focus{border-color:var(--gold);}
.score-sep{font-family:var(--fd);font-size:24px;color:var(--muted);}
.modal-actions{display:flex;gap:8px;}
.modal-btn{flex:1;padding:10px;border-radius:8px;font-family:var(--fb);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:transparent;color:var(--muted);letter-spacing:.5px;}
.modal-btn.confirm{background:var(--green);border-color:var(--green);color:#000;}
.modal-btn.confirm:hover{opacity:.88;}

/* Toast */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface);border:1px solid var(--border2);padding:10px 20px;border-radius:20px;font-family:var(--fb);font-size:13px;font-weight:600;letter-spacing:.3px;opacity:0;transition:all 0.25s;pointer-events:none;z-index:500;white-space:nowrap;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.success{border-color:rgba(0,166,80,0.4);color:var(--green);}
#toast.error{border-color:rgba(227,30,36,0.4);color:var(--red);}

/* Sync */
#sync-dot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;margin-right:4px;animation:syncPulse 2s ease-in-out infinite;}
#sync-dot.syncing{background:var(--gold);}
#sync-dot.error{background:var(--red);animation:none;}
@keyframes syncPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ══════════════════════════════════════
   MI 11 IDEAL
══════════════════════════════════════ */
.lineup-wrap{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start;}
.pitch-outer{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:16px;position:relative;overflow:hidden;}
.pitch-formation-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.pitch-formation-bar .label{font-size:9px;letter-spacing:2px;color:var(--muted);font-family:var(--fm);}
.formation-btn{padding:4px 10px;border-radius:5px;font-size:11px;font-family:var(--fm);border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .12s;}
.formation-btn.active{background:var(--gold);border-color:var(--gold);color:#1a0a00;font-weight:700;}
.formation-btn:hover:not(.active){border-color:var(--border3);color:var(--text);}
.pitch{position:relative;width:100%;aspect-ratio:7/10;background:linear-gradient(180deg,#1a3a1a 0%,#1e421e 50%,#1a3a1a 100%);border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,0.08);}
.pitch::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent,transparent 9.9%,rgba(255,255,255,0.04) 9.9%,rgba(255,255,255,0.04) 10%),radial-gradient(circle at 50% 50%,transparent 14%,rgba(255,255,255,0.04) 14%,rgba(255,255,255,0.04) 14.4%,transparent 14.4%),linear-gradient(90deg,transparent 10%,rgba(255,255,255,0.04) 10%,rgba(255,255,255,0.04) 10.5%,transparent 10.5%,transparent 89.5%,rgba(255,255,255,0.04) 89.5%,rgba(255,255,255,0.04) 90%,transparent 90%),linear-gradient(180deg,transparent 49.5%,rgba(255,255,255,0.06) 49.5%,rgba(255,255,255,0.06) 50.5%,transparent 50.5%);pointer-events:none;}
.pitch-slot{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:transform .15s;z-index:2;}
.pitch-slot:hover{transform:translate(-50%,-50%) scale(1.08);}
.pitch-slot.filled:hover{transform:translate(-50%,-50%) scale(1.05);}
.pitch-circle{width:42px;height:42px;border-radius:50%;border:2px solid rgba(255,255,255,0.15);background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;font-size:20px;position:relative;transition:all .2s;}
.pitch-slot.filled .pitch-circle{border-color:var(--gold);background:rgba(239,159,39,0.15);box-shadow:0 0 12px rgba(239,159,39,0.3);}
.pitch-slot.filled.rare .pitch-circle{border-color:var(--rare-c);background:rgba(91,164,245,0.15);box-shadow:0 0 12px rgba(91,164,245,0.2);}
.pitch-slot.filled.legendary .pitch-circle{border-color:var(--legendary-c);background:rgba(239,159,39,0.15);box-shadow:0 0 16px rgba(239,159,39,0.35);}
.pitch-slot.filled.icon .pitch-circle{border-color:var(--icon-c);background:rgba(229,53,171,0.15);box-shadow:0 0 18px rgba(229,53,171,0.4);}
.pitch-add{font-size:18px;opacity:0.25;font-weight:300;}
.pitch-slot.filled .pitch-add{display:none;}
.pitch-player-emoji{display:none;font-size:22px;}
.pitch-slot.filled .pitch-player-emoji{display:block;}
.pitch-name-tag{font-size:8px;font-family:var(--fm);font-weight:700;background:rgba(0,0,0,0.7);color:#fff;padding:2px 5px;border-radius:3px;white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis;text-align:center;letter-spacing:.3px;}
.pitch-pos-tag{font-size:7px;font-family:var(--fm);padding:1px 4px;border-radius:2px;}
.pos-tag-POR{background:rgba(227,30,36,.3);color:#f07070;}
.pos-tag-DEF{background:rgba(91,164,245,.3);color:#7ab4f0;}
.pos-tag-MED{background:rgba(0,166,80,.3);color:#4dc98a;}
.pos-tag-DEL{background:rgba(239,159,39,.3);color:var(--gold);}
.pitch-remove{position:absolute;top:-4px;right:-4px;width:14px;height:14px;background:var(--red);border-radius:50%;font-size:9px;display:none;align-items:center;justify-content:center;color:#fff;font-weight:700;z-index:3;}
.pitch-slot.filled:hover .pitch-remove{display:flex;}
.lineup-rating{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface3);border-radius:8px;margin-top:12px;}
.rating-num{font-family:var(--fd);font-size:36px;letter-spacing:1px;background:linear-gradient(135deg,var(--gold),var(--red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.rating-label{font-size:10px;color:var(--muted);font-family:var(--fm);letter-spacing:1px;}
.rating-stars{color:var(--gold);font-size:12px;letter-spacing:1px;}
.picker-panel{background:var(--surface2);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;overflow:hidden;max-height:80vh;}
.picker-header{padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.picker-title{font-family:var(--fd);font-size:20px;letter-spacing:2px;margin-bottom:8px;}
.picker-search{width:100%;padding:7px 10px;background:var(--surface3);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:var(--fb);font-size:13px;outline:none;}
.picker-search:focus{border-color:var(--gold);}
.picker-filters{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap;}
.filter-btn{padding:3px 9px;border-radius:4px;font-size:10px;font-family:var(--fm);border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .12s;}
.filter-btn.active{background:var(--surface3);border-color:var(--gold);color:var(--gold);}
.filter-btn:hover:not(.active){color:var(--text);}
.picker-list{overflow-y:auto;flex:1;}
.picker-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid rgba(255,255,255,0.02);}
.picker-item:hover{background:rgba(255,255,255,0.03);}
.picker-item.already-used{opacity:.35;cursor:not-allowed;}
.picker-item.not-owned{opacity:.28;cursor:not-allowed;}
.picker-emoji{font-size:18px;width:26px;text-align:center;flex-shrink:0;}
.picker-info{flex:1;min-width:0;}
.picker-name{font-size:12px;font-weight:700;color:var(--text);font-family:var(--fb);}
.picker-meta{font-size:10px;color:var(--muted);font-family:var(--fs);}
.picker-rarity{font-size:7px;font-family:var(--fm);padding:1px 5px;border-radius:2px;flex-shrink:0;letter-spacing:.5px;}
.r-common{background:rgba(136,153,170,.15);color:var(--common-c);}
.r-rare{background:rgba(91,164,245,.15);color:var(--rare-c);}
.r-legendary{background:rgba(239,159,39,.15);color:var(--legendary-c);}
.r-icon{background:rgba(229,53,171,.15);color:var(--icon-c);}
.lineup-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.lineup-name-input{flex:1;padding:8px 12px;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;color:var(--text);font-family:var(--fb);font-size:13px;outline:none;min-width:140px;}
.lineup-name-input:focus{border-color:var(--gold);}
.lineup-saved-list{margin-top:14px;}
.saved-entry{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface3);border-radius:8px;margin-bottom:6px;border:1px solid var(--border);cursor:pointer;transition:border-color .12s;}
.saved-entry:hover{border-color:var(--border2);}
.saved-entry-name{font-size:12px;font-weight:700;flex:1;font-family:var(--fb);}
.saved-entry-rating{font-family:var(--fd);font-size:18px;color:var(--gold);}
.saved-entry-del{font-size:11px;color:var(--muted);padding:2px 6px;border-radius:4px;border:1px solid var(--border);background:transparent;cursor:pointer;}
.saved-entry-del:hover{border-color:var(--red);color:var(--red);}
.picker-slot-target{background:var(--gold-dim);border:1px solid var(--gold);border-radius:6px;padding:7px 12px;font-size:11px;font-family:var(--fm);color:var(--gold);letter-spacing:1px;text-align:center;margin-bottom:8px;}

/* ══════════════════════════════════════
   TRIVIA
══════════════════════════════════════ */
.trivia-lobby{display:flex;flex-direction:column;align-items:center;padding:20px 0 40px;gap:0;}
.trivia-hero{text-align:center;margin-bottom:36px;}
.trivia-hero h2{font-family:var(--fd);font-size:52px;letter-spacing:4px;line-height:1;}
.trivia-hero p{font-size:14px;color:var(--muted);font-family:var(--fs);margin-top:8px;max-width:460px;line-height:1.6;}
.trivia-modes{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;width:100%;max-width:800px;margin-bottom:32px;}
.trivia-mode-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:22px 20px;cursor:pointer;transition:all .15s;text-align:center;}
.trivia-mode-card:hover{transform:translateY(-3px);border-color:var(--border2);}
.trivia-mode-card.selected{border-color:var(--gold);background:var(--gold-dim);}
.tmc-icon{font-size:32px;margin-bottom:10px;}
.tmc-name{font-family:var(--fd);font-size:20px;letter-spacing:1px;margin-bottom:4px;}
.tmc-desc{font-size:11px;color:var(--muted);font-family:var(--fs);line-height:1.5;}
.tmc-badge{display:inline-block;margin-top:8px;font-size:9px;font-family:var(--fm);letter-spacing:1px;padding:2px 8px;border-radius:3px;}
.trivia-cats{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:28px;}
.trivia-cat-btn{padding:7px 16px;border-radius:20px;font-size:12px;font-family:var(--fb);font-weight:600;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .12s;letter-spacing:.3px;}
.trivia-cat-btn.active{background:var(--surface3);border-color:var(--gold);color:var(--gold);}
.trivia-cat-btn:hover:not(.active){color:var(--text);border-color:var(--border3);}
.trivia-start-btn{padding:14px 48px;border-radius:10px;font-family:var(--fd);font-size:22px;letter-spacing:3px;background:linear-gradient(135deg,var(--red),var(--blue));color:#fff;border:none;cursor:pointer;transition:all .15s;box-shadow:0 4px 20px rgba(227,30,36,0.3);}
.trivia-start-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(227,30,36,0.4);}
.trivia-game{max-width:700px;margin:0 auto;padding:0 0 60px;}
.trivia-hud{display:flex;align-items:center;gap:0;background:var(--surface2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:28px;}
.hud-cell{flex:1;padding:12px 16px;border-right:1px solid var(--border);text-align:center;}
.hud-cell:last-child{border:none;}
.hud-val{font-family:var(--fd);font-size:26px;letter-spacing:1px;}
.hud-val.green{color:var(--green);}
.hud-val.gold{color:var(--gold);}
.hud-val.red{color:var(--red);}
.hud-lbl{font-size:8px;font-family:var(--fm);letter-spacing:2px;color:var(--muted);margin-top:1px;}
.trivia-timer-wrap{height:4px;background:var(--border);border-radius:2px;margin-bottom:24px;overflow:hidden;}
.trivia-timer-bar{height:100%;border-radius:2px;transition:width .1s linear;background:linear-gradient(90deg,var(--green),var(--gold));}
.trivia-timer-bar.danger{background:linear-gradient(90deg,var(--gold),var(--red));}
.trivia-q-card{background:var(--surface2);border:1px solid var(--border);border-radius:16px;padding:28px 28px 24px;margin-bottom:20px;position:relative;overflow:hidden;}
.trivia-q-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.cat-historia .trivia-q-card::before{background:var(--gold);}
.cat-jugadores .trivia-q-card::before{background:var(--rare-c);}
.cat-estadios .trivia-q-card::before{background:var(--green);}
.cat-records .trivia-q-card::before{background:var(--red);}
.cat-selecciones .trivia-q-card::before{background:var(--icon-c);}
.cat-mix .trivia-q-card::before{background:linear-gradient(90deg,var(--red),var(--blue),var(--green));}
.trivia-q-meta{display:flex;align-items:center;gap:8px;margin-bottom:14px;}
.trivia-q-cat{font-size:9px;font-family:var(--fm);letter-spacing:2px;color:var(--muted);}
.trivia-q-diff{font-size:9px;font-family:var(--fm);padding:2px 7px;border-radius:3px;}
.diff-easy{background:rgba(0,166,80,.15);color:var(--green);}
.diff-medium{background:rgba(239,159,39,.15);color:var(--gold);}
.diff-hard{background:rgba(227,30,36,.15);color:var(--red);}
.trivia-q-num{margin-left:auto;font-size:10px;font-family:var(--fm);color:var(--muted);}
.trivia-q-text{font-family:var(--fb);font-size:21px;font-weight:700;line-height:1.4;color:var(--text);margin-bottom:4px;}
.trivia-q-hint{font-size:12px;color:var(--muted);font-family:var(--fs);margin-top:6px;font-style:italic;}
.trivia-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.trivia-opt{padding:14px 16px;border-radius:10px;border:1px solid var(--border2);background:var(--surface2);font-family:var(--fb);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;text-align:left;display:flex;align-items:center;gap:10px;letter-spacing:.2px;color:var(--text);}
.trivia-opt:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:var(--gold-dim);}
.trivia-opt:disabled{cursor:not-allowed;}
.trivia-opt.correct{background:rgba(0,166,80,.12);border-color:var(--green);color:var(--green);}
.trivia-opt.wrong{background:rgba(227,30,36,.1);border-color:var(--red);color:var(--red);}
.trivia-opt.missed{border-color:var(--green);border-style:dashed;color:var(--muted);}
.opt-key{width:22px;height:22px;border-radius:4px;background:rgba(255,255,255,0.05);border:1px solid var(--border2);font-size:10px;font-family:var(--fm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;}
.trivia-opt.correct .opt-key{background:var(--green);border-color:var(--green);color:#000;}
.trivia-opt.wrong .opt-key{background:var(--red);border-color:var(--red);color:#fff;}
.trivia-feedback{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:16px;display:none;}
.trivia-feedback.show{display:flex;align-items:flex-start;gap:14px;}
.tf-icon{font-size:28px;flex-shrink:0;}
.tf-title{font-family:var(--fd);font-size:20px;letter-spacing:1px;margin-bottom:3px;}
.tf-title.correct{color:var(--green);}
.tf-title.wrong{color:var(--red);}
.tf-explain{font-size:13px;color:var(--muted);font-family:var(--fs);line-height:1.6;}
.tf-pts{font-family:var(--fd);font-size:16px;color:var(--gold);margin-top:4px;}
.trivia-next-btn{width:100%;padding:13px;border-radius:10px;background:linear-gradient(135deg,var(--red),var(--blue));border:none;color:#fff;font-family:var(--fd);font-size:20px;letter-spacing:3px;cursor:pointer;transition:all .15s;display:none;}
.trivia-next-btn.show{display:block;}
.trivia-next-btn:hover{opacity:.88;transform:translateY(-1px);}
.trivia-progress{display:flex;gap:6px;justify-content:center;margin-bottom:20px;flex-wrap:wrap;}
.prog-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:all .3s;}
.prog-dot.correct{background:var(--green);}
.prog-dot.wrong{background:var(--red);}
.prog-dot.current{background:var(--gold);box-shadow:0 0 6px var(--gold-glow);}
.trivia-results{max-width:540px;margin:0 auto;text-align:center;padding:20px 0 60px;}
.results-trophy{font-size:72px;margin-bottom:16px;animation:trophyBounce .6s ease;}
@keyframes trophyBounce{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.results-title{font-family:var(--fd);font-size:48px;letter-spacing:4px;margin-bottom:4px;}
.results-score{font-family:var(--fd);font-size:80px;letter-spacing:-2px;line-height:1;background:linear-gradient(135deg,var(--gold),var(--red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.results-label{font-size:12px;color:var(--muted);font-family:var(--fm);letter-spacing:2px;margin-bottom:24px;}
.results-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:24px;}
.results-stat{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 10px;}
.results-stat .n{font-family:var(--fd);font-size:28px;letter-spacing:1px;}
.results-stat .l{font-size:9px;font-family:var(--fm);letter-spacing:1px;color:var(--muted);margin-top:2px;}
.results-review{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:left;margin-bottom:20px;max-height:260px;overflow-y:auto;}
.review-item{padding:10px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;}
.review-item:last-child{border:none;}
.review-ico{flex-shrink:0;font-size:14px;margin-top:1px;}
.review-q{font-size:11px;color:var(--text);font-family:var(--fb);font-weight:600;line-height:1.4;}
.review-a{font-size:10px;color:var(--muted);font-family:var(--fs);margin-top:2px;}
.review-a strong{color:var(--green);}
.results-btns{display:flex;gap:10px;justify-content:center;}
.res-btn{padding:11px 28px;border-radius:8px;font-family:var(--fd);font-size:16px;letter-spacing:2px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);}
.res-btn.primary{background:linear-gradient(135deg,var(--red),var(--blue));border:none;color:#fff;}
.res-btn.secondary{background:transparent;color:var(--muted);}
.res-btn:hover{transform:translateY(-1px);}

/* ══════════════════════════════════════
   PREDICTOR IA
══════════════════════════════════════ */
.predictor-wrap{max-width:900px;margin:0 auto;}
.predictor-hero{text-align:center;padding:36px 20px 28px;background:var(--surface2);border:1px solid var(--border);border-radius:18px;margin-bottom:24px;position:relative;overflow:hidden;}
.predictor-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 30% 50%,rgba(227,30,36,0.08),transparent 60%),radial-gradient(ellipse at 70% 50%,rgba(0,79,159,0.08),transparent 60%);}
.predictor-hero h2{font-family:var(--fd);font-size:44px;letter-spacing:4px;position:relative;background:linear-gradient(90deg,var(--red),var(--text),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.predictor-hero p{font-size:13px;color:var(--muted);font-family:var(--fs);margin-top:6px;position:relative;}
.pred-modes{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px;}
.pred-mode{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px 14px;cursor:pointer;transition:all .15s;text-align:center;}
.pred-mode:hover{border-color:var(--border2);transform:translateY(-2px);}
.pred-mode.active{border-color:var(--gold);background:var(--gold-dim);}
.pred-mode-icon{font-size:24px;margin-bottom:6px;}
.pred-mode-name{font-family:var(--fd);font-size:16px;letter-spacing:1px;margin-bottom:3px;}
.pred-mode-desc{font-size:10px;color:var(--muted);font-family:var(--fs);}
.pred-arena{display:grid;grid-template-columns:1fr 64px 1fr;align-items:center;gap:12px;margin-bottom:20px;}
.pred-team-slot{background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:20px 16px;text-align:center;cursor:pointer;transition:all .15s;min-height:130px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative;}
.pred-team-slot:hover{border-color:var(--gold);background:var(--gold-dim);}
.pred-team-slot.selected{border-color:var(--gold);background:var(--gold-dim);}
.pred-team-slot.selecting{border-color:var(--blue);background:rgba(0,79,159,0.08);animation:selectPulse 1s ease-in-out infinite;}
@keyframes selectPulse{0%,100%{border-color:var(--blue)}50%{border-color:rgba(0,79,159,0.3)}}
.pred-flag-big{width:56px;height:40px;object-fit:cover;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,0.3);}
.pred-team-name{font-family:var(--fd);font-size:17px;letter-spacing:1px;}
.pred-team-rank{font-size:9px;font-family:var(--fm);color:var(--muted);letter-spacing:1px;}
.pred-team-slot .add-hint{font-size:28px;opacity:0.2;}
.pred-slot-label{font-size:9px;font-family:var(--fm);color:var(--muted);letter-spacing:2px;margin-bottom:4px;}
.pred-vs{font-family:var(--fd);font-size:28px;letter-spacing:2px;text-align:center;color:var(--muted);}
.pred-picker{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;overflow:hidden;margin-bottom:20px;display:none;}
.pred-picker.open{display:block;}
.pred-picker-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.pred-picker-search{flex:1;background:var(--surface3);border:1px solid var(--border2);border-radius:6px;padding:6px 10px;color:var(--text);font-family:var(--fb);font-size:13px;outline:none;}
.pred-picker-search:focus{border-color:var(--gold);}
.pred-picker-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px;transition:color .12s;}
.pred-picker-close:hover{color:var(--red);}
.pred-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px;padding:12px;max-height:280px;overflow-y:auto;}
.pred-country-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .12s;text-align:left;color:var(--text);}
.pred-country-btn:hover{border-color:var(--gold);background:var(--gold-dim);}
.pred-country-flag{width:20px;height:14px;object-fit:cover;border-radius:2px;flex-shrink:0;}
.pred-country-name{font-size:11px;font-family:var(--fb);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pred-btn{width:100%;padding:15px;border-radius:12px;background:linear-gradient(135deg,var(--red) 0%,var(--blue) 100%);border:none;color:#fff;font-family:var(--fd);font-size:22px;letter-spacing:4px;cursor:pointer;transition:all .15s;margin-bottom:24px;position:relative;overflow:hidden;}
.pred-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,0.06) 50%,transparent 100%);animation:predSheen 3s ease-in-out infinite;}
@keyframes predSheen{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.pred-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(227,30,36,0.35);}
.pred-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.pred-loading{text-align:center;padding:48px 20px;background:var(--surface2);border:1px solid var(--border);border-radius:14px;margin-bottom:24px;}
.pred-loading-orb{width:64px;height:64px;border-radius:50%;margin:0 auto 20px;background:conic-gradient(var(--red),var(--blue),var(--green),var(--gold),var(--red));animation:orbSpin 1.2s linear infinite;}
@keyframes orbSpin{to{transform:rotate(360deg)}}
.pred-loading-text{font-family:var(--fd);font-size:22px;letter-spacing:3px;margin-bottom:6px;}
.pred-loading-sub{font-size:12px;color:var(--muted);font-family:var(--fs);}
.pred-loading-steps{margin-top:20px;display:flex;flex-direction:column;gap:6px;max-width:300px;margin-left:auto;margin-right:auto;}
.pred-step{display:flex;align-items:center;gap:8px;font-size:11px;font-family:var(--fm);color:var(--muted);letter-spacing:.5px;transition:color .3s;}
.pred-step.active{color:var(--text);}
.pred-step.done{color:var(--green);}
.pred-step-dot{width:6px;height:6px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background .3s;}
.pred-step.active .pred-step-dot{background:var(--gold);box-shadow:0 0 6px var(--gold);}
.pred-step.done .pred-step-dot{background:var(--green);}
.pred-result{background:var(--surface2);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:20px;animation:resultReveal .4s cubic-bezier(.34,1.56,.64,1) forwards;}
@keyframes resultReveal{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
.pred-result-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.pred-result-header .ai-badge{font-size:9px;font-family:var(--fm);letter-spacing:2px;background:rgba(127,119,221,0.15);color:#a09ae8;padding:3px 8px;border-radius:4px;border:1px solid rgba(127,119,221,0.25);}
.pred-result-title{font-family:var(--fd);font-size:22px;letter-spacing:2px;flex:1;}
.pred-winner-banner{padding:24px;display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,var(--surface3),rgba(239,159,39,0.04));}
.pred-winner-flag{width:72px;height:52px;object-fit:cover;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.4);flex-shrink:0;}
.pred-winner-label{font-size:9px;font-family:var(--fm);letter-spacing:3px;color:var(--gold);margin-bottom:4px;}
.pred-winner-name{font-family:var(--fd);font-size:32px;letter-spacing:2px;}
.pred-winner-prob{font-family:var(--fd);font-size:48px;letter-spacing:-1px;margin-left:auto;background:linear-gradient(135deg,var(--gold),var(--red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.pred-winner-prob-label{font-size:9px;font-family:var(--fm);color:var(--muted);text-align:right;letter-spacing:1px;}
.pred-score-box{display:flex;align-items:center;justify-content:center;gap:20px;padding:16px 24px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(255,255,255,0.01);}
.pred-score-team{text-align:center;}
.pred-score-flag2{width:32px;height:23px;object-fit:cover;border-radius:3px;margin-bottom:4px;}
.pred-score-name{font-size:10px;font-family:var(--fm);color:var(--muted);}
.pred-score-num{font-family:var(--fd);font-size:42px;letter-spacing:-1px;line-height:1;}
.pred-score-sep{font-family:var(--fd);font-size:28px;color:var(--muted);}
.pred-analysis{padding:20px 24px;font-family:var(--fs);font-size:14px;line-height:1.75;color:var(--text);}
.pred-analysis p{margin-bottom:12px;}
.pred-analysis p:last-child{margin-bottom:0;}
.pred-analysis strong{color:var(--gold);}
.pred-stats-grid{display:grid;grid-template-columns:1fr 80px 1fr;gap:0;padding:16px 24px;border-top:1px solid var(--border);}
.pred-stat-row{display:contents;}
.pred-stat-left{text-align:right;font-size:13px;font-family:var(--fb);font-weight:600;padding:5px 8px;}
.pred-stat-label{text-align:center;font-size:9px;font-family:var(--fm);letter-spacing:1px;color:var(--muted);padding:5px 0;display:flex;align-items:center;justify-content:center;}
.pred-stat-right{text-align:left;font-size:13px;font-family:var(--fb);font-weight:600;padding:5px 8px;}
.pred-stat-bar-wrap{grid-column:1/-1;height:4px;background:var(--border);border-radius:2px;margin:2px 0 8px;overflow:hidden;position:relative;}
.pred-stat-bar-l{position:absolute;right:50%;top:0;bottom:0;border-radius:2px 0 0 2px;background:var(--red);transition:width .8s ease;}
.pred-stat-bar-r{position:absolute;left:50%;top:0;bottom:0;border-radius:0 2px 2px 0;background:var(--blue);transition:width .8s ease;}
.pred-factors{padding:16px 24px;border-top:1px solid var(--border);}
.pred-factors-title{font-size:9px;font-family:var(--fm);letter-spacing:2px;color:var(--muted);margin-bottom:10px;}
.pred-factor{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:12px;font-family:var(--fs);color:var(--text);line-height:1.5;}
.pred-factor-ico{flex-shrink:0;font-size:14px;}
.pred-actions{display:flex;gap:10px;margin-top:4px;}
.pred-action-btn{flex:1;padding:11px;border-radius:8px;font-family:var(--fd);font-size:15px;letter-spacing:2px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:transparent;color:var(--muted);}
.pred-action-btn:hover{border-color:var(--border3);color:var(--text);}
.pred-action-btn.primary{background:var(--gold);border-color:var(--gold);color:#1a0a00;}
.pred-action-btn.primary:hover{background:#f5b040;}
.stream-cursor{display:inline-block;width:2px;height:1em;background:var(--gold);margin-left:2px;vertical-align:middle;animation:blink .7s step-end infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ══════════════════════════════════════
   GOLEADORES
══════════════════════════════════════ */
.scorers-section{margin-bottom:28px;}
.scorers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;}
.scorer-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;transition:border-color .15s;}
.scorer-card:hover{border-color:var(--border2);}
.scorer-card.top1{border-color:rgba(239,159,39,0.45);background:linear-gradient(135deg,rgba(239,159,39,0.06),var(--surface2));}
.scorer-card.top2{border-color:rgba(192,192,192,0.35);}
.scorer-card.top3{border-color:rgba(176,141,87,0.35);}
.scorer-rank{font-family:var(--fd);font-size:28px;letter-spacing:-1px;flex-shrink:0;width:28px;text-align:center;}
.scorer-rank.r1{color:var(--gold);}
.scorer-rank.r2{color:#C0C0C0;}
.scorer-rank.r3{color:#B08D57;}
.scorer-rank.r4{color:var(--muted);}
.scorer-emoji{font-size:26px;flex-shrink:0;}
.scorer-info{flex:1;min-width:0;}
.scorer-name{font-family:var(--fb);font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.scorer-era{font-size:10px;color:var(--muted);font-family:var(--fs);margin-top:1px;}
.scorer-goals-wrap{text-align:right;flex-shrink:0;}
.scorer-goals{font-family:var(--fd);font-size:32px;letter-spacing:-1px;line-height:1;}
.scorer-goals.g1{color:var(--gold);}
.scorer-goals.g2{color:#C0C0C0;}
.scorer-goals.g3{color:#B08D57;}
.scorer-goals.g4{color:var(--text);}
.scorer-goals-label{font-size:8px;font-family:var(--fm);letter-spacing:1px;color:var(--muted);margin-top:1px;}
.scorer-bar{position:absolute;bottom:0;left:0;height:2px;border-radius:0 2px 2px 0;transition:width 1s ease;}
.scorer-card.top1 .scorer-bar{background:var(--gold);}
.scorer-card.top2 .scorer-bar{background:#C0C0C0;}
.scorer-card.top3 .scorer-bar{background:#B08D57;}
.scorer-card .scorer-bar{background:var(--border2);}
.scorer-appearances{font-size:9px;font-family:var(--fm);color:var(--muted);padding:2px 6px;background:rgba(255,255,255,0.04);border-radius:3px;margin-top:4px;display:inline-block;}

/* ══════════════════════════════════════
   COMPARADOR
══════════════════════════════════════ */
.cmp-wrap{max-width:960px;margin:0 auto;padding-bottom:60px;}
.cmp-hero{text-align:center;padding:32px 20px 24px;background:var(--surface2);border:1px solid var(--border);border-radius:18px;margin-bottom:24px;position:relative;overflow:hidden;}
.cmp-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 20% 50%,rgba(239,159,39,0.07),transparent 55%),radial-gradient(ellipse at 80% 50%,rgba(91,164,245,0.07),transparent 55%);}
.cmp-hero h2{font-family:var(--fd);font-size:42px;letter-spacing:4px;position:relative;}
.cmp-hero p{font-size:13px;color:var(--muted);font-family:var(--fs);margin-top:6px;position:relative;}
.cmp-arena{display:grid;grid-template-columns:1fr 60px 1fr;align-items:start;gap:12px;margin-bottom:20px;}
.cmp-slot{background:var(--surface2);border:1.5px dashed rgba(255,255,255,0.1);border-radius:16px;padding:22px 16px;text-align:center;cursor:pointer;transition:all .15s;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;}
.cmp-slot:hover{border-color:rgba(255,255,255,0.2);background:rgba(255,255,255,0.02);}
.cmp-slot.has-player{border-style:solid;cursor:default;}
.cmp-slot.slot-a.has-player{border-color:rgba(239,159,39,0.4);background:rgba(239,159,39,0.04);}
.cmp-slot.slot-b.has-player{border-color:rgba(91,164,245,0.4);background:rgba(91,164,245,0.04);}
.cmp-slot.selecting{border-style:solid;border-color:var(--gold);animation:slotPulse 1.2s ease-in-out infinite;}
@keyframes slotPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,159,39,0)}50%{box-shadow:0 0 0 6px rgba(239,159,39,0.12)}}
.cmp-slot-emoji{font-size:44px;line-height:1;}
.cmp-slot-name{font-family:var(--fd);font-size:20px;letter-spacing:1px;margin-top:2px;}
.cmp-slot-meta{font-size:11px;color:var(--muted);font-family:var(--fs);}
.cmp-slot-flag{width:32px;height:23px;object-fit:cover;border-radius:4px;flex-shrink:0;}
.cmp-slot-rarity{font-size:9px;font-family:var(--fm);letter-spacing:1px;padding:3px 8px;border-radius:3px;}
.cmp-slot-hint{font-size:12px;color:var(--muted);font-family:var(--fm);letter-spacing:1px;}
.cmp-slot-add{font-size:32px;opacity:.15;}
.cmp-slot-change{font-size:9px;font-family:var(--fm);letter-spacing:1px;color:var(--muted);padding:4px 10px;border-radius:4px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .12s;margin-top:4px;}
.cmp-slot-change:hover{border-color:var(--gold);color:var(--gold);}
.cmp-vs-col{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding-top:40px;}
.cmp-vs{font-family:var(--fd);font-size:26px;color:var(--muted);letter-spacing:2px;}
.cmp-picker{background:var(--surface2);border:1px solid var(--border2);border-radius:14px;overflow:hidden;margin-bottom:20px;display:none;}
.cmp-picker.open{display:block;}
.cmp-picker-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.cmp-picker-title{font-size:11px;font-family:var(--fm);letter-spacing:1px;color:var(--muted);}
.cmp-picker-search{flex:1;background:var(--surface3);border:1px solid var(--border2);border-radius:6px;padding:6px 10px;color:var(--text);font-family:var(--fb);font-size:13px;outline:none;}
.cmp-picker-search:focus{border-color:var(--gold);}
.cmp-picker-filters{display:flex;gap:5px;padding:8px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.cmp-filter{padding:3px 10px;border-radius:4px;font-size:10px;font-family:var(--fm);border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .12s;}
.cmp-filter.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold);}
.cmp-filter:hover:not(.active){color:var(--text);}
.cmp-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;padding:12px;max-height:300px;overflow-y:auto;}
.cmp-player-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .12s;text-align:left;color:var(--text);}
.cmp-player-btn:hover{border-color:var(--gold);background:var(--gold-dim);}
.cmp-player-btn[disabled],.cmp-player-btn.not-owned{opacity:.3;cursor:not-allowed;}
.cmp-player-btn .pe{font-size:18px;flex-shrink:0;}
.cmp-player-btn .pi{flex:1;min-width:0;}
.cmp-player-btn .pn{font-size:11px;font-family:var(--fb);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cmp-player-btn .pm{font-size:9px;color:var(--muted);font-family:var(--fs);}
.cmp-player-btn .pr{font-size:7px;font-family:var(--fm);padding:1px 4px;border-radius:2px;flex-shrink:0;}
.cmp-card{background:var(--surface2);border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-bottom:16px;}
.cmp-card-header{display:grid;grid-template-columns:1fr auto 1fr;border-bottom:1px solid var(--border);}
.cmp-player-head{padding:20px 20px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.cmp-player-head.side-b{background:rgba(91,164,245,0.03);}
.cmp-player-head.side-a{background:rgba(239,159,39,0.03);}
.cmp-ph-emoji{font-size:48px;line-height:1;}
.cmp-ph-name{font-family:var(--fd);font-size:22px;letter-spacing:1px;text-align:center;}
.cmp-ph-club{font-size:11px;color:var(--muted);font-family:var(--fs);}
.cmp-ph-flag{width:28px;height:20px;object-fit:cover;border-radius:3px;}
.cmp-ph-rarity{font-size:8px;font-family:var(--fm);padding:2px 7px;border-radius:3px;letter-spacing:.5px;}
.cmp-divider-col{width:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-left:1px solid var(--border);border-right:1px solid var(--border);padding:12px 0;gap:6px;}
.cmp-winner-badge{font-size:9px;font-family:var(--fm);letter-spacing:1px;padding:3px 6px;border-radius:3px;writing-mode:vertical-lr;}
.cmp-stats-body{padding:0;}
.cmp-stat-row{display:grid;grid-template-columns:1fr 120px 1fr;align-items:center;border-bottom:1px solid rgba(255,255,255,0.03);transition:background .1s;}
.cmp-stat-row:last-child{border:none;}
.cmp-stat-row:hover{background:rgba(255,255,255,0.02);}
.cmp-stat-val{padding:10px 14px;font-family:var(--fd);font-size:22px;letter-spacing:.5px;}
.cmp-stat-val.side-a{text-align:left;color:var(--gold);}
.cmp-stat-val.side-b{text-align:right;color:var(--rare-c);}
.cmp-stat-val.winner-a{color:var(--gold);text-shadow:0 0 12px rgba(239,159,39,0.4);}
.cmp-stat-val.winner-b{color:var(--rare-c);text-shadow:0 0 12px rgba(91,164,245,0.35);}
.cmp-stat-val.tie{color:var(--muted);}
.cmp-stat-mid{text-align:center;padding:8px 6px;}
.cmp-stat-label{font-size:9px;font-family:var(--fm);letter-spacing:1.5px;color:var(--muted);margin-bottom:5px;}
.cmp-stat-bar-wrap{height:4px;background:var(--border);border-radius:2px;overflow:hidden;display:flex;}
.cmp-stat-bar-a{height:100%;background:var(--gold);border-radius:2px 0 0 2px;transition:width .9s ease;}
.cmp-stat-bar-b{height:100%;background:var(--rare-c);border-radius:0 2px 2px 0;transition:width .9s ease;}
.cmp-verdict{padding:20px 24px;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;}
.cmp-verdict-side{text-align:center;}
.cmp-verdict-score{font-family:var(--fd);font-size:44px;letter-spacing:-1px;line-height:1;}
.cmp-verdict-score.side-a{color:var(--gold);}
.cmp-verdict-score.side-b{color:var(--rare-c);}
.cmp-verdict-label{font-size:9px;font-family:var(--fm);letter-spacing:2px;color:var(--muted);margin-top:3px;}
.cmp-verdict-mid{text-align:center;}
.cmp-verdict-winner{font-family:var(--fd);font-size:13px;letter-spacing:2px;padding:8px 16px;border-radius:8px;}
.cmp-verdict-winner.a{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(239,159,39,0.3);}
.cmp-verdict-winner.b{background:rgba(91,164,245,0.1);color:var(--rare-c);border:1px solid rgba(91,164,245,0.3);}
.cmp-verdict-winner.tie{background:var(--surface3);color:var(--muted);border:1px solid var(--border);}
.cmp-owned-badge{font-size:8px;font-family:var(--fm);padding:2px 6px;border-radius:3px;background:rgba(0,166,80,0.12);color:var(--green);border:1px solid rgba(0,166,80,0.2);}
.cmp-actions{display:flex;gap:10px;}
.cmp-btn{flex:1;padding:11px;border-radius:8px;font-family:var(--fd);font-size:15px;letter-spacing:2px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:transparent;color:var(--muted);}
.cmp-btn:hover{border-color:var(--border3);color:var(--text);}
.cmp-btn.gold{background:var(--gold);border-color:var(--gold);color:#1a0a00;}
.cmp-btn.gold:hover{background:#f5b040;}
.cmp-random-row{display:flex;gap:8px;margin-bottom:20px;align-items:center;}
.cmp-random-btn{padding:8px 16px;border-radius:8px;font-family:var(--fb);font-size:13px;font-weight:600;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .12px;}
.cmp-random-btn:hover{border-color:var(--gold);color:var(--gold);}
.cmp-only-owned{display:flex;align-items:center;gap:6px;font-size:11px;font-family:var(--fm);color:var(--muted);cursor:pointer;margin-left:auto;}
.cmp-only-owned input{accent-color:var(--gold);}

/* ══════════════════════════════════════
   MODO CLARO
══════════════════════════════════════ */
:root.light{
  --bg:#F0F2F8;--surface:#FFFFFF;--surface2:#F5F7FC;--surface3:#E8ECF5;--card:#FFFFFF;
  --border:rgba(0,0,0,0.07);--border2:rgba(0,0,0,0.13);--border3:rgba(0,0,0,0.22);
  --text:#0D1117;--muted:rgba(13,17,23,0.50);--muted2:rgba(13,17,23,0.30);
  --gold-dim:rgba(239,159,39,0.10);--gold-glow:rgba(239,159,39,0.28);
  --green-dim:rgba(0,166,80,0.09);
  --common-c:#5A6978;--rare-c:#1A6FD4;--legendary-c:#C07A00;--icon-c:#C4207E;
}
:root.light ::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);}
:root.light #sidebar{background:var(--surface);border-right-color:var(--border);box-shadow:2px 0 12px rgba(0,0,0,0.07);}
:root.light .sb-item:hover{background:rgba(0,0,0,0.03);}
:root.light .sb-item.active{background:rgba(239,159,39,0.09);}
:root.light .sb-bar{background:rgba(0,0,0,0.08);}
:root.light #topbar{background:var(--surface);border-bottom-color:var(--border);box-shadow:0 1px 8px rgba(0,0,0,0.06);}
:root.light .auth-card{background:var(--surface);box-shadow:0 4px 40px rgba(0,0,0,0.12), 0 0 0 1px var(--border);}
:root.light #auth-screen{background:var(--bg);}
:root.light .auth-input{background:rgba(0,0,0,0.03);border-color:var(--border2);color:var(--text);}
:root.light .auth-input:focus{background:#fff;border-color:var(--gold);}
:root.light .sticker-slot{background:rgba(0,0,0,0.02);border-color:rgba(0,0,0,0.1);}
:root.light .sticker-slot.collected{background:rgba(0,0,0,0.015);}
:root.light .slot-info{background:rgba(255,255,255,0.85);border-top-color:var(--border);}
:root.light .slot-name{color:#0D1117;}
:root.light .slot-club{color:rgba(13,17,23,0.55);}
:root.light .slot-empty-icon{opacity:0.12;}
:root.light .home-card{background:var(--surface);}
:root.light .home-card:hover{background:var(--surface2);}
:root.light .home-hero{background:var(--surface);}
:root.light .home-hero-bg{background:radial-gradient(ellipse at 80% 50%,rgba(0,79,159,0.06) 0%,transparent 60%),radial-gradient(ellipse at 20% 50%,rgba(227,30,36,0.04) 0%,transparent 60%);}
:root.light .info-card{background:var(--surface);}
:root.light .timeline-track{border-left-color:var(--border2);}
:root.light .timeline-item::before{background:var(--surface2);}
:root.light .standings-table{background:var(--surface);}
:root.light .standings-table th{background:var(--surface2);}
:root.light .std-input{background:var(--surface2);color:var(--text);}
:root.light .modal-box{background:var(--surface);}
:root.light #modal-overlay{background:rgba(0,0,0,0.45);}
:root.light .score-input{background:var(--surface2);color:var(--text);}
:root.light .trivia-q-card{background:var(--surface);}
:root.light .trivia-opt{background:var(--surface);}
:root.light .trivia-opt:hover:not(:disabled){background:rgba(239,159,39,0.06);}
:root.light .trivia-hud{background:var(--surface);}
:root.light .trivia-feedback{background:var(--surface2);}
:root.light .trivia-timer-wrap{background:rgba(0,0,0,0.08);}
:root.light .cmp-card{background:var(--surface);}
:root.light .cmp-slot{background:var(--surface2);}
:root.light .cmp-picker{background:var(--surface);}
:root.light .cmp-player-btn{background:var(--surface2);}
:root.light .cmp-stat-row:hover{background:rgba(0,0,0,0.02);}
:root.light .pack-front{background:linear-gradient(135deg,#E8EDF8,#D4DBF0);border-color:rgba(239,159,39,0.5);}
:root.light .pred-team-slot{background:var(--surface);}
:root.light .pred-result{background:var(--surface);}
:root.light .pred-loading{background:var(--surface);}
:root.light .rk-hero{background:var(--surface);}
:root.light .rk-table{background:var(--surface);}
:root.light .rk-row:hover{background:rgba(0,0,0,0.02);}
:root.light .rk-podium-card{background:var(--surface);}
:root.light .rk-my-card{background:rgba(239,159,39,0.05);}
:root.light .pitch-outer{background:var(--surface);}
:root.light .picker-panel{background:var(--surface);}
:root.light .picker-item:hover{background:rgba(0,0,0,0.03);}
:root.light .saved-entry{background:var(--surface2);}
:root.light .fav-hero{background:linear-gradient(135deg,rgba(240,242,248,0.97),rgba(245,247,252,0.9)) !important;}
:root.light .fav-pack-section{background:var(--surface);}
:root.light .fav-mission{background:var(--surface);}
:root.light .fav-players-section{background:var(--surface);}
:root.light .scorer-card{background:var(--surface);}
:root.light .wm-map-container{background:rgba(200,210,235,0.4);}
:root.light .wm-stats-bar{background:rgba(0,0,0,0.03);border-color:rgba(0,0,0,0.07);}
:root.light .wm-pill{background:rgba(0,0,0,0.03);border-color:rgba(0,0,0,0.07);}
:root.light .wm-pill:hover{background:rgba(239,159,39,0.08);}
:root.light .wm-tooltip{background:rgba(255,255,255,0.97);border-color:rgba(0,0,0,0.12);color:#0D1117;}
:root.light #toast{background:var(--surface);border-color:var(--border2);color:var(--text);}
:root.light #toast.success{border-color:rgba(0,166,80,0.3);color:#006830;}
:root.light #toast.error{border-color:rgba(227,30,36,0.3);color:#B01018;}
:root.light .section-label::after{background:var(--border2);}
:root.light .gs-modal{background:var(--surface);}
:root.light .gs-result-item:hover{background:rgba(0,0,0,0.03);}

/* Transiciones suaves para cambio de tema */
html,body,#sidebar,#topbar,#main,
.sticker-slot,.home-card,.home-hero,
.standings-table,.modal-box,.trivia-q-card,
.cmp-card,.picker-panel,
.fav-hero,.fav-pack-section,.scorer-card{
  transition:background-color 0.25s ease,border-color 0.2s ease,color 0.2s ease,box-shadow 0.2s ease;
}

/* Theme toggle */
.theme-toggle{display:flex;align-items:center;gap:6px;background:var(--surface3);border:1px solid var(--border2);border-radius:20px;padding:3px 3px 3px 10px;cursor:pointer;transition:all .2s;user-select:none;font-family:var(--fm);font-size:10px;letter-spacing:1px;color:var(--muted);}
.theme-toggle:hover{border-color:var(--gold);color:var(--text);}
.theme-toggle-track{width:32px;height:18px;border-radius:9px;background:var(--surface);border:1px solid var(--border2);position:relative;flex-shrink:0;transition:background .2s;}
:root.light .theme-toggle-track{background:#C9D1E8;}
.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:var(--muted);transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1;}
:root.light .theme-toggle-thumb{transform:translateX(14px);background:var(--gold);}
.tb-theme-toggle{display:flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:5px 10px;cursor:pointer;transition:all .15s;font-size:14px;color:var(--muted);}
.tb-theme-toggle:hover{border-color:var(--gold);color:var(--text);}
.tb-theme-label{font-size:9px;font-family:var(--fm);letter-spacing:1px;}

/* Responsive */
@media (max-width:520px){
  .auth-card{width:92%;padding:34px 24px;border-radius:20px;}
  .auth-logo-num{font-size:64px;}
  .auth-title{font-size:24px;}
  .auth-sub{font-size:13px;margin-bottom:20px;}
  .auth-row{grid-template-columns:1fr;}
  .auth-btn{padding:12px 16px;font-size:15px;}
}

/* ══════════════════════════════════════
   LÁMINAS ESPECIALES — Bandera y Plantel
══════════════════════════════════════ */

/* Grid de láminas especiales: más anchas para mostrar bien la bandera/plantel */
.stickers-grid-special {
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

/* La lámina especial tiene más altura para bandera landscape */
.sticker-special {
  aspect-ratio: 3/4;
  border-color: var(--border2) !important;
}

/* Foto de plantel: imagen wide adaptada al aspect-ratio de la tarjeta */
.slot-team-img {
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface3);
}
.slot-team-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Bandera: centrada con padding para que respire */
.slot-flag-img {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface3);
  padding: 10px;
}
.slot-flag-img img {
  width: 100%;
  height: auto;
  max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.4);
}

/* Label especial dentro de la lámina */
.slot-special-label {
  font-size: 7px;
  font-family: var(--fm);
  letter-spacing: 1px;
  color: var(--gold);
  margin-top: 2px;
  text-transform: uppercase;
}

/* Lámina de bandera collected: borde dorado */
.sticker-special.common.collected {
  border-color: var(--gold) !important;
  border-style: solid !important;
  box-shadow: 0 0 14px rgba(239,159,39,0.2);
}

/* Lámina de plantel collected: borde azul */
.sticker-special.rare.collected {
  border-color: var(--rare-c) !important;
  box-shadow: 0 0 14px rgba(91,164,245,0.25);
}

/* En el sobre, las especiales destacan más */
.pack-sticker-reveal .sticker-special {
  transform-origin: center bottom;
}
.pack-sticker-reveal.shown .sticker-special {
  animation: cardRevealSpecial 0.6s cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes cardRevealSpecial {
  to { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════
   STICKER DETAIL MODAL
══════════════════════════════════════ */
.sdm-overlay{
  position:fixed;inset:0;z-index:600;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;transition:opacity .25s;
}
.sdm-overlay.sdm-open{opacity:1;}
.sdm-card{
  width:100%;max-width:420px;
  max-height:92vh;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:20px;overflow:hidden;overflow-y:auto;
  position:relative;
  transform:scale(.93) translateY(16px);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
  display:flex;flex-direction:column;
}
.sdm-card::-webkit-scrollbar{width:3px;}
.sdm-card::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.sdm-overlay.sdm-open .sdm-card{transform:none;}
.sdm-top-bar{height:4px;width:100%;}
.sdm-bar-common{background:var(--common-c);}
.sdm-bar-rare{background:var(--rare-c);}
.sdm-bar-legendary{background:var(--legendary-c);}
.sdm-bar-icon{background:var(--icon-c);}

.sdm-close{
  position:absolute;top:10px;right:10px;z-index:2;
  background:rgba(255,255,255,0.08);border:none;
  width:28px;height:28px;border-radius:50%;
  color:var(--muted);font-size:13px;cursor:pointer;
  transition:all .15s;
}
.sdm-close:hover{background:rgba(255,255,255,0.15);color:var(--text);}

/* Imagen de jugador */
.sdm-player-wrap,.sdm-team-wrap,.sdm-flag-wrap{
  width:100%;
  /* Proporción 3:4 de la lámina para no cortar */
  aspect-ratio:3/4;
  max-height:340px;
  overflow:hidden;
  background:var(--surface2);
  position:relative;
}
.sdm-player-wrap img,.sdm-team-wrap img{
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
}
.sdm-flag-wrap{
  display:flex;align-items:center;justify-content:center;
  padding:32px;aspect-ratio:4/3;max-height:240px;
}
.sdm-flag-wrap img{
  max-width:100%;max-height:100%;
  object-fit:contain;border-radius:8px;
  box-shadow:0 4px 24px rgba(0,0,0,0.5);
}
.sdm-emoji-wrap{
  width:100%;aspect-ratio:3/4;max-height:280px;
  display:flex;align-items:center;justify-content:center;
  font-size:100px;background:var(--surface2);
}
.sdm-emoji-wrap.sdm-locked{
  filter:grayscale(1);opacity:0.25;
}

.sdm-body{padding:16px 20px 20px;}

.sdm-id-row{
  display:flex;align-items:center;gap:8px;margin-bottom:8px;
}
.sdm-id{font-family:var(--fm);font-size:10px;color:var(--muted);letter-spacing:1px;}
.sdm-rarity-badge{
  font-size:8px;font-family:var(--fm);letter-spacing:1px;
  padding:2px 7px;border-radius:4px;border:1px solid;
}
.sdm-locked-badge{
  font-size:10px;font-family:var(--fm);color:var(--muted);
  background:rgba(255,255,255,0.04);padding:2px 8px;border-radius:4px;
  margin-left:auto;
}

.sdm-name{
  font-family:var(--fd);font-size:28px;letter-spacing:1px;
  line-height:1.1;margin-bottom:2px;
}
.sdm-country{
  font-size:11px;color:var(--muted);font-family:var(--fs);margin-bottom:14px;
}

.sdm-info-grid{
  display:flex;flex-direction:column;gap:6px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:10px;padding:12px 14px;margin-bottom:14px;
}
.sdm-info-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;
}
.sdm-info-row span{color:var(--muted);font-family:var(--fs);}
.sdm-info-row strong{color:var(--text);font-family:var(--fb);font-weight:700;}

.sdm-actions{display:flex;gap:8px;}
.sdm-btn{
  flex:1;padding:11px;border-radius:10px;font-family:var(--fb);
  font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;
  border:none;letter-spacing:.3px;
}
.sdm-btn-add{background:var(--green);color:#000;}
.sdm-btn-add:hover{background:#00c060;}
.sdm-btn-remove{background:rgba(227,30,36,0.12);color:var(--red);border:1px solid rgba(227,30,36,0.25);}
.sdm-btn-remove:hover{background:rgba(227,30,36,0.2);}

/* Light mode */
:root.light .sdm-card{background:var(--surface);}
:root.light .sdm-player-wrap,.sdm-team-wrap,.sdm-flag-wrap{background:var(--surface2);}

/* ══════════════════════════════════════
   TRIVIA RANKING
══════════════════════════════════════ */
.trivia-rank-btn{
  margin-top:12px;padding:10px 28px;border-radius:8px;
  background:transparent;border:1px solid var(--border2);
  color:var(--muted);font-family:var(--fb);font-size:14px;
  font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.3px;
}
.trivia-rank-btn:hover{border-color:var(--gold);color:var(--gold);}

.trk-my-row{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(239,159,39,0.08);border:1px solid rgba(239,159,39,0.2);
  border-radius:10px;padding:12px 16px;margin-bottom:16px;
}
.trk-my-label{font-family:var(--fb);font-size:14px;color:var(--muted);}
.trk-my-label strong{color:var(--gold);}
.trk-my-score{font-family:var(--fd);font-size:24px;color:var(--gold);letter-spacing:1px;}

.trk-table{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
}
.trk-header{
  display:grid;grid-template-columns:40px 1fr 80px 70px;
  padding:8px 16px;font-size:9px;font-family:var(--fm);
  letter-spacing:2px;color:var(--muted);
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,0.02);
}
.trk-row{
  display:grid;grid-template-columns:40px 1fr 80px 70px;
  padding:10px 16px;align-items:center;
  border-bottom:1px solid rgba(255,255,255,0.03);
  transition:background .1s;
}
.trk-row:last-child{border:none;}
.trk-row:hover{background:rgba(255,255,255,0.02);}
.trk-row-me{background:rgba(239,159,39,0.06) !important;border-left:2px solid var(--gold);}
.trk-pos{font-family:var(--fd);font-size:16px;text-align:center;}
.trk-name{font-size:13px;font-family:var(--fb);font-weight:600;color:var(--text);}
.trk-score{font-family:var(--fd);font-size:18px;text-align:right;}
.trk-pct{font-size:12px;font-family:var(--fm);text-align:right;}

/* Reglas Firestore para triviaRanking (recordatorio en comentario) */
/* match /triviaRanking/{userId} {
     allow read: if request.auth != null;
     allow write: if request.auth != null && request.auth.uid == userId;
   } */

/* ══════════════════════════════════════
   LEAFLET MAP OVERRIDES
══════════════════════════════════════ */
.wm-map-container{
  border-radius:12px;overflow:hidden;
  border:1px solid var(--border);
  height:480px;position:relative;
  margin-bottom:4px;
}
#wm-leaflet-map{width:100%;height:100%;}

/* Popup estilo FIFA */
.wm-popup .leaflet-popup-content-wrapper{
  border-radius:12px !important;
  box-shadow:0 8px 32px rgba(0,0,0,0.35) !important;
  padding:0 !important;
  overflow:hidden;
}
.wm-popup .leaflet-popup-content{margin:12px !important;}
.wm-popup .leaflet-popup-tip-container{display:none !important;}

:root.light .wm-map-container{border-color:var(--border2);}

/* ══════════════════════════════════════
   SIDEBAR LIMPIO — solo grupos y países
══════════════════════════════════════ */

/* Ocultar todos los sb-item del menú superior — solo quedan los de países */
#nav-home,#nav-pack,#nav-game,#nav-exchange,#nav-lineup,
#nav-trivia,#nav-predictor,#nav-compare,#nav-worldmap,
#nav-ranking,#nav-limited,#nav-favorite,#nav-chatbot,
#nav-stadiums,#nav-bracket,#nav-standings {
  display: none !important;
}

/* Ocultar secciones del sidebar que no sean Grupos/Países */
.sb-scroll > .sb-section:not([data-keep]) {
  /* Solo se ocultan las secciones sin data-keep via JS */
}

/* El sidebar ahora va directo a grupos y países */
.sb-brand { padding-bottom: 10px; }

/* ══════════════════════════════════════
   HOME — categorías y grid mejorado
══════════════════════════════════════ */
.home-section-label {
  font-family: var(--fd);
  font-size: 15px;
  letter-spacing: 2px;
  color: var(--text);
  margin: 24px 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
}

.home-grid-4 {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.home-grid-3 {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

/* Cards con hover más pronunciado */
.home-card {
  position: relative;
  transition: all 0.18s;
}
.home-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 12px;
  opacity: 0;
  transition: opacity 0.18s;
  background: linear-gradient(135deg,
    rgba(239,159,39,0.04),
    rgba(0,79,159,0.04));
}
.home-card:hover::after { opacity: 1; }
.home-card:hover {
  transform: translateY(-3px);
  border-color: var(--border3);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

/* ══════════════════════════════════════
   BACK BUTTON — breadcrumb
══════════════════════════════════════ */
.back-crumb-btn {
  background: none;
  border: none;
  color: var(--muted);
  font-family: var(--fm);
  font-size: 11px;
  cursor: pointer;
  padding: 2px 0;
  transition: color .15s;
  letter-spacing: .5px;
}
.back-crumb-btn:hover { color: var(--gold); }

/* Back button flotante en páginas internas */
.page-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 14px;
  font-family: var(--fb);
  font-size: 13px;
  color: var(--muted);
  cursor: pointer;
  transition: all .15s;
  margin-bottom: 20px;
}
.page-back-btn:hover {
  border-color: var(--border2);
  color: var(--text);
}

/* ══════════════════════════════════════
   COMPARADOR — jugadores locked/owned
══════════════════════════════════════ */
.cmp-btn-locked {
  opacity: 0.5;
}
.cmp-btn-locked:hover {
  border-color: var(--border) !important;
  background: transparent !important;
  transform: none !important;
}
.cmp-player-btn {
  position: relative;
  transition: all .12s;
}
.cmp-player-btn:not(.not-owned):not(.cmp-btn-locked):hover {
  border-color: var(--gold);
  background: var(--gold-dim);
  transform: translateY(-1px);
}

/* Light mode para back btn */
:root.light .back-crumb-btn { color: rgba(13,17,23,0.5); }
:root.light .back-crumb-btn:hover { color: var(--gold); }
:root.light .page-back-btn {
  background: var(--surface);
  border-color: var(--border2);
}

/* ══════════════════════════════════════
   LÁMINAS — mejoras visuales v5
══════════════════════════════════════ */

/* Grid más espacioso */
.stickers-grid {
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
  gap: 14px !important;
}

/* Slot base — border redondeado y sombra suave */
.sticker-slot {
  border-radius: 14px !important;
}
.sticker-slot:hover {
  transform: translateY(-5px) scale(1.02) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.3) !important;
}

/* Lámina con foto — barra superior de rareza más visible */
.sticker-slot.legendary.collected {
  box-shadow: 0 0 24px rgba(239,159,39,0.35) !important;
}
.sticker-slot.icon.collected {
  box-shadow: 0 0 24px rgba(229,53,171,0.35) !important;
}
.sticker-slot.rare.collected {
  box-shadow: 0 0 16px rgba(91,164,245,0.25) !important;
}

/* slot-img: ocupa todo el espacio disponible encima del info */
.slot-img {
  flex: 1;
  overflow: hidden;
  position: relative;
}
.slot-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}

/* Estado bloqueado — fondo con textura */
.slot-img-locked {
  flex: 1;
  background: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,0.02) 0px,
    rgba(255,255,255,0.02) 2px,
    transparent 2px,
    transparent 8px
  );
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Info zona */
.slot-info {
  padding: 8px 10px 9px !important;
}
.slot-name {
  font-size: 11px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Número de lámina */
.slot-number {
  font-size: 9px !important;
  opacity: 0.6;
}

/* ── MODAL SDM — rediseño para no cortar imagen ── */
.sdm-overlay {
  align-items: center !important;
  overflow-y: auto !important;
  padding: 16px !important;
}

.sdm-card {
  max-width: 420px !important;
  max-height: 92vh !important;
  overflow-y: auto !important;
  border-radius: 20px !important;
}

/* Imagen del jugador en modal: aspect-ratio 3/4, completa */
.sdm-player-wrap {
  width: 100% !important;
  aspect-ratio: 3/4 !important;
  height: auto !important;
  max-height: 400px !important;
}
.sdm-player-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top center !important;
}

/* Plantel: landscape, más bajo */
.sdm-team-wrap {
  width: 100% !important;
  aspect-ratio: 16/9 !important;
  height: auto !important;
  max-height: 220px !important;
}
.sdm-team-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
}

/* Bandera */
.sdm-flag-wrap {
  width: 100% !important;
  aspect-ratio: 5/3 !important;
  height: auto !important;
  max-height: 200px !important;
  padding: 28px !important;
}
.sdm-flag-wrap img {
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  border-radius: 6px !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.5) !important;
}

/* Locked en modal */
.sdm-emoji-wrap {
  aspect-ratio: 3/4 !important;
  height: auto !important;
  max-height: 320px !important;
  min-height: 160px !important;
  font-size: 80px !important;
}
.sdm-emoji-wrap.sdm-locked {
  font-size: 60px !important;
  background: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,0.02) 0px,
    rgba(255,255,255,0.02) 2px,
    transparent 2px,
    transparent 10px
  ) !important;
  opacity: 1 !important;
  filter: none !important;
}

/* Nombre más grande en el modal */
.sdm-name {
  font-size: 26px !important;
}

/* Light mode SDM */
:root.light .sdm-card { background: var(--surface) !important; }
:root.light .sdm-player-wrap,
:root.light .sdm-team-wrap,
:root.light .sdm-flag-wrap,
:root.light .sdm-emoji-wrap { background: var(--surface2) !important; }
