/* ============================================================
   Polla Mundial 2026 — Tema "cancha" (verde + dorado)
   Fuentes: Anton (display), Barlow Condensed (títulos), Barlow (texto)
   ============================================================ */
:root{
  /* Paleta cancha */
  --pitch-dark:#0a5b2c;
  --pitch:#0c6a33;
  --pitch-light:#0f7a3b;
  --ink:#062a14;
  --ink-soft:#0a3d1d;
  --gold:#ffcb2d;
  --gold-deep:#f5a623;
  --cream:#f6f4e9;
  --rojo:#d7263d;

  /* Compatibilidad con estilos previos (mismos nombres, nuevos valores) */
  --azul:var(--ink);
  --azul-2:#04200f;
  --oro:var(--gold);
  --verde:var(--pitch);
  --verde-claro:var(--pitch-light);
  --gris:#eef3ea;
  --texto:#12281b;

  --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 10px 30px rgba(6,42,20,.10);
}

*{box-sizing:border-box}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--texto);
  margin:0;
}
a{color:var(--pitch)}
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}

/* ---------- NAVBAR ---------- */
.navbar-polla{
  background:linear-gradient(110deg,var(--ink),var(--pitch-dark));
  box-shadow:0 2px 14px rgba(6,42,20,.3);
  border-bottom:3px solid var(--gold);
}
.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)}
.navbar-polla .nav-link{color:#e9f3e4 !important;font-weight:700;border-radius:10px;padding:.4rem .85rem !important;font-family:var(--font-head);letter-spacing:.5px;text-transform:uppercase;font-size:.95rem}
.navbar-polla .nav-link:hover{color:#fff !important;background:rgba(255,255,255,.10)}
.navbar-polla .nav-link.active{color:var(--ink) !important;background:var(--gold)}
.navbar-polla .navbar-toggler{border-color:rgba(255,255,255,.3)}

/* ---------- AUTH ---------- */
.auth-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(1100px 480px at 80% -10%, rgba(255,203,45,.22), transparent),
    repeating-linear-gradient(100deg, var(--pitch) 0, var(--pitch) 70px, var(--pitch-light) 70px, var(--pitch-light) 140px);
  padding:24px;
}
.auth-card{
  width:100%;max-width:440px;background:#fff;border-radius:20px;
  box-shadow:0 24px 60px rgba(0,0,0,.35);overflow:hidden;
}
.auth-card.lg{max-width:920px}
.auth-head{
  background:linear-gradient(110deg,var(--pitch),var(--pitch-light));
  color:#fff;padding:26px 28px;text-align:center;border-bottom:3px solid var(--gold);
}
.auth-head h1{font-family:var(--font-display);font-weight:400;font-size:1.6rem;margin:0;letter-spacing:1px}
.auth-head .ball{color:var(--gold)}
.auth-head p{margin:.35rem 0 0;opacity:.92;font-size:.9rem;font-family:var(--font-body)}
.auth-body{padding:26px 28px}

/* Login ancho con info */
.login-info{
  background:linear-gradient(160deg,var(--pitch-dark),var(--ink) 75%);
  color:var(--cream);padding:34px;display:flex;flex-direction:column;justify-content:center;
}
.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:2.8rem;color:var(--gold);line-height:1}
.login-info .precio-box{border-left:4px 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:34px;display:flex;flex-direction:column;justify-content:center}
@media (max-width:767px){ .login-info{padding:24px} .login-form{padding:24px} .login-info .precio{font-size:2.2rem} }

/* ---------- CARDS / STATS ---------- */
.card-polla{border:none;border-radius:18px;box-shadow:var(--shadow);background:#fff}
.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}
.btn-success{background:var(--pitch);border-color:var(--pitch)}
.btn-success:hover{background:var(--pitch-dark);border-color:var(--pitch-dark)}
.btn-warning{background:var(--gold);border-color:var(--gold);color:var(--ink)}

.stat{border-radius:18px;padding:18px 20px;color:#fff;position:relative;overflow:hidden;height:100%}
.stat .label{opacity:.9;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:.9;margin-top:6px}
.stat-azul{background:linear-gradient(135deg,var(--pitch-dark),var(--ink))}
.stat-verde{background:linear-gradient(135deg,var(--pitch),var(--pitch-light))}
.stat-oro{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:var(--ink)}
.stat-rojo{background:linear-gradient(135deg,#a81a2d,var(--rojo))}
.stat .icon{position:absolute;right:14px;bottom:6px;font-size:3.4rem;opacity:.18}

/* ---------- BADGES ---------- */
.badge-pagado{background:var(--pitch) !important}
.badge-pendiente{background:var(--gold) !important;color:var(--ink)}

/* ---------- PRONOSTICOS ---------- */
.match-row{
  background:#fff;border-radius:14px;padding:12px 14px;margin-bottom:10px;
  box-shadow:0 3px 12px rgba(6,42,20,.07);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 #cfe0d3;border-radius:10px;
  padding:8px 12px;font-weight:800;min-width:46px;text-align:center;color:#5b6577;background:#fff;
  transition:.15s;font-family:var(--font-head)
}
.lev input:checked + label{border-color:var(--pitch);background:var(--pitch);color:#fff}
.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}

/* ---------- TABLAS / POSICIONES ---------- */
.pos-tabs .nav-link{font-family:var(--font-head);font-weight:700;color:var(--ink);border:1px solid rgba(6,42,20,.12)}
.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:#fff7da !important}
.medal-1{color:var(--gold-deep)}.medal-2{color:#9aa4b2}.medal-3{color:#cd7f32}
.ganador-card{background:linear-gradient(135deg,var(--gold),#ffd76b);border-radius:18px;color:var(--ink);padding:18px 20px}

/* ---------- ADMIN ---------- */
.admin-layout{display:flex;min-height:100vh}
.admin-side{
  width:248px;background:linear-gradient(180deg,var(--pitch-dark),var(--ink));color:#dcecd9;
  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:#dcecd9;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,.07);color:#fff}
.admin-side a.active{background:rgba(255,203,45,.16);border-left-color:var(--gold);color:#fff}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--cream)}
.admin-topbar{background:#fff;padding:14px 24px;box-shadow:0 2px 10px rgba(6,42,20,.06);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}
}

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