/* ===================================================================
   EL ORÁCULO · estilos v2 — deportivo + mobile-first
   Vibra: transmisión de TV + cancha nocturna. Verde césped, lima neón,
   cian eléctrico, magenta gol, oro podio. Nav inferior tipo app.
   =================================================================== */
:root{
  --bg:#0a0e14;
  --bg2:#0f141d;
  --card:#141b26;
  --card2:#1a2230;
  --line:#28323f;
  --ink:#e9eef4;
  --muted:#8694a3;
  --lima:#33c87b;       /* verde césped (acción principal) */
  --lima-deep:#22a866;
  --cian:#5aa9e6;       /* azul acero (enlaces/acentos) */
  --magenta:#ef4458;    /* rojo (alerta / gol) */
  --oro:#f3c64a;        /* oro (1.º) */
  --radius:14px;
  --shadow:0 10px 28px rgba(0,0,0,.42);
  --maxw:600px;
  --nav-h:64px;
}
/* ===== TEMAS (7 estilos) — solo cambian la paleta ===== */
:root[data-theme="oceano"]{--bg:#07121a;--bg2:#0c1a26;--card:#112430;--card2:#16303f;--line:#23414f;--lima:#2bd4c0;--lima-deep:#16a394;--cian:#5ad0e6}
:root[data-theme="brasa"]{--bg:#140f0a;--bg2:#1b150d;--card:#231b12;--card2:#2d2318;--line:#3d3122;--lima:#f5a52e;--lima-deep:#d07d12;--cian:#f0c07a}
:root[data-theme="tinto"]{--bg:#150913;--bg2:#1c0f1a;--card:#241524;--card2:#2e1b2d;--line:#3f2840;--lima:#ff6b9d;--lima-deep:#d94d7e;--cian:#e6a3c2}
:root[data-theme="violeta"]{--bg:#0d0a18;--bg2:#120f22;--card:#191430;--card2:#211b40;--line:#322a57;--lima:#b39cff;--lima-deep:#8f72f0;--cian:#9db4ff}
:root[data-theme="oro"]{--bg:#0b0b0c;--bg2:#111113;--card:#17171b;--card2:#1f1f24;--line:#2e2e35;--lima:#f3c64a;--lima-deep:#d4a72a;--cian:#cbb46a}
:root[data-theme="claro"]{--bg:#eef1f4;--bg2:#e3e8ee;--card:#ffffff;--card2:#f3f6f9;--line:#d3dae2;--ink:#16202b;--muted:#5d6b78;--lima:#1f9d57;--lima-deep:#15814a;--cian:#2f74c0;--shadow:0 10px 28px rgba(20,30,45,.12)}
/* tema claro: contraste de texto dorado / blanco sobre superficies claras */
:root[data-theme="claro"] .daily-h,
:root[data-theme="claro"] .win-line.exact,
:root[data-theme="claro"] .fin-winner b{color:#9a7400}
:root[data-theme="claro"] .danger-ghost:hover{color:var(--magenta)}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html,body{height:100%}
body{
  font-family:"Outfit",system-ui,sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.45;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.012) 0 56px, transparent 56px 112px),
    radial-gradient(1100px 560px at 50% -12%, rgba(51,200,123,.10), transparent 62%),
    radial-gradient(800px 480px at 100% 110%, rgba(90,169,230,.06), transparent 55%),
    var(--bg);
  background-attachment:fixed;
}
.screen{min-height:100dvh}
[hidden]{display:none !important}
a{color:var(--cian)}

.brand,h1,h2,.score-big,.rank-num,.result-box,.group-title,.br-col-title,.scoreboard{
  font-family:"Anton",sans-serif;font-weight:400;letter-spacing:.5px}

/* ---------- LOGIN ---------- */
.login{display:grid;place-items:center;padding:24px;
  background:radial-gradient(700px 380px at 50% 0%, rgba(51,200,123,.10), transparent 60%), var(--bg)}
.login-card{width:100%;max-width:390px;text-align:center;
  background:linear-gradient(180deg,var(--card),var(--bg2));
  border:1px solid var(--line);border-radius:26px;padding:38px 26px 28px;box-shadow:var(--shadow);
  position:relative;overflow:hidden}
.login-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--lima)}
.login-card.wide{max-width:420px}
.logo-mark{font-size:54px;line-height:1}
.brand{font-size:46px;line-height:.92;margin:8px 0 4px;color:var(--ink);letter-spacing:1px}
.brand.sm{font-size:30px;margin-bottom:6px}
.tagline{font-weight:800;font-size:20px;margin:6px 0 2px}
.sub{color:var(--muted);font-size:13px;margin-bottom:22px}
.field{display:block;text-align:left;margin:0 0 14px}
.field>span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px}
.field input{width:100%;padding:14px;border-radius:13px;background:var(--bg2);border:1px solid var(--line);
  color:var(--ink);font:inherit;font-size:16px;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus{border-color:var(--lima);box-shadow:0 0 0 3px rgba(51,200,123,.16)}
.fineprint{color:var(--muted);font-size:12px;margin-top:14px;font-style:italic}
.gbtn-wrap{display:flex;justify-content:center;min-height:44px;margin-top:6px}
.install-btn{margin:14px auto 0;display:inline-flex;width:auto;padding:9px 16px}
/* banderas como imagen (idénticas en todo dispositivo) */
.flag-img{height:1em;width:auto;vertical-align:-0.14em;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,.35);background:var(--card2)}
/* en las tarjetas de partido: banderas en recuadro uniforme (mismo tamaño) */
.team .flag-img{width:46px;height:31px;object-fit:cover;border-radius:5px;vertical-align:baseline}
.flag{filter:none !important}
.code-hi{font-size:15px;margin:4px 0 16px;line-height:1.5}
.code-hi b{color:var(--lima)}
#code-box{animation:fade .2s ease}
.avatar{width:24px;height:24px;border-radius:50%;vertical-align:middle;margin-right:7px;object-fit:cover;border:1px solid var(--line)}

/* ---------- LANDING (login + guía) ---------- */
.landing{min-height:100dvh;padding-bottom:40px;
  background:radial-gradient(900px 460px at 50% -8%, rgba(51,200,123,.10), transparent 60%), var(--bg)}
.lhero{text-align:center;padding:calc(46px + env(safe-area-inset-top)) 22px 26px;max-width:440px;margin:0 auto}
.lhero .logo-mark{font-size:58px}
.lhero .brand{font-size:46px;letter-spacing:1px}
.lhero .sub{max-width:380px;margin:6px auto 20px}
.lhero .gbtn-wrap{margin-top:4px}
.scroll-hint{color:var(--muted);font-size:12px;margin-top:22px;letter-spacing:.5px;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(4px)}}
.lwrap{max-width:560px;margin:0 auto;padding:0 16px}
.lsec{padding:18px 0}
.lsec h2{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--cian);text-align:center;margin-bottom:16px}
.steps{display:flex;flex-direction:column;gap:10px}
.step{display:flex;gap:13px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px}
.step .num{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:rgba(51,200,123,.14);color:var(--lima);
  font-family:"Anton";font-size:17px;display:flex;align-items:center;justify-content:center}
.step h3{font-size:15px;margin-bottom:2px}
.step p{color:var(--muted);font-size:13.5px;line-height:1.5}
.pts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.pt{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;text-align:center;min-width:120px}
.pt b{font-family:"Anton";font-size:30px;color:var(--lima);display:block}
.pt.gold b{color:var(--oro)}
.pt span{font-size:12px;color:var(--muted)}
.lgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.lgrid{grid-template-columns:1fr}}
.feat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px}
.feat .ic{font-size:22px;margin-bottom:6px}
.feat h3{font-size:14px;margin-bottom:3px}
.feat p{color:var(--muted);font-size:13px}
.lnote{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:16px;text-align:center;color:var(--muted);font-size:14px}
.lnote b{color:var(--ink)}
.lcta{text-align:center;padding:24px 0 8px;border-top:1px solid var(--line);margin-top:10px}
.lcta-h{font-family:"Anton";font-size:20px;letter-spacing:.5px;margin-bottom:14px}
.lcta .gbtn-wrap{justify-content:center}

/* ---------- BOTONES ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:15px 18px;min-height:50px;border:none;border-radius:14px;cursor:pointer;
  font:inherit;font-weight:800;font-size:16px;color:#06150a;
  background:linear-gradient(180deg,var(--lima),var(--lima-deep));
  box-shadow:0 8px 20px rgba(51,200,123,.28);transition:transform .08s,filter .15s;
  -webkit-tap-highlight-color:transparent}
.btn:active{transform:translateY(1px) scale(.99)}
.btn:hover{filter:brightness(1.06)}
.btn-big{font-size:18px;padding:17px}
.btn-mag{background:linear-gradient(180deg,var(--magenta),#cc2560);color:#fff;box-shadow:0 8px 20px rgba(239,68,88,.28)}
.btn-line{background:none;border:1.5px solid var(--cian);color:var(--cian);box-shadow:none}
.btn-ghost{background:none;border:1px solid var(--line);color:var(--muted);padding:8px 13px;
  border-radius:10px;cursor:pointer;font:inherit;font-size:13px;min-height:38px}
.btn-ghost:hover{color:var(--ink);border-color:var(--muted)}
.danger-ghost{color:var(--magenta);border-color:rgba(239,68,88,.35)}
.danger-ghost:hover{color:#fff;background:rgba(239,68,88,.12);border-color:var(--magenta)}
.error{color:var(--magenta);font-size:13px;margin-top:10px;font-weight:600}

/* ---------- APP SHELL ---------- */
.app{max-width:var(--maxw);margin:0 auto;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 48px)}

/* ---------- BANDA DE PUBLICIDAD (marquesina) ---------- */
.ad-ticker{position:fixed;left:0;right:0;bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));z-index:25;
  display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;
  background:var(--bg2);border-top:1px solid var(--line);backdrop-filter:blur(8px)}
.ad-tag{flex:0 0 auto;font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);
  border:1px solid var(--line);border-radius:5px;padding:2px 7px;background:var(--bg2)}
.ad-viewport{flex:1;min-width:0;overflow:hidden;height:100%;display:flex;align-items:center}
.ad-track{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform;
  animation:marquee 87s linear infinite}
