/* ============================================================
   Polla Mundial Prom 2027 — Tema "gala neón" (morado · dorado · blanco)
   Look juvenil/moderno: degradados, glass y glow.
   Fuentes: Anton (display), Barlow Condensed (títulos), Barlow (texto)
   ============================================================ */
:root{
  /* Paleta morado + dorado (se conservan los nombres var para compatibilidad) */
  --pitch-dark:#4c1d95;   /* morado profundo */
  --pitch:#7c3aed;        /* morado principal */
  --pitch-light:#a855f7;  /* violeta claro */
  --ink:#1b0838;          /* casi negro morado */
  --ink-soft:#2a0f52;
  --gold:#fbbf24;         /* dorado */
  --gold-deep:#f59e0b;    /* dorado profundo */
  --cream:#f6f2ff;        /* blanco con tinte violeta */
  --rojo:#ef4444;         /* rojo para "fallo" */

  /* Compatibilidad con estilos previos (mismos nombres, nuevos valores) */
  --azul:var(--ink);
  --azul-2:#120426;
  --oro:var(--gold);
  --verde:var(--pitch);
  --verde-claro:var(--pitch-light);
  --gris:#efe9fb;
  --texto:#2a1a44;
  --magenta:#d946ef;

  --font-body:'Barlow',system-ui,-apple-system,sans-serif;
  --font-head:'Barlow Condensed',system-ui,sans-serif;
  --font-display:'Anton','Barlow Condensed',sans-serif;
  --shadow:0 16px 40px rgba(76,29,149,.14);
}

*{box-sizing:border-box}
body{
  font-family:var(--font-body);
  background:
    radial-gradient(900px 500px at 110% -10%, rgba(168,85,247,.10), transparent 60%),
    radial-gradient(800px 480px at -10% 0%, rgba(251,191,36,.10), transparent 55%),
    linear-gradient(180deg,#f7f3ff,#efe7ff);
  background-attachment:fixed;
  color:var(--texto);
  margin:0;
}
a{color:var(--pitch)}
a:hover{color:var(--pitch-dark)}
h1,h2,h3,h4,h5,h6,.fw-bold{font-family:var(--font-head);font-weight:800;letter-spacing:.3px}
.display-5,.display-6{font-family:var(--font-display);font-weight:400;letter-spacing:1px}

/* ---------- Overrides de utilidades Bootstrap (quitar verde/azul) ---------- */
.bg-success{background-color:var(--pitch)!important}
.text-success{color:var(--pitch)!important}
.progress-bar.bg-success{background-color:var(--pitch)!important}
.progress-bar.bg-info{background-color:var(--pitch-light)!important}
.bg-info{background-color:var(--pitch-light)!important}
.badge.bg-success,.badge.text-bg-success{background-color:var(--pitch)!important}
.text-primary{color:var(--pitch)!important}
.text-warning{color:var(--gold-deep)!important}
.bg-warning,.badge.bg-warning,.badge.text-bg-warning{background-color:var(--gold)!important;color:#3a2400!important}
.alert-success{--bs-alert-bg:#f1e9ff;--bs-alert-border-color:#e2d2fd;--bs-alert-color:#4c1d95}
.alert-info{--bs-alert-bg:#efe7ff;--bs-alert-border-color:#ddc9ff;--bs-alert-color:#4c1d95}
.btn-outline-primary,.btn-outline-success{--bs-btn-color:var(--pitch);--bs-btn-border-color:var(--pitch);--bs-btn-hover-bg:var(--pitch);--bs-btn-hover-border-color:var(--pitch);--bs-btn-active-bg:var(--pitch-dark);--bs-btn-active-border-color:var(--pitch-dark)}
.btn-outline-warning{--bs-btn-color:var(--gold-deep);--bs-btn-border-color:var(--gold);--bs-btn-hover-bg:var(--gold);--bs-btn-hover-border-color:var(--gold);--bs-btn-hover-color:#3a2400;--bs-btn-active-bg:var(--gold-deep)}

/* ---------- NAVBAR ---------- */
.navbar-polla{
  background:linear-gradient(110deg,#2a0f52,#4c1d95 55%,#6d28d9);
  box-shadow:0 6px 22px rgba(27,8,56,.35);
  border-bottom:1px solid rgba(251,191,36,.55);
}
.navbar-polla .navbar-brand{font-family:var(--font-display);font-weight:400;letter-spacing:1px;color:#fff;font-size:1.35rem}
.navbar-polla .navbar-brand .ball{color:var(--gold);filter:drop-shadow(0 0 6px rgba(251,191,36,.7))}
.navbar-polla .nav-link{color:#ece3ff !important;font-weight:700;border-radius:11px;padding:.4rem .85rem !important;font-family:var(--font-head);letter-spacing:.5px;text-transform:uppercase;font-size:.95rem;transition:.18s}
.navbar-polla .nav-link:hover{color:#fff !important;background:rgba(255,255,255,.12)}
.navbar-polla .nav-link.active{color:var(--ink) !important;background:linear-gradient(135deg,var(--gold),#ffd76b);box-shadow:0 4px 14px rgba(251,191,36,.45)}
.navbar-polla .navbar-toggler{border-color:rgba(255,255,255,.3)}
.navbar-polla .dropdown-menu{border:none;border-radius:14px;box-shadow:0 18px 44px rgba(27,8,56,.22)}

/* ---------- AUTH ---------- */
.auth-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(60% 60% at 80% 0%, rgba(217,70,239,.45), transparent 60%),
    radial-gradient(55% 55% at 12% 12%, rgba(251,191,36,.30), transparent 60%),
    radial-gradient(70% 70% at 50% 110%, rgba(124,58,237,.55), transparent 60%),
    linear-gradient(160deg,#1b0838,#3b0d6b 55%,#2a0f52);
  padding:24px;position:relative;overflow:hidden;
}
.auth-card{
  width:100%;max-width:440px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.6);
  border-radius:24px;
  box-shadow:0 30px 70px rgba(11,2,30,.5);overflow:hidden;backdrop-filter:blur(6px);
}
.auth-card.lg{max-width:920px}
.auth-head{
  background:linear-gradient(120deg,var(--pitch-dark),var(--pitch) 60%,var(--magenta));
  color:#fff;padding:28px;text-align:center;border-bottom:1px solid rgba(251,191,36,.5);
}
.auth-head h1{font-family:var(--font-display);font-weight:400;font-size:1.7rem;margin:0;letter-spacing:1px}
.auth-head .ball{color:var(--gold)}
.auth-head p{margin:.4rem 0 0;opacity:.95;font-size:.9rem;font-family:var(--font-body)}
.auth-body{padding:28px}

/* Login ancho con info */
.login-info{
  background:linear-gradient(160deg,#3b0d6b,#1b0838 80%);
  color:var(--cream);padding:36px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;
}
.login-info::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(217,70,239,.5),transparent 70%);top:-80px;right:-60px;filter:blur(10px)}
.login-info>*{position:relative;z-index:1}
.login-info .ball{color:var(--gold)}
.login-info h1{font-family:var(--font-display);font-weight:400;letter-spacing:1px}
.login-info .precio{font-family:var(--font-display);font-size:3rem;line-height:1;
  background:linear-gradient(90deg,var(--gold),#ffe39a);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-info .precio-box{border-left:3px solid var(--gold);padding-left:14px}
.login-info ul{list-style:none;padding:0;margin:0}
.login-info li{padding:6px 0;display:flex;gap:10px;align-items:flex-start;font-size:.92rem}
.login-form{padding:36px;display:flex;flex-direction:column;justify-content:center}
.login-form .form-control:focus{border-color:var(--pitch-light);box-shadow:0 0 0 .25rem rgba(124,58,237,.2)}
@media (max-width:767px){ .login-info{padding:24px} .login-form{padding:24px} .login-info .precio{font-size:2.3rem} }

/* ---------- CARDS / STATS ---------- */
.card-polla{border:1px solid rgba(124,58,237,.10);border-radius:20px;box-shadow:var(--shadow);background:#fff;transition:transform .15s ease, box-shadow .15s ease}
.card-polla:hover{transform:translateY(-2px);box-shadow:0 22px 50px rgba(76,29,149,.18)}
.card-polla .card-body h5,.card-polla .card-body h6{font-family:var(--font-head)}
.btn{font-family:var(--font-head);font-weight:700;letter-spacing:.4px;border-radius:12px}
.btn-success{background:linear-gradient(135deg,var(--pitch),var(--magenta));border:none;box-shadow:0 8px 20px rgba(124,58,237,.32)}
.btn-success:hover{filter:brightness(1.07);box-shadow:0 10px 26px rgba(124,58,237,.42)}
.btn-warning{background:linear-gradient(135deg,var(--gold-deep),var(--gold));border:none;color:#3a2400}

.stat{border-radius:20px;padding:18px 20px;color:#fff;position:relative;overflow:hidden;height:100%;box-shadow:0 14px 34px rgba(27,8,56,.18)}
.stat .label{opacity:.92;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;font-family:var(--font-head)}
.stat .value{font-family:var(--font-display);font-weight:400;font-size:2.1rem;line-height:1.05;margin-top:4px}
.stat .sub{font-size:.8rem;opacity:.92;margin-top:6px}
.stat-azul{background:linear-gradient(135deg,#2a0f52,#4c1d95)}
.stat-verde{background:linear-gradient(135deg,var(--pitch),var(--pitch-light))}
.stat-oro{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#3a2400}
.stat-oro .label{opacity:.85}
.stat-rojo{background:linear-gradient(135deg,#7c3aed,var(--magenta))}
.stat .icon{position:absolute;right:14px;bottom:6px;font-size:3.4rem;opacity:.20}

/* ---------- BADGES ---------- */
.badge-pagado{background:linear-gradient(135deg,var(--pitch),var(--pitch-light)) !important}
.badge-pendiente{background:linear-gradient(135deg,var(--gold-deep),var(--gold)) !important;color:#3a2400}

/* ---------- PRONOSTICOS ---------- */
.match-row{
  background:#fff;border-radius:16px;padding:12px 14px;margin-bottom:10px;
  box-shadow:0 6px 18px rgba(76,29,149,.08);display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  border-left:4px solid var(--pitch-light);
}
.match-row.bloqueado{opacity:.85}
.team{display:flex;align-items:center;gap:8px;font-weight:700;min-width:0;font-family:var(--font-head)}
.team .flag{font-size:1.4rem}
.team.local{justify-content:flex-end;text-align:right}
.lev{display:flex;gap:6px}
.lev input{display:none}
.lev label{
  cursor:pointer;border:2px solid #e2d6f7;border-radius:11px;
  padding:8px 12px;font-weight:800;min-width:46px;text-align:center;color:#6b5b86;background:#fff;
  transition:.15s;font-family:var(--font-head)
}
.lev input:checked + label{border-color:var(--pitch);background:linear-gradient(135deg,var(--pitch),var(--magenta));color:#fff;box-shadow:0 6px 16px rgba(124,58,237,.35)}
.lev label:hover{border-color:var(--pitch-light)}
.lev.bloqueado label{cursor:not-allowed}
.acierto{color:var(--pitch);font-weight:800}
.fallo{color:var(--rojo);font-weight:800}

/* ---------- AYUDA L / E / V ---------- */
.ayuda-lev{background:#f3ecff;border:1px solid #e2d2fd;border-left:5px solid var(--pitch);border-radius:14px}
.lev-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e2d6f7;border-radius:999px;padding:4px 12px;font-size:.92rem}
.lev-chip .b{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;border-radius:8px;background:var(--pitch);color:#fff;font-weight:800;font-family:var(--font-head)}
.ej-row{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}
.ej-team{font-weight:800;font-family:var(--font-head)}
.ej-btns{display:flex;gap:6px}
.ej-b{display:inline-flex;align-items:center;justify-content:center;min-width:40px;padding:7px 10px;border:2px solid #e2d6f7;border-radius:11px;font-weight:800;color:#6b5b86;background:#fff;font-family:var(--font-head)}
.ej-b.on{border-color:var(--pitch);background:var(--pitch);color:#fff}

/* ---------- TABLAS / POSICIONES ---------- */
.pos-tabs .nav-link{font-family:var(--font-head);font-weight:700;color:var(--ink);border:1px solid rgba(124,58,237,.18)}
.pos-tabs .nav-link.active{background:var(--pitch);color:#fff;border-color:var(--pitch)}
.tabla-pos td,.tabla-pos th{vertical-align:middle}
.tabla-pos thead th{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem}
.tabla-pos .yo{background:#f6edff !important}
.medal-1{color:var(--gold-deep)}.medal-2{color:#9aa4b2}.medal-3{color:#cd7f32}
.ganador-card{background:linear-gradient(135deg,var(--gold-deep),var(--gold));border-radius:20px;color:#3a2400;padding:18px 20px;box-shadow:0 14px 34px rgba(245,158,11,.3)}

/* ---------- ADMIN ---------- */
.admin-layout{display:flex;min-height:100vh}
.admin-side{
  width:248px;background:linear-gradient(180deg,#2a0f52,#1b0838);color:#e7dcff;
  flex-shrink:0;padding:0;position:sticky;top:0;height:100vh;overflow:auto;
}
.admin-side .brand{padding:20px;font-family:var(--font-display);font-weight:400;color:#fff;font-size:1.15rem;border-bottom:1px solid rgba(255,255,255,.1);letter-spacing:1px}
.admin-side .brand .ball{color:var(--gold)}
.admin-side a{
  display:flex;align-items:center;gap:10px;color:#e7dcff;text-decoration:none;
  padding:12px 20px;font-weight:700;border-left:3px solid transparent;font-family:var(--font-head);letter-spacing:.4px;
}
.admin-side a:hover{background:rgba(255,255,255,.08);color:#fff}
.admin-side a.active{background:rgba(251,191,36,.16);border-left-color:var(--gold);color:#fff}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column;background:transparent}
.admin-topbar{background:#fff;padding:14px 24px;box-shadow:0 2px 10px rgba(76,29,149,.08);display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--gold)}
.admin-topbar strong{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.5px}
.admin-content{padding:24px;flex:1}

@media (max-width:768px){
  .admin-side{position:fixed;z-index:1040;transform:translateX(-100%);transition:.2s}
  .admin-side.open{transform:none}
}
@media (max-width:520px){
  .match-row{padding:10px;gap:6px}
  .team .name{font-size:.82rem;line-height:1.05}
  .team .flag{font-size:1.1rem}
  .lev label{min-width:38px;padding:7px 9px}
}

/* ---------- PAGO NEQUI ---------- */
.nequi-box{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-radius:16px;padding:16px 18px;color:#fff;background:linear-gradient(135deg,var(--pitch),var(--magenta));box-shadow:0 12px 28px rgba(124,58,237,.3);margin-bottom:8px}
.nequi-ico{font-size:2rem;line-height:1}
.nequi-lbl{font-size:.72rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;opacity:.9;font-family:var(--font-head)}
.nequi-num{font-family:var(--font-display);font-size:1.7rem;line-height:1.05;letter-spacing:.5px}
.nequi-tit{font-size:.9rem;opacity:.95}
.nequi-amt{font-family:var(--font-display);font-size:1.4rem}
.nequi-note{font-size:.82rem;color:#6b5b86;margin-bottom:12px}

.footer-polla{color:#7b6aa0;font-size:.82rem;text-align:center;padding:18px;font-family:var(--font-head);letter-spacing:.5px}