.ad-viewport:hover .ad-track,.ad-viewport:active .ad-track{animation-play-state:paused}
.ad-item{font-size:12px;font-weight:600;color:var(--ink);text-decoration:none;padding:0 2px}
a.ad-item{color:var(--cian)}
a.ad-item:hover{text-decoration:underline}
.ad-dot{color:var(--lima);font-size:8px;margin:0 14px;opacity:.7}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(min-width:560px){
  .ad-ticker{bottom:0}
}
.topbar{position:sticky;top:0;z-index:45;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;
  padding:calc(12px + env(safe-area-inset-top)) 14px 12px;
  background:var(--bg);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.topbar .group-wrap{justify-self:start;min-width:0;max-width:100%}
.topbar-brand{justify-self:center;font-family:"Anton";font-size:18px;letter-spacing:1px;color:var(--ink);
  background:none;border:none;cursor:pointer;white-space:nowrap;padding:0}
.topbar-right{justify-self:end;display:flex;align-items:center;gap:10px;min-width:0}
.chip{background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;
  font-weight:700;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center}

/* NAV: barra inferior en móvil, pastillas arriba en desktop */
.tabs{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;
  padding:6px 8px calc(6px + env(safe-area-inset-bottom));gap:4px;
  background:var(--bg);
  backdrop-filter:blur(14px);border-top:1px solid var(--line)}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  min-height:52px;padding:6px 2px;border:none;background:none;color:var(--muted);
  border-radius:13px;cursor:pointer;font:inherit;font-weight:700;font-size:11px;
  transition:color .15s,background .15s;-webkit-tap-highlight-color:transparent}
.tab .ti{font-size:21px;line-height:1;filter:grayscale(.4) opacity(.8);transition:.15s}
.tab.active{color:var(--lima);background:rgba(51,200,123,.10)}
.tab.active .ti{filter:none;transform:translateY(-1px)}

.tabpane{display:none;padding:16px 12px 8px}
.tabpane.active{display:block;animation:fade .22s ease}
@keyframes fade{from{opacity:0;transform:translateY(5px)}}
.muted{color:var(--muted);font-size:13px}

/* ---------- MATCH CARDS ---------- */
.matches{display:flex;flex-direction:column;gap:12px}
.day-sep{font-family:"Anton";font-size:13px;letter-spacing:1.2px;color:var(--cian);text-transform:uppercase;
  margin:12px 2px 2px;display:flex;align-items:center;gap:10px}
.day-sep::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--cian);transform:rotate(45deg)}
.day-sep::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}
.day-sep.today{color:var(--lima);scroll-margin-top:72px}
.day-sep.today::before{background:var(--lima)}
.today-badge{font-family:"Outfit";font-size:10px;font-weight:800;letter-spacing:.5px;color:#06150a;
  background:var(--lima);border-radius:999px;padding:2px 9px;margin-left:2px;text-transform:none}
.match.is-today{border-color:rgba(51,200,123,.55);box-shadow:0 0 0 1px rgba(51,200,123,.25)}

/* sección HOY destacada */
.hoy-section{background:linear-gradient(180deg, rgba(51,200,123,.10), rgba(51,200,123,.02));
  border:1px solid rgba(51,200,123,.40);border-radius:16px;padding:12px;margin-bottom:18px}
.hoy-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.hoy-title{font-family:"Anton";font-size:18px;letter-spacing:1.5px;color:#06150a;
  background:var(--lima);padding:4px 14px;border-radius:8px}
.hoy-date{font-size:16px;font-weight:600;color:var(--ink);text-transform:capitalize}
.hoy-empty{color:var(--muted);font-size:14px;text-align:center;padding:8px 4px}
.hoy-section .match{margin-bottom:10px}
.hoy-section .match:last-child{margin-bottom:0}

.match{position:relative;background:linear-gradient(180deg,var(--card),var(--card2));
  border:1px solid var(--line);border-radius:var(--radius);padding:14px 14px 12px;cursor:pointer;
  transition:border-color .15s,transform .08s;overflow:hidden}
.match::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(180deg, var(--hc, var(--lima)), var(--ac, var(--lima-deep)))}
.match:active{transform:scale(.994)}
.match:hover{border-color:var(--lima)}
.match-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.match-meta{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.status{font-size:10px;font-weight:800;padding:4px 10px;border-radius:999px;letter-spacing:.4px;text-transform:uppercase}
.status.abierto{background:rgba(51,200,123,.15);color:var(--lima)}
.status.cerrado{background:rgba(239,68,88,.15);color:var(--magenta)}
.status.vivo{background:var(--magenta);color:#fff;animation:pulse 1.3s infinite}
.status.final{background:rgba(243,198,74,.16);color:var(--oro)}
@keyframes pulse{50%{opacity:.5}}

.teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.team{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.flag{font-size:34px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
.team-name{font-weight:800;font-size:15px}
.vs{font-family:"Anton";color:var(--muted);font-size:13px;background:var(--bg2);border:1px solid var(--line);
  border-radius:8px;padding:6px 10px}
.result-box{font-size:30px;text-align:center;color:var(--oro);background:#0a0f09;border:1px solid var(--line);
  border-radius:10px;padding:4px 12px;letter-spacing:2px;box-shadow:inset 0 0 12px rgba(0,0,0,.5)}
.result-box small{display:block;font-family:"Outfit";font-size:9px;color:var(--muted);font-weight:700;letter-spacing:1px}

.match-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:11px;
  border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.my-pick{font-weight:700;color:var(--ink)}
.my-pick b{color:var(--lima);font-family:"Anton";font-size:15px}
.foot-cta{color:var(--cian);font-weight:800}
.foot-cta.center{flex:1;text-align:center}
/* CTA llamativo y central para pronosticar un partido abierto */
.pick-cta{flex:1;text-align:center;background:var(--lima);color:#06150a;font-weight:800;
  padding:10px 12px;border-radius:11px;font-size:14px;letter-spacing:.3px;
  box-shadow:0 5px 16px rgba(51,200,123,.30)}
.match:hover .pick-cta,.match:active .pick-cta{filter:brightness(1.06)}
.pts{font-weight:800;border-radius:999px;padding:4px 10px;font-size:12px}
.pts.p3{background:var(--oro);color:#06150a}
.pts.p1{background:rgba(51,200,123,.2);color:var(--lima)}
.pts.p0{background:rgba(239,68,88,.15);color:var(--magenta)}

/* ---------- MODAL (evento) ---------- */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:end center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.66);backdrop-filter:blur(4px)}
.modal-card{position:relative;width:100%;max-width:var(--maxw);max-height:94dvh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;background:var(--bg2);border:1px solid var(--line);
  border-radius:24px 24px 0 0;padding:22px 16px calc(26px + env(safe-area-inset-bottom));
  box-shadow:0 -12px 44px rgba(0,0,0,.65);animation:slideup .26s cubic-bezier(.2,.8,.2,1)}
.modal-card::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:42px;height:4px;border-radius:99px;background:var(--line)}
@media(min-width:560px){.modal{place-items:center}.modal-card{border-radius:24px;max-height:88dvh}.modal-card::before{display:none}}
@keyframes slideup{from{transform:translateY(44px);opacity:.6}}
.modal-close{position:absolute;top:14px;right:14px;background:var(--card2);border:1px solid var(--line);
  color:var(--muted);width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;z-index:2}
.ev-accent{position:absolute;top:0;left:0;right:0;height:4px;border-radius:24px 24px 0 0}
.ev-meta{font-size:12px;color:var(--cian);text-transform:uppercase;letter-spacing:.6px;margin:6px 0 4px;font-weight:700}
.ev-teams{font-family:"Anton";font-size:24px;text-align:center;margin:8px 0}
.ev-venue{text-align:center;color:var(--muted);font-size:13px;margin-bottom:6px}
.ev-squads{text-align:center;font-size:13px;margin-bottom:8px}
.ev-squads a{font-weight:700;text-decoration:none;border-bottom:1px dotted var(--cian)}
.ev-section{margin:16px 0;padding-top:16px;border-top:1px solid var(--line)}
.ev-section h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:12px;font-weight:800}

/* scoreboard / stepper */
.pick-row{display:flex;align-items:center;justify-content:center;gap:12px;margin:6px 0 14px}
.pick-row .team-mini{flex:1;text-align:center;font-weight:800;font-size:14px}
.stepper{display:flex;flex-direction:column;align-items:center;gap:8px}
.stepper input{width:70px;height:74px;text-align:center;font-family:"Anton";font-size:38px;
  background:#0a0f09;border:2px solid var(--line);border-radius:14px;color:var(--lima);outline:none;
  box-shadow:inset 0 0 14px rgba(0,0,0,.55)}
.stepper input:focus{border-color:var(--lima)}
.step-btns{display:flex;gap:8px}
.step-btns button{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--card2);
  color:var(--ink);font-size:22px;cursor:pointer;line-height:1;-webkit-tap-highlight-color:transparent}
.step-btns button:active{background:var(--lima);color:#06150a}
.dash{font-family:"Anton";font-size:32px;color:var(--muted)}

.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-row .btn{flex:1;min-width:140px}
.locked-note{background:rgba(239,68,88,.1);border:1px solid rgba(239,68,88,.32);border-radius:13px;
  padding:13px;font-size:13px;color:var(--ink)}

/* pronósticos del grupo en un partido (nombre + marcador con banderas y VS) */
.gp-list{display:flex;flex-direction:column;gap:7px}
.gp-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;
  background:var(--card);border:1px solid var(--line);border-radius:10px;padding:8px 12px}
.gp-row.me{border-color:var(--lima)}
.gp-row.result-row{border-color:var(--oro);background:rgba(243,198,74,.12)}
.gp-row.result-row .gp-name{color:var(--oro);font-weight:800;text-transform:uppercase;letter-spacing:.5px;font-size:11px}
.gp-row.result-row .gp-score{color:var(--oro)}
.gp-name{font-weight:700;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gp-score{display:flex;align-items:center;gap:5px;font-family:"Anton";font-size:18px;white-space:nowrap}
.gp-score i{font-family:"Outfit";font-style:normal;font-size:9px;font-weight:800;color:var(--muted)}
.gp-score .flag-img{height:15px}

.picks-table{width:100%;border-collapse:collapse;font-size:14px}
.picks-table td{padding:9px 6px;border-bottom:1px solid var(--line)}
.picks-table td:last-child{text-align:right;font-family:"Anton";font-size:18px}
.picks-table .me td{color:var(--lima)}
.hidden-note{color:var(--muted);font-style:italic;font-size:13px;text-align:center;padding:10px}

.banter{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;max-height:210px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.banter-msg{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:9px 12px;font-size:14px}
.banter-msg b{color:var(--lima);font-size:13px}
.banter-msg .t{color:var(--muted);font-size:11px;float:right}
.banter-input{display:flex;gap:8px}
.banter-input input{flex:1;padding:13px;border-radius:12px;background:var(--card);border:1px solid var(--line);color:var(--ink);font:inherit;font-size:15px}
.banter-input button{padding:0 18px;border-radius:12px;border:none;background:var(--lima);color:#06150a;font-weight:800;cursor:pointer;min-height:46px}

/* ---------- RANKING ---------- */
.ranking-head{text-align:center;margin-bottom:16px}
.ranking-head h2{font-size:28px;color:var(--oro)}
.ranking{display:flex;flex-direction:column;gap:10px}
.rank-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
  background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:15px;padding:13px 15px}
.rank-row.top1{border-color:var(--oro);box-shadow:0 0 0 1px var(--oro) inset,0 8px 22px rgba(243,198,74,.14)}
.rank-row.top2{border-color:#c9d2cf88}
.rank-row.top3{border-color:#cd7f4d88}
.rank-row.last{border-color:rgba(239,68,88,.42)}
.rank-num{font-size:25px;color:var(--muted);min-width:32px;text-align:center}
.rank-row.top1 .rank-num{color:var(--oro)}
.rank-info .rank-name{font-weight:800;font-size:16px}
.rank-info .rank-title{font-size:12px;color:var(--muted);font-style:italic}
.rank-pts{font-family:"Anton";font-size:27px;color:var(--lima)}
.rank-pts small{font-family:"Outfit";font-size:11px;color:var(--muted);font-weight:600;display:block;text-align:right}
.empty{text-align:center;color:var(--muted);padding:44px 20px;font-style:italic}

/* ---------- CELEBRACIÓN ---------- */
.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:200;overflow:hidden}
.confetti-layer i{position:absolute;top:-14px;width:8px;height:13px;border-radius:2px;
  animation:confetti-fall cubic-bezier(.3,.6,.7,1) forwards}
@keyframes confetti-fall{0%{transform:translateY(0) rotate(0)}100%{transform:translateY(108vh) rotate(680deg);opacity:.85}}
.crown{margin-right:4px}

.win-line{font-size:14px;padding:8px 0;border-bottom:1px solid var(--line)}
.win-line:last-child{border-bottom:none}
.win-line.exact{color:var(--oro)}
.win-line b{color:var(--ink)}

/* ganadores del día */
.daily-card{background:linear-gradient(180deg,rgba(243,198,74,.08),var(--card2));border:1px solid rgba(243,198,74,.35);border-radius:14px;padding:14px}
.daily-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.daily-h{font-family:"Anton";font-size:16px;color:var(--oro);letter-spacing:.5px}
.daily-line{font-size:13px;color:var(--muted);margin-top:4px}
.daily-line b{color:var(--ink)}

/* podio */
.podium{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:end;gap:8px;margin:4px 0 6px}
.pod{display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px}
.pod-ava{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:"Anton";font-size:18px;background:var(--card2);border:1px solid var(--line);color:var(--ink)}
.pod-name{font-size:12px;font-weight:700;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pod-block{width:100%;border-radius:10px 10px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  gap:2px;padding:8px 4px;background:var(--card)}
.pod-medal{font-size:18px}
.pod-pts{font-family:"Anton";font-size:20px;color:var(--lima)}
.pod1 .pod-block{height:98px;background:linear-gradient(180deg,rgba(243,198,74,.18),var(--card));border:1px solid var(--oro)}
.pod1 .pod-ava{border-color:var(--oro);color:var(--oro)}
.pod2 .pod-block{height:80px;border:1px solid #c9d2cf66}
.pod3 .pod-block{height:66px;border:1px solid #cd7f4d66}

/* ---------- ESCALERILLA ---------- */
.esc-head{text-align:center;margin-bottom:14px}
.esc-head h2{font-size:28px;color:var(--lima)}
.esc-switch{display:inline-flex;margin-top:12px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.esc-btn{padding:11px 26px;background:var(--card);color:var(--muted);border:none;cursor:pointer;font:inherit;font-weight:800;font-size:13px;min-height:44px}
.esc-btn.active{background:var(--lima);color:#06150a}

#esc-grupos{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:480px){#esc-grupos{grid-template-columns:1fr 1fr}}
.group-box{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:15px;padding:13px;overflow:hidden}
.group-title{font-size:18px;color:var(--oro);margin-bottom:8px;letter-spacing:.5px}
.group-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:8px}
.group-table th{font-size:10px;text-transform:uppercase;color:var(--muted);font-weight:700;text-align:center;padding:2px}
.group-table th:nth-child(2){text-align:left}
.group-table td{padding:6px 2px;text-align:center;border-bottom:1px solid var(--line)}
.group-table td.tname{text-align:left;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.group-table td.tname a{color:var(--ink);text-decoration:none}
.group-table .jersey{opacity:.45;font-size:11px}
.group-table td.pos{color:var(--muted);font-family:"Anton"}
.group-table td.b{font-weight:800;color:var(--lima);font-family:"Anton";font-size:15px}
.group-table tr.qualifies td.pos{color:var(--lima)}
.group-table tr.qualifies{background:rgba(51,200,123,.05)}
.group-matches{display:flex;flex-direction:column;gap:3px}
.esc-match{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;font-size:12px;
  padding:7px 6px;border-radius:9px;cursor:pointer;transition:background .12s;min-height:34px}
.esc-match:active{background:var(--card2)}
.esc-match .e-h{text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.esc-match .e-a{text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.esc-match .sc{color:var(--oro);font-family:"Anton"}
.esc-match .ko{color:var(--muted);font-weight:600;font-size:11px}

.bracket{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 14px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.br-col{flex:0 0 auto;width:172px;scroll-snap-align:start}
.br-col-title{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--cian);text-align:center;margin-bottom:10px}
.br-match{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:10px}
.br-n{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;text-align:center}
.br-team{font-size:13px;font-weight:600;padding:3px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.br-slot{color:var(--muted);font-weight:500}
.br-real{color:var(--ink);font-weight:800}
.br-vs{font-size:10px;color:var(--muted);text-align:center;margin:1px 0}
.br-col:last-child .br-match{border-color:var(--oro);box-shadow:0 0 0 1px var(--oro) inset}

/* ---------- ADMIN ---------- */
.admin-gate{max-width:370px;margin:30px auto;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px}
.admin-gate h2{font-size:22px;margin-bottom:8px}
.admin-section{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:14px}
.admin-section h3{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--lima);margin-bottom:12px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-grid .full{grid-column:1/-1}
.form-grid label{font-size:12px;color:var(--muted)}
.form-grid input,.form-grid select{width:100%;padding:11px;border-radius:10px;background:var(--bg2);border:1px solid var(--line);color:var(--ink);font:inherit;margin-top:3px;font-size:15px}
.stats-box{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}
.stat{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:10px 4px}
.stat b{display:block;font-family:"Anton";font-size:22px;color:var(--lima);line-height:1.1}
.stat span{font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted)}
@media(max-width:420px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat-groups{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.stat-groups span{background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:4px 10px;font-size:12px;color:var(--ink)}
.admin-match{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.admin-match-info b{display:block}
.admin-match-info span{font-size:12px;color:var(--muted)}
.admin-actions{display:flex;gap:6px;align-items:center}
.res-input{width:44px;padding:8px;text-align:center;border-radius:8px;background:var(--bg2);border:1px solid var(--line);color:var(--ink);font:inherit}
.ko-edit{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end;flex:1}
.ko-edit input{padding:7px 9px;border-radius:8px;background:var(--bg2);border:1px solid var(--line);color:var(--ink);font:inherit;font-size:13px}
.ko-edit input[type="text"]{width:108px}
.ko-edit input[type="datetime-local"]{width:170px}
.mini-btn{padding:8px 11px;border-radius:9px;border:1px solid var(--line);background:var(--card2);color:var(--ink);cursor:pointer;font:inherit;font-size:12px;font-weight:700;min-height:38px}
.mini-btn.danger{color:var(--magenta);border-color:rgba(239,68,88,.32)}

/* ---------- TOAST ---------- */
.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 20px + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:100;
  background:var(--card2);border:1px solid var(--lima);color:var(--ink);padding:13px 18px;border-radius:13px;
  font-weight:700;font-size:14px;box-shadow:var(--shadow);max-width:90vw;text-align:center;animation:toastin .25s ease}
.toast.err{border-color:var(--magenta)}
@keyframes toastin{from{transform:translate(-50%,12px);opacity:0}}

/* ---------- GATE (pantalla de grupos) ---------- */
.gate-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;text-align:left}
.gate-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:2px}
.gate-item{display:flex;justify-content:space-between;align-items:center;width:100%;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 15px;cursor:pointer;
  font:inherit;font-weight:700;font-size:15px;color:var(--ink);min-height:48px}
.gate-item:hover{border-color:var(--lima)}
.gate-item small{color:var(--muted);font-weight:600}
.gate-form{text-align:left;margin-top:8px;padding-top:14px;border-top:1px solid var(--line)}
.gate-form .field{margin-bottom:8px}

/* ---------- CHIP DE GRUPO (topbar) ---------- */
.group-chip{display:flex;align-items:center;gap:7px;background:var(--card2);border:1px solid var(--line);
  border-radius:999px;padding:7px 13px;color:var(--ink);font:inherit;font-weight:800;font-size:14px;cursor:pointer;
  max-width:100%;-webkit-tap-highlight-color:transparent}
.group-chip:hover{border-color:var(--lima)}
.group-chip #group-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gc-dot{width:9px;height:9px;border-radius:50%;background:var(--lima);flex:0 0 auto;box-shadow:0 0 0 3px rgba(51,200,123,.18)}
.caret{color:var(--muted);font-size:11px;transition:transform .15s}
.group-chip.open .caret{transform:rotate(180deg)}
.group-wrap{position:relative}
.group-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:50;min-width:230px;max-width:78vw;
  background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:var(--shadow);
  animation:fade .15s ease}
.gm-head{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:8px 10px 4px}
.gm-item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;cursor:pointer;
  padding:11px 10px;border-radius:10px;color:var(--ink);font:inherit;font-weight:700;font-size:14px;text-align:left;
  -webkit-tap-highlight-color:transparent}
.gm-item:hover{background:var(--card)}
.gm-item.active{background:rgba(51,200,123,.10)}
.gm-item .gm-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gm-item small{color:var(--muted);font-weight:600}
.gm-item .gm-check{color:var(--lima);font-weight:800}
.gm-item:not(.active) .gc-dot{background:var(--muted);box-shadow:none}
.gm-manage{display:block;width:100%;margin-top:4px;padding:11px 10px;border:none;border-top:1px solid var(--line);
  background:none;color:var(--cian);font:inherit;font-weight:700;font-size:13px;text-align:left;cursor:pointer;border-radius:0 0 10px 10px}
.gm-manage:hover{background:var(--card)}

/* ---------- AVATAR + MENÚ DE USUARIO ---------- */
.user-wrap{position:relative}
.user-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;
  padding:0;border-radius:50%;cursor:pointer;-webkit-tap-highlight-color:transparent}
.user-btn.open .user-ava,.user-btn:hover .user-ava{border-color:var(--lima)}
.user-ava{position:relative;width:36px;height:36px;border-radius:50%;overflow:visible;display:flex;align-items:center;
  justify-content:center;background:var(--card);border:1px solid var(--line);font-weight:800;font-size:14px;color:var(--ink);flex:0 0 auto;transition:border-color .15s}
.user-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.user-ava.leader{border-color:var(--oro);box-shadow:0 0 0 1px var(--oro)}
.user-ava.leader::after{content:"👑";position:absolute;top:-10px;right:-7px;font-size:12px}
.user-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:50;min-width:250px;max-width:84vw;
  background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:var(--shadow);animation:fade .15s ease}
.um-head{display:flex;align-items:center;gap:10px;padding:8px 10px 10px;border-bottom:1px solid var(--line);margin-bottom:4px}
.um-ava{width:38px;height:38px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;
  background:var(--card);border:1px solid var(--line);font-weight:800;color:var(--ink);flex:0 0 auto}
.um-ava img{width:100%;height:100%;object-fit:cover}
.um-id{min-width:0}
.um-name{font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.um-mail{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.um-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;cursor:pointer;
  padding:11px 10px;border-radius:10px;color:var(--ink);font:inherit;font-weight:600;font-size:14px;text-align:left;text-decoration:none}
.um-item:hover{background:var(--card)}
.um-item.danger{color:var(--magenta)}
.um-ic{font-size:16px;width:20px;text-align:center;flex:0 0 auto}
.um-chev{margin-left:auto;color:var(--muted);font-size:11px}
.um-themes{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px 6px 8px}
.theme-sw{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:8px 10px;cursor:pointer;font:inherit;font-size:12px;font-weight:700;color:var(--ink)}
.theme-sw .sw-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;background:var(--sw-ac);
  box-shadow:inset 0 0 0 4px var(--sw-bg),0 0 0 1px rgba(255,255,255,.15)}
.theme-sw.active{border-color:var(--lima);box-shadow:0 0 0 1px var(--lima)}

/* ---------- PESTAÑA GRUPO ---------- */
.grp-card{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);
  border-radius:14px;padding:16px;margin-bottom:12px}
.grp-card h3{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:12px}
.grp-title{font-family:"Anton";font-size:24px;letter-spacing:.5px}
.invite-box{background:var(--bg2);border:1px dashed var(--line);border-radius:11px;padding:10px 14px}
.invite-box code{display:block;font-family:"Space Mono",ui-monospace,monospace;font-size:20px;color:var(--lima);letter-spacing:2px;margin-top:2px}
.members{display:flex;flex-wrap:wrap;gap:8px}
.member{background:var(--bg2);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;min-height:38px;-webkit-tap-highlight-color:transparent}
.member:hover{border-color:var(--lima)}
.member.owner{border-color:var(--lima)}
.member small{color:var(--lima);font-weight:700;margin-left:4px}
/* pronósticos de un miembro · tabla tipo marcador */
.member-picks{display:flex;flex-direction:column;gap:8px}
.mp-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;
  background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 12px}
.mp-team{display:flex;align-items:center;gap:7px;min-width:0;font-weight:700;font-size:13px}
.mp-team .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-team.th{justify-content:flex-end;text-align:right}
.mp-team.ta{justify-content:flex-start}
.mp-team .flag-img{height:18px}
.mp-vs{display:flex;align-items:center;gap:7px;font-family:"Anton";font-size:22px;color:var(--ink);white-space:nowrap}
.mp-vs i{font-family:"Outfit";font-style:normal;font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.5px}
.mp-final{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:6px;padding-top:6px;border-top:1px solid var(--line);
  font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.grp-switch{display:flex;flex-wrap:wrap;gap:8px}
.grp-pill{display:inline-flex;align-items:center;gap:7px;background:var(--bg2);border:1px solid var(--line);
  border-radius:999px;padding:9px 14px;cursor:pointer;font:inherit;font-size:13px;font-weight:700;color:var(--ink);min-height:40px}
.grp-pill small{color:var(--muted);font-weight:600}
.grp-pill.active{background:var(--lima);color:#06150a;border-color:var(--lima)}
.grp-pill.active small{color:rgba(0,0,0,.55)}
.admin-details{padding:0}
.admin-details summary{padding:16px;cursor:pointer;font-weight:800;font-size:14px;list-style:none;color:var(--ink)}
.admin-details summary::-webkit-details-marker{display:none}
.admin-details summary::after{content:"▾";float:right;color:var(--muted)}
.admin-details[open] summary::after{content:"▴"}
.admin-details > #admin-inner{padding:0 16px 16px}

/* ---------- DESKTOP: nav arriba como pastillas ---------- */
@media(min-width:560px){
  .app{padding-bottom:48px}
  .tabs{position:sticky;top:60px;bottom:auto;flex-direction:row;border-top:none;border-bottom:1px solid var(--line);
    padding:10px 12px;gap:6px;background:var(--bg)}
  .tab{flex-direction:row;gap:7px;border:1px solid var(--line);background:var(--card);border-radius:11px;font-size:13px;min-height:44px}
  .tab .ti{font-size:16px}
  .tab.active{background:var(--lima);color:#06150a}
  .tab.active .ti{filter:none}
  .toast{bottom:24px}
}

/* ===== nav inferior con 5 pestañas: etiquetas en una línea ===== */
.tab .tl{white-space:nowrap}
@media(max-width:559px){ .tab{font-size:10px;padding:6px 1px} .tab .ti{font-size:19px} }

/* ===== QUINIELA DE FINALISTAS ===== */
.fin-head h2{font-family:"Anton";font-size:24px;letter-spacing:.5px;color:var(--ink)}
.fin-sub{color:var(--muted);font-size:13.5px;margin-top:6px;line-height:1.5}
.fin-deadline{margin-top:12px;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--lima);
  border-radius:11px;padding:11px 13px;font-size:13px;line-height:1.5}
.fin-deadline.closed{border-left-color:var(--magenta)}
.fin-counter{margin:16px 0 9px;font-weight:800;color:var(--lima);font-size:18px;font-family:"Anton"}
.fin-counter-max{color:var(--muted);font-family:"Outfit";font-size:13px;font-weight:700;margin-left:4px}
.fin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:8px}
.fin-team{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:9px 11px;cursor:pointer;color:var(--ink);font-weight:600;font-size:13px;
  text-align:left;-webkit-tap-highlight-color:transparent;transition:border-color .12s,background .12s}
.fin-team span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fin-team .flag-img{width:24px;height:16px;object-fit:cover;border-radius:3px;flex:0 0 auto}
.fin-team.on{border-color:var(--lima);background:rgba(51,200,123,.14);box-shadow:inset 0 0 0 1px var(--lima)}
.fin-save{width:100%;margin-top:16px}
.fin-note{text-align:center;margin-top:8px;font-size:12px;color:var(--muted)}
.fin-mine{margin-top:16px}
.fin-mine h3,.fin-rank h3{font-size:16px;margin-bottom:6px;color:var(--ink)}
.fin-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:8px}
.fin-chip{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);
  border-radius:999px;padding:6px 11px;font-size:13px;font-weight:600}
.fin-chip .flag-img{width:22px;height:15px;object-fit:cover;border-radius:2px}
.fin-chip.hit{border-color:var(--lima);color:var(--lima)}
.fin-chip.miss{opacity:.55}
.fin-hit{color:var(--lima);font-weight:800}
.fin-miss{color:var(--magenta);font-weight:800}
.fin-rank{margin-top:22px}
/* lista ordenable (orden de resultado 1.º–8.º) */
.fin-order{margin-top:6px}
.fin-order-list{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.fin-slot{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:8px 10px}
.fin-pos{flex:0 0 auto;min-width:104px;font-size:12px;color:var(--muted);font-weight:700;line-height:1.2}
.fin-pos b{color:var(--lima);font-family:"Anton";font-size:16px;margin-right:4px}
.fin-slot-team{flex:1;min-width:0;display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.fin-slot-team .flag-img{width:24px;height:16px;object-fit:cover;border-radius:3px;flex:0 0 auto}
.fin-slot-btns{flex:0 0 auto;display:flex;gap:4px}
.fin-slot-btns button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);
  background:var(--card2);color:var(--ink);font-size:14px;font-weight:800;cursor:pointer;line-height:1;
  -webkit-tap-highlight-color:transparent}
.fin-slot-btns button:disabled{opacity:.3}
.fin-slot-btns .fin-x{color:var(--magenta)}
.fin-badge{flex:0 0 auto;font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px}
.fin-badge.hit{background:rgba(51,200,123,.18);color:var(--lima)}
.fin-badge.miss{background:rgba(239,68,88,.14);color:var(--magenta)}
.fin-actions{display:flex;flex-direction:column;gap:9px;margin-top:16px}
.fin-actions .btn{width:100%;margin:0}
/* confirmación visible tras guardar el pronóstico */
.fin-save.saved{background:#16a34a;color:#fff;box-shadow:0 0 0 3px rgba(34,163,74,.35);
  animation:finSaved .35s ease}
@keyframes finSaved{0%{transform:scale(.97)}55%{transform:scale(1.03)}100%{transform:scale(1)}}
#fin-clear{color:var(--magenta)}
.fin-winner{margin:0 0 10px;background:linear-gradient(180deg,rgba(243,198,74,.16),var(--card2));
  border:1px solid rgba(243,198,74,.45);border-radius:12px;padding:11px 13px;font-size:14px;color:var(--ink)}
.fin-winner b{color:var(--oro)}
