/* ═══════════════════════════════════════════════════════════
   Mundial 2026 — Tema Emisora Suba Alternativa
   Colores: Verde #1B6B2F · Amarillo/Dorado #F0B429 · Azul oscuro #0D2240
   Tipografía: Oswald (display) + Source Sans 3 (body)
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;600;700&family=Source+Sans+3:wght@400;500;600;700&display=swap');

:root {
  --sa-verde:       #1B6B2F;    /* Verde principal Suba Alternativa */
  --sa-verde-dark:  #134d22;    /* Verde oscuro */
  --sa-verde-light: #2a8a40;    /* Verde medio */
  --sa-amarillo:    #F0B429;    /* Amarillo/Dorado del logo */
  --sa-amarillo-dk: #c9920f;    /* Dorado oscuro */
  --sa-azul:        #0D2240;    /* Azul oscuro fondo header */
  --sa-azul-mid:    #153460;    /* Azul medio */
  --sa-blanco:      #FFFFFF;
  --sa-crema:       #F7F9F3;    /* Crema verdoso muy sutil */
  --sa-borde:       #D5E8D2;    /* Verde muy claro */
  --sa-texto:       #1A2E1E;    /* Verde casi negro */
  --sa-muted:       #6B8C72;    /* Verde grisáceo */
  --sa-radius:      10px;
  --sa-shadow:      0 4px 20px rgba(27,107,47,.12);
  --font-display:   'Oswald', 'Impact', sans-serif;
  --font-body:      'Source Sans 3', system-ui, sans-serif;

  /* Aliases para el resto del CSS */
  --mundial-accent:  var(--sa-verde);
  --mundial-dark:    var(--sa-azul);
  --mundial-gold:    var(--sa-amarillo);
  --mundial-green:   var(--sa-verde);
  --mundial-light:   var(--sa-crema);
  --mundial-border:  var(--sa-borde);
  --mundial-text:    var(--sa-texto);
  --mundial-muted:   var(--sa-muted);
  --mundial-radius:  var(--sa-radius);
  --mundial-shadow:  var(--sa-shadow);
}

/* ══ Contenedor principal ══════════════════════════════════ */
.mundial-app {
  font-family: var(--font-body);
  color: var(--sa-texto);
  max-width: 1100px;
  margin: 0 auto;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 6px 32px rgba(27,107,47,.13);
  overflow: hidden;
  border: 1px solid var(--sa-borde);
}

/* ══ Header ════════════════════════════════════════════════ */
.mundial-header {
  background: linear-gradient(135deg, var(--sa-azul) 0%, var(--sa-azul-mid) 45%, var(--sa-verde-dark) 100%);
  color: #fff;
  padding: 28px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  position: relative;
  overflow: hidden;
}
/* Patrón radial sutil tipo emisora */
.mundial-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(240,180,41,.08) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='1' fill='%23ffffff' fill-opacity='0.04'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
/* Raya dorada lateral izquierda */
.mundial-header::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  background: linear-gradient(to bottom, var(--sa-amarillo), var(--sa-amarillo-dk));
}

.mundial-header-logo {
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
}
.mundial-trophy {
  font-size: 3rem;
  filter: drop-shadow(0 2px 8px rgba(240,180,41,.5));
}
.mundial-header h2 {
  font-family: var(--font-display);
  font-size: 2.2rem;
  letter-spacing: 2px;
  margin: 0 0 4px;
  color: #fff !important;
  text-transform: uppercase;
}
.mundial-header p { margin: 0; opacity: .9; font-size: .9rem; color: #fff !important; }

.mundial-header-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  position: relative;
}
.mundial-fecha-inicio {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: .85rem;
  color: #fff;
}
.mundial-equipos-badge {
  background: var(--sa-amarillo);
  color: var(--sa-azul);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: .85rem;
  font-weight: 700;
}

/* ══ Tabs ═══════════════════════════════════════════════════ */
.mundial-tabs {
  display: flex;
  background: var(--sa-azul);
  overflow-x: auto;
  scrollbar-width: none;
  border-bottom: 3px solid var(--sa-verde-dark);
}
.mundial-tabs::-webkit-scrollbar { display: none; }
.mundial-tab {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .85rem;
  color: rgba(255,255,255,.6);
  background: none;
  border: none;
  padding: 14px 22px;
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
  transition: color .2s, border-color .2s, background .2s;
  letter-spacing: .3px;
}
.mundial-tab:hover {
  color: var(--sa-amarillo);
  background: rgba(240,180,41,.06);
}
.mundial-tab.active {
  color: var(--sa-amarillo);
  border-bottom-color: var(--sa-amarillo);
  background: rgba(240,180,41,.08);
}

/* ══ Panel ══════════════════════════════════════════════════ */
.mundial-panel { display: none; padding: 24px; }
.mundial-panel.active { display: block; }

/* ══ Sección títulos ════════════════════════════════════════ */
.mundial-seccion-titulo {
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: 1px;
  color: var(--sa-verde-dark);
  text-transform: uppercase;
  margin: 0 0 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.mundial-seccion-titulo::after {
  content: '';
  flex: 1;
  height: 2px;
  background: linear-gradient(to right, var(--sa-amarillo), transparent);
}

/* ══════════════════════════════════════════════
   GRUPOS
   ══════════════════════════════════════════════ */
.mundial-grupos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
}
.mundial-grupo-card {
  border: 1px solid var(--sa-borde);
  border-radius: 10px;
  overflow: hidden;
  transition: box-shadow .2s;
}
.mundial-grupo-card:hover {
  box-shadow: 0 4px 18px rgba(27,107,47,.14);
}
.mundial-grupo-header {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
  padding: 10px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.grupo-letra {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 1px;
  color: var(--sa-amarillo);
}
.grupo-sede {
  font-size: .75rem;
  color: rgba(255,255,255,.7);
  font-style: italic;
}
.mundial-grupo-tabla {
  width: 100%;
  border-collapse: collapse;
  font-size: .82rem;
}
.mundial-grupo-tabla thead tr {
  background: linear-gradient(90deg, #f0f7f0, var(--sa-crema));
}
.mundial-grupo-tabla th {
  padding: 6px 8px;
  text-align: center;
  font-weight: 700;
  font-size: .72rem;
  color: var(--sa-verde-dark);
  border-bottom: 2px solid var(--sa-borde);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.mundial-grupo-tabla th:nth-child(2) { text-align: left; }
.mundial-grupo-tabla td {
  padding: 10px 8px;
  text-align: center;
  border-bottom: 1px solid #eef4ee;
  vertical-align: middle;
}
.mundial-grupo-tabla tr:last-child td { border-bottom: none; }
.bandera-cell { font-size: 1.6rem; width: 36px; line-height: 1; vertical-align: middle; text-align: center; }
.pais-cell { text-align: left; font-weight: 600; }
.puntos-cell { font-size: .95rem; }
.mundial-grupo-tabla tr.clasifica {
  background: rgba(27,107,47,.05);
}
.mundial-grupo-tabla tr.clasifica .puntos-cell strong {
  color: var(--sa-verde);
  font-weight: 700;
}
.mundial-leyenda {
  margin-top: 12px;
  font-size: .8rem;
  color: var(--sa-muted);
  text-align: right;
}

/* ══════════════════════════════════════════════
   PARTIDOS
   ══════════════════════════════════════════════ */
.mundial-partidos-filtros {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.mf-btn {
  font-family: var(--font-body);
  font-size: .82rem;
  font-weight: 600;
  background: var(--sa-crema);
  border: 1px solid var(--sa-borde);
  color: var(--sa-texto);
  border-radius: 20px;
  padding: 6px 16px;
  cursor: pointer;
  transition: all .2s;
}
.mf-btn:hover {
  background: var(--sa-verde);
  border-color: var(--sa-verde);
  color: #fff;
}
.mf-btn.active {
  background: var(--sa-verde);
  border-color: var(--sa-verde);
  color: #fff;
}

.mundial-partido-card {
  background: #fff;
  border: 1px solid var(--sa-borde);
  border-radius: 12px;
  margin-bottom: 8px;
  overflow: hidden;
  transition: box-shadow .2s, transform .15s;
  cursor: pointer;
}
.mundial-partido-card:hover {
  box-shadow: 0 4px 18px rgba(27,107,47,.12);
  transform: translateY(-1px);
}
.mundial-partido-card.en_vivo {
  border: none;
  box-shadow: 0 0 0 2px var(--sa-verde);
}
.mp-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 14px;
  background: linear-gradient(90deg, #f0f7f0, var(--sa-crema));
  border-bottom: 1px solid var(--sa-borde);
  font-size: .7rem;
  color: var(--sa-muted);
  font-weight: 600;
  letter-spacing: .3px;
}
.mp-card-top .mp-grupo { margin: 0; background: none; padding: 0; font-size: .7rem; }
.mp-card-body { padding: 12px 14px 10px; }
.mp-equipos {
  display: flex;
  align-items: center;
  gap: 8px;
}
.mp-bandera { font-size: 1.6rem; }
.mp-pais { font-size: .88rem; font-weight: 600; line-height: 1.2; }
.mp-marcador {
  text-align: center;
  min-width: 80px;
  flex-shrink: 0;
}
.mp-score {
  font-family: var(--font-display);
  font-size: 1.8rem;
  letter-spacing: 3px;
  color: var(--sa-azul);
}
.mp-hora {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--sa-verde);
}

.mp-equipo { display: flex; align-items: center; gap: 8px; flex: 1; }
.mp-visit  { justify-content: flex-end; }
.mp-visit .mp-pais { text-align: right; }

.mp-grupo {
  display: inline-block;
  background: var(--sa-amarillo);
  color: var(--sa-azul);
  font-size: .65rem;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 10px;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.mp-fecha-hora {
  font-size: .75rem;
  color: var(--sa-muted);
  text-align: center;
  margin-top: 6px;
}
.mp-estado {
  font-size: .7rem;
  font-weight: 700;
  text-align: center;
  margin-top: 4px;
  color: var(--sa-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.mp-estado.finalizado { color: var(--sa-verde-dark); }
.mp-minuto {
  font-size: .7rem;
  font-weight: 700;
  color: var(--sa-verde);
  background: rgba(27,107,47,.08);
  border-radius: 4px;
  padding: 1px 5px;
}
.mundial-fecha-titulo {
  font-family: var(--font-display);
  font-size: .85rem;
  letter-spacing: 1px;
  color: var(--sa-amarillo-dk);
  text-transform: uppercase;
  padding: 10px 2px 6px;
  border-bottom: 1px solid var(--sa-borde);
  margin-bottom: 8px;
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 1;
}
.mp-prediccion {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--sa-borde);
  font-size: .78rem;
  color: var(--sa-muted);
}
.mp-prediccion input {
  width: 42px;
  border: 1px solid var(--sa-borde);
  border-radius: 6px;
  text-align: center;
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--sa-azul);
  padding: 4px 6px;
  outline: none;
  transition: border-color .2s;
}
.mp-prediccion input:focus { border-color: var(--sa-verde); }
.pred-save {
  font-family: var(--font-body);
  font-size: .75rem;
  font-weight: 600;
  background: var(--sa-verde);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 5px 12px;
  cursor: pointer;
  transition: background .2s, transform .1s;
}
.pred-save:hover { background: var(--sa-verde-dark); }
.pred-saved-label {
  font-size: .72rem;
  color: var(--sa-verde);
  font-weight: 600;
  display: none;
}
#mundial-partidos-list { min-height: 60px; }

/* ══════════════════════════════════════════════
   GOLEADORES
   ══════════════════════════════════════════════ */
.mundial-goleadores-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}
.mundial-goleadores-table thead tr {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
}
.mundial-goleadores-table th {
  padding: 10px 12px;
  text-align: left;
  font-weight: 700;
  font-size: .75rem;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.mundial-goleadores-table th:first-child { text-align: center; width: 48px; }
.mundial-goleadores-table th:last-child { text-align: center; }
.mundial-goleadores-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--sa-borde);
}
.mundial-goleadores-table tr:last-child td { border-bottom: none; }
.mundial-goleadores-table tbody tr:hover { background: var(--sa-crema); }
.mundial-goleadores-table td:first-child,
.mundial-goleadores-table td:last-child { text-align: center; }
.gol-pos {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--sa-muted);
}
.gol-pos-1 { color: var(--sa-amarillo-dk); font-weight: 700; }
.gol-pos-2 { color: #8a9bb5; font-weight: 700; }
.gol-pos-3 { color: #a07850; font-weight: 700; }
.gol-jugador { font-weight: 600; }
.gol-pais { font-size: .78rem; color: var(--sa-muted); }
.gol-num {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--sa-verde);
}
.gol-bandera { font-size: 1.2rem; }

/* ══════════════════════════════════════════════
   QUINIELA
   ══════════════════════════════════════════════ */
.mundial-quiniela-header {
  background: linear-gradient(135deg, var(--sa-azul), var(--sa-verde-dark));
  color: #fff;
  padding: 20px 24px;
  border-radius: 10px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mundial-quiniela-header h3 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  margin: 0;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.mundial-quiniela-header p {
  margin: 4px 0 0;
  opacity: .8;
  font-size: .85rem;
}
.mundial-quiniela-save-all {
  font-family: var(--font-body);
  font-weight: 700;
  background: var(--sa-amarillo);
  color: var(--sa-azul);
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  cursor: pointer;
  font-size: .88rem;
  transition: background .2s;
}
.mundial-quiniela-save-all:hover { background: var(--sa-amarillo-dk); color: #fff; }
.mundial-quiniela-login {
  text-align: center;
  padding: 40px 20px;
  background: var(--sa-crema);
  border-radius: 10px;
  color: var(--sa-muted);
}
.mundial-quiniela-login a { color: var(--sa-verde); font-weight: 600; }
.quiniela-partido {
  background: #fff;
  border: 1px solid var(--sa-borde);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: box-shadow .2s;
}
.quiniela-partido:hover { box-shadow: 0 2px 12px rgba(27,107,47,.10); }
.qp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  font-size: .75rem;
  color: var(--sa-muted);
}
.qp-grupo-badge {
  background: var(--sa-amarillo);
  color: var(--sa-azul);
  border-radius: 8px;
  padding: 2px 8px;
  font-weight: 700;
  font-size: .7rem;
  text-transform: uppercase;
}
.qp-match {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.qp-team {
  text-align: center;
  font-size: .88rem;
  font-weight: 600;
  flex: 1;
}
.qp-team-left { text-align: right; }
.qp-team-right { text-align: left; }
.qp-flag { font-size: 1.4rem; display: block; margin-bottom: 4px; }
.qp-vs { font-family: var(--font-display); font-size: .85rem; color: var(--sa-muted); min-width: 20px; text-align: center; }
.qp-inputs { display: flex; align-items: center; gap: 8px; }
.qp-in {
  width: 44px;
  height: 44px;
  border: 2px solid var(--sa-borde);
  border-radius: 8px;
  text-align: center;
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--sa-azul);
  outline: none;
  transition: border-color .2s;
}
.qp-in:focus { border-color: var(--sa-verde); }
.qp-sep { font-family: var(--font-display); font-size: 1.4rem; color: var(--sa-muted); }
.qp-save {
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 8px;
  background-color: var(--sa-verde);
  color: #fff;
  font-size: 0.7rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, transform .1s;
  flex-shrink: 0;
  position: relative;
}
.qp-save::after {
  content: '';
  display: block;
  width: 20px;
  height: 20px;
  background-color: #fff;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M19 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11l5 5v11a2 2 0 0 1-2 2z' fill='none' stroke='white' stroke-width='2'/%3E%3Cpolyline points='17 21 17 13 7 13 7 21' fill='none' stroke='white' stroke-width='2'/%3E%3Cpolyline points='7 3 7 8 15 8' fill='none' stroke='white' stroke-width='2'/%3E%3C/svg%3E") no-repeat center / contain;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M19 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11l5 5v11a2 2 0 0 1-2 2z' fill='none' stroke='white' stroke-width='2'/%3E%3Cpolyline points='17 21 17 13 7 13 7 21' fill='none' stroke='white' stroke-width='2'/%3E%3Cpolyline points='7 3 7 8 15 8' fill='none' stroke='white' stroke-width='2'/%3E%3C/svg%3E") no-repeat center / contain;
}
.qp-save:hover  { background: #1e9451; }
.qp-save:active { transform: scale(.93); }
.qp-save:disabled { background: var(--sa-muted); cursor: not-allowed; }
.qp-saved { color: var(--sa-verde); font-size: .75rem; font-weight: 600; margin-top: 6px; text-align: center; display: none; }

/* ══════════════════════════════════════════════
   RANKING QUINIELA
   ══════════════════════════════════════════════ */
.mundial-ranking-header {
  background: linear-gradient(135deg, var(--sa-azul), var(--sa-verde-dark));
  color: #fff;
  padding: 16px 20px;
  border-radius: 10px;
  margin-bottom: 20px;
}
.mundial-ranking-header h3 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  margin: 0;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.mundial-ranking-header p { margin: 4px 0 0; opacity: .75; font-size: .83rem; }
.mundial-ranking-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.mundial-ranking-table thead tr {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
}
.mundial-ranking-table th {
  padding: 10px 12px;
  text-align: left;
  font-weight: 700;
  font-size: .75rem;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.mundial-ranking-table td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--sa-borde);
}
.mundial-ranking-table tr:last-child td { border-bottom: none; }
.mundial-ranking-table tbody tr:hover { background: var(--sa-crema); }
.ranking-pos {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--sa-muted);
  text-align: center;
}
.ranking-pos-1 { color: var(--sa-amarillo-dk); }
.ranking-pos-2 { color: #8a9bb5; }
.ranking-pos-3 { color: #a07850; }
.ranking-usuario { display: flex; align-items: center; gap: 10px; }
.ranking-avatar {
  width: 28px; height: 28px;
  background: linear-gradient(135deg, var(--sa-verde), var(--sa-azul));
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .75rem; font-weight: 700;
  flex-shrink: 0;
}
.ranking-nombre { font-weight: 600; }
.ranking-puntos {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--sa-verde);
  text-align: center;
}
.ranking-exactos {
  font-size: .85rem;
  color: var(--sa-muted);
  text-align: center;
}
.ranking-yo { background: rgba(27,107,47,.05) !important; }
.ranking-yo .ranking-nombre::after {
  content: ' (tú)';
  font-size: .72rem;
  color: var(--sa-verde);
  font-weight: 400;
}
.mundial-btn {
  font-family: var(--font-body);
  font-size: .85rem;
  font-weight: 600;
  background: var(--sa-verde);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 18px;
  cursor: pointer;
  transition: background .2s;
}
.mundial-btn:hover { background: var(--sa-verde-dark); }
.mundial-btn-secondary {
  background: transparent;
  color: var(--sa-verde);
  border: 1px solid var(--sa-verde);
}
.mundial-btn-secondary:hover { background: var(--sa-crema); }

/* ══════════════════════════════════════════════
   ESTADÍSTICAS
   ══════════════════════════════════════════════ */
.mstat-filtros {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.mstat-grupo-btn {
  font-family: var(--font-body);
  font-size: .8rem;
  font-weight: 600;
  background: var(--sa-crema);
  border: 1px solid var(--sa-borde);
  color: var(--sa-texto);
  border-radius: 20px;
  padding: 5px 14px;
  cursor: pointer;
  transition: all .2s;
}
.mstat-grupo-btn:hover,
.mstat-grupo-btn.active {
  background: var(--sa-verde);
  border-color: var(--sa-verde);
  color: #fff;
}
.mstat-table-wrap { overflow-x: auto; border-radius: 10px; box-shadow: var(--sa-shadow); }
.mstat-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .84rem;
  background: #fff;
}
.mstat-table thead tr {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
}
.mstat-table th {
  padding: 10px 12px;
  text-align: center;
  font-size: .72rem;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
}
.mstat-th-pais { text-align: left !important; min-width: 160px; }
.mstat-td-pais { text-align: left; }
.mstat-table td {
  padding: 10px 12px;
  text-align: center;
  border-bottom: 1px solid var(--sa-borde);
}
.mstat-table tr:last-child td { border-bottom: none; }
.mstat-table tbody tr:hover { background: var(--sa-crema); cursor: pointer; }
.mstat-pais-info { display: flex; align-items: center; gap: 8px; }
.mstat-bandera { font-size: 1.2rem; }
.mstat-pais-nombre { font-weight: 600; }
.mstat-grupo-tag {
  font-size: .68rem;
  color: var(--sa-muted);
  background: var(--sa-crema);
  border: 1px solid var(--sa-borde);
  border-radius: 8px;
  padding: 1px 6px;
  margin-left: 4px;
}
.mstat-bar-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 100px;
}
.mstat-bar-bg {
  flex: 1;
  height: 6px;
  background: var(--sa-borde);
  border-radius: 3px;
  overflow: hidden;
}
.mstat-bar-fill {
  height: 100%;
  background: linear-gradient(to right, var(--sa-verde), var(--sa-verde-light));
  border-radius: 3px;
  transition: width .5s ease;
}
.mstat-bar-val { font-weight: 700; font-size: .88rem; color: var(--sa-verde-dark); min-width: 20px; }
.mstat-val-accent { font-weight: 700; color: var(--sa-amarillo-dk); }
.mstat-val-muted { color: var(--sa-muted); font-size: .8rem; }
.mstat-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: .72rem;
  font-weight: 700;
}
.mstat-badge-green { background: rgba(27,107,47,.12); color: var(--sa-verde-dark); }
.mstat-badge-yellow { background: rgba(240,180,41,.15); color: var(--sa-amarillo-dk); }
.mstat-badge-red { background: rgba(200,16,46,.10); color: #9b0e20; }

/* Panel de detalle */
.mstat-detail-panel {
  margin-top: 24px;
  border: 2px solid var(--sa-verde);
  border-radius: var(--sa-radius);
  overflow: hidden;
  animation: fadeIn .25s ease;
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.mstat-detail-header {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
  color: #fff;
  padding: 14px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-display);
  font-size: 1.2rem;
  letter-spacing: .5px;
}
.mstat-detail-close {
  background: rgba(255,255,255,.15);
  color: #fff;
  border: none;
  padding: 4px 12px;
  border-radius: 20px;
  cursor: pointer;
  font-size: .78rem;
  transition: background .15s;
}
.mstat-detail-close:hover { background: rgba(255,255,255,.28); }
.mstat-detail-content { padding: 20px; background: var(--sa-crema); }
.mstat-loading { text-align: center; padding: 32px; color: var(--sa-muted); }
.mstat-detail-hero {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.mstat-detail-flag { font-size: 3rem; }
.mstat-detail-hero h3 {
  font-family: var(--font-display);
  font-size: 1.8rem;
  margin: 0;
  color: var(--sa-azul);
  letter-spacing: 1px;
}
.mstat-detail-grupo { color: var(--sa-muted); font-size: .82rem; margin: 2px 0 0; }
.mstat-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.mstat-kpi {
  background: #fff;
  border-radius: 10px;
  padding: 16px 12px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(27,107,47,.08);
  display: flex;
  flex-direction: column;
  gap: 6px;
  border: 1px solid var(--sa-borde);
}
.mstat-kpi-icon { font-size: 1.5rem; }
.mstat-kpi-val {
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--sa-verde);
  letter-spacing: .5px;
}
.mstat-kpi-label { font-size: .7rem; color: var(--sa-muted); font-weight: 500; }
.mstat-detail-subtitle {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .5px;
  color: var(--sa-azul);
  margin: 0 0 12px;
  text-transform: uppercase;
}
.mstat-pp-table-wrap { overflow-x: auto; border-radius: 8px; }
.mstat-pp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .8rem;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(27,107,47,.07);
}
.mstat-pp-table th {
  background: linear-gradient(90deg, var(--sa-azul), var(--sa-verde-dark));
  color: #fff;
  padding: 9px 10px;
  text-align: center;
  font-size: .73rem;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.mstat-pp-table td {
  padding: 9px 10px;
  text-align: center;
  border-bottom: 1px solid var(--sa-borde);
  white-space: nowrap;
}
.mstat-pp-table tbody tr:last-child td { border-bottom: none; }
.mstat-pp-table tbody tr:hover { background: var(--sa-crema); }
.mstat-pp-rival {
  text-align: left !important;
  display: flex;
  align-items: center;
  gap: 6px;
  padding-left: 12px !important;
  font-weight: 600;
}
.mstat-pp-score {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--sa-verde);
  margin-left: 4px;
}
.mstat-no-data { text-align: center; color: var(--sa-muted); padding: 24px; }

/* ══════════════════════════════════════════════
   LIVE badge
   ══════════════════════════════════════════════ */
.live-pulse {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--sa-verde);
  color: #fff;
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: 1.5px;
  padding: 2px 8px 2px 6px;
  border-radius: 20px;
  text-transform: uppercase;
  animation: livepulse 2s ease-in-out infinite;
}
.live-pulse::before {
  content: '';
  width: 7px; height: 7px;
  background: var(--sa-amarillo);
  border-radius: 50%;
  animation: liveDot 1.2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes livepulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(27,107,47,.5); }
  50%      { box-shadow: 0 0 0 6px rgba(27,107,47,0); }
}
@keyframes liveDot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.7); }
}

/* ══ Skeleton ═══════════════════════════════════════════════ */
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
.skel {
  background: linear-gradient(90deg, #e4ede4 25%, #f0f7f0 50%, #e4ede4 75%);
  background-size: 600px 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: 6px;
  display: inline-block;
}
.skel-card {
  background: #fff;
  border: 1px solid var(--sa-borde);
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 10px;
}
.skel-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 0; }
.skel-team { display: flex; align-items: center; gap: 10px; flex: 1; }
.skel-flag  { width:36px; height:28px; border-radius:4px; }
.skel-name  { width:80px; height:14px; }
.skel-score { width:60px; height:32px; border-radius:8px; margin: 0 auto; }
.skel-meta  { width:140px; height:10px; margin-top:10px; }
.skel-title { width:200px; height:16px; margin-bottom:12px; }
.skel-tab   { width:70px; height:34px; border-radius:20px; }
.mundial-skeleton-tabs {
  display: flex; gap: 8px; padding: 12px 16px;
  background: var(--sa-azul);
  overflow-x: auto; scrollbar-width: none;
}
.mundial-skeleton-tabs::-webkit-scrollbar { display:none; }

/* ══ Toast ══════════════════════════════════════════════════ */
.mundial-toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--sa-azul);
  color: #fff;
  padding: 10px 22px;
  border-radius: 24px;
  font-size: .85rem;
  font-weight: 600;
  z-index: 9999;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
  white-space: nowrap;
  pointer-events: none;
  border-left: 4px solid var(--sa-amarillo);
}
.mundial-toast.show { transform: translateX(-50%) translateY(0); }

/* ══ Feedback botón quiniela ════════════════════════════════ */
.pred-save.saved {
  background: var(--sa-verde);
  border-color: var(--sa-verde);
  color: #fff;
  animation: savedPop .3s ease;
}
@keyframes savedPop {
  0%   { transform: scale(.9); }
  60%  { transform: scale(1.15); }
  100% { transform: scale(1); }
}
.mundial-partido-card.en_vivo .mp-card-top {
  background: rgba(27,107,47,.06);
  border-bottom-color: rgba(27,107,47,.2);
}
.mundial-partido-card.en_vivo .mp-pais { font-weight: 700; }

/* ══ Empty state ════════════════════════════════════════════ */
.mundial-empty-state {
  text-align: center;
  padding: 40px 24px;
  color: var(--sa-muted);
}
.mundial-empty-icon { font-size: 2.5rem; display: block; margin-bottom: 12px; }
.mundial-empty-sub  { font-size: .82rem; margin-top: 4px; }

/* ══ Accesibilidad ══════════════════════════════════════════ */
.mundial-tab:focus-visible,
.mf-btn:focus-visible,
.mundial-btn:focus-visible {
  outline: 2px solid var(--sa-amarillo);
  outline-offset: 2px;
}

/* ══ Responsive ═════════════════════════════════════════════ */
.mundial-tabs {
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 0 4px;
}
.mundial-tab { scroll-snap-align: start; flex-shrink: 0; }
.mundial-tabs-wrap { position: relative; }
.mundial-tabs-fade {
  position: absolute; right: 0; top: 0; bottom: 0; width: 40px;
  background: linear-gradient(to right, transparent, var(--sa-azul));
  pointer-events: none; display: none;
}
@media (max-width: 700px) {
  .mundial-grupos-grid { grid-template-columns: 1fr; gap: 12px; }
  .mundial-grupo-tabla th,
  .mundial-grupo-tabla td { padding: 6px 4px; font-size: .75rem; }
  .bandera-cell { font-size: 1.4rem; }
}
@media (max-width: 600px) {
  .mundial-header { padding: 16px; flex-direction: column; align-items: flex-start; gap: 10px; }
  .mundial-header h2 { font-size: 1.6rem; }
  .mundial-header p  { font-size: .78rem; }
  .mundial-header-meta { flex-direction: row; align-items: center; width: 100%; justify-content: flex-start; }
  .mundial-trophy { font-size: 2rem; }
  .mundial-tabs-fade { display: block; }
  .mundial-tab { padding: 12px 14px; font-size: .78rem; }
  .mundial-panel { padding: 12px; }
  .mstat-filtros { gap: 6px; }
  .mstat-grupo-btn { padding: 5px 10px; font-size: .72rem; }
  .mstat-kpi-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .mstat-kpi { padding: 10px 8px; }
  .mstat-kpi-val { font-size: 1.3rem; }
  .mstat-detail-hero .mstat-detail-flag { font-size: 2.2rem; }
  .mstat-detail-hero h3 { font-size: 1.4rem; }
}
@media (max-width: 500px) {
  .mundial-goleadores-table th,
  .mundial-goleadores-table td { padding: 8px 6px; font-size: .75rem; }
  .gol-num { font-size: 1.1rem; }
  .qp-match { gap: 6px; }
  .qp-in    { width: 38px; padding: 4px; font-size: .9rem; }
  .qp-team  { font-size: .82rem; }
  .mundial-ranking-table th,
  .mundial-ranking-table td { padding: 8px 6px; font-size: .78rem; }
  .ranking-avatar { width: 22px !important; height: 22px !important; }
}
@media (max-width: 480px) {
  .mp-bandera { font-size: 1.3rem; }
  .mp-pais    { font-size: .78rem; }
  .mp-score   { font-size: 1.5rem; letter-spacing: 2px; }
  .mp-hora    { font-size: 1.1rem; }
  .mp-marcador { min-width: 70px; }
  .mp-equipo  { flex-direction: column; align-items: center; text-align: center; gap: 4px; }
  .mp-visit   { flex-direction: column-reverse; }
  .mp-prediccion { flex-wrap: wrap; gap: 6px; }
  .mp-prediccion input { width: 38px; padding: 4px; }
  .mstat-table th,
  .mstat-table td { padding: 8px 6px; font-size: .72rem; }
  .mstat-th-pais,
  .mstat-td-pais { min-width: 120px; }
  .mstat-bar-wrap { min-width: 60px; }
  .mstat-kpi-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ══ Dark mode ══════════════════════════════════════════════ */
/* Modo oscuro desactivado — el plugin usa siempre el tema claro Suba Alternativa */

/* ══ Clases adicionales de templates ══════════════════════ */
.mundial-section-title {
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 1px;
  color: var(--sa-verde-dark);
  text-transform: uppercase;
  margin: 0 0 16px;
  padding-left: 12px;
  border-left: 4px solid var(--sa-amarillo);
}

/* Goleadores extra clases */
.mundial-goleadores-table-wrap { overflow-x: auto; border-radius: 10px; box-shadow: var(--sa-shadow); }
.gol-row.oro   { background: rgba(240,180,41,.07); }
.gol-row.plata { background: rgba(138,155,181,.07); }
.gol-row.bronce{ background: rgba(160,120,80,.06); }
.gol-medal { font-size: 1.2rem; }
.gol-goles { text-align: center; }
.gol-asist { text-align: center; color: var(--sa-muted); font-size: .88rem; }
.gol-nombre { display: flex; flex-direction: column; gap: 2px; }
.gol-nombre strong { font-weight: 600; }

/* Ranking extra clases */
.mundial-ranking-table-wrap { overflow-x: auto; border-radius: 10px; box-shadow: var(--sa-shadow); }
.ranking-row { transition: background .15s; }
.ranking-me { background: rgba(27,107,47,.06) !important; }
.ranking-me .ranking-total strong { color: var(--sa-verde); }
.ranking-you { font-size: .72rem; color: var(--sa-verde); margin-left: 6px; }
.ranking-total { text-align: center; }
.ranking-total strong { font-family: var(--font-display); font-size: 1.15rem; color: var(--sa-verde-dark); }
.ranking-user { display: flex; align-items: center; gap: 8px; }
.ranking-avatar { border-radius: 50% !important; width: 28px !important; height: 28px !important; }
.ranking-pos { text-align: center; font-family: var(--font-display); font-size: 1.05rem; }
.ranking-login-cta { text-align: center; margin-top: 16px; font-size: .85rem; color: var(--sa-muted); }
.ranking-login-cta a { color: var(--sa-verde); font-weight: 600; }

/* Quiniela extra */
.quiniela-partido:last-child { margin-bottom: 0; }

/* Partidos: clases del template */
.mp-equipos { display: flex; align-items: center; gap: 8px; }
.mp-equipo { display: flex; align-items: center; gap: 8px; flex: 1; }
.mp-local { justify-content: flex-start; }
.mp-visit { justify-content: flex-end; }
.mp-visit .mp-pais { text-align: right; }
.mp-marcador { text-align: center; min-width: 80px; flex-shrink: 0; }
.mp-vs { display: block; font-size: .7rem; color: var(--sa-muted); letter-spacing: 1px; }
.mp-meta { margin-top: 8px; font-size: .73rem; color: var(--sa-muted); text-align: center; }
.mp-prediccion-login { font-size: .75rem; color: var(--sa-muted); margin-top: 8px; text-align: center; }
.mp-prediccion-login a { color: var(--sa-verde); font-weight: 600; }
.pred-label { font-size: .75rem; color: var(--sa-muted); white-space: nowrap; }
.pred-save.button {
  background: var(--sa-verde) !important;
  color: #fff !important;
  border-color: var(--sa-verde-dark) !important;
  font-size: .8rem;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
}
.pred-saved { font-size: .72rem; color: var(--sa-verde); font-weight: 600; }
.live-score { color: var(--sa-verde); }

/* ══ Auth — Login / Registro propio ═══════════════════════ */
.mundial-auth-wrap {
  max-width: 420px;
  margin: 0 auto;
  padding: 28px 24px;
  background: var(--sa-crema);
  border-radius: var(--sa-radius);
  border: 1px solid var(--sa-borde);
}
.mauth-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 24px;
  border-bottom: 2px solid var(--sa-borde);
}
.mauth-tab {
  flex: 1;
  padding: 10px 0;
  background: none;
  border: none;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--sa-muted);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: color .2s, border-color .2s;
}
.mauth-tab.active {
  color: var(--sa-verde);
  border-bottom-color: var(--sa-verde);
}
.mauth-panel { display: none; }
.mauth-panel.active { display: block; }

.mauth-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mauth-form label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--sa-texto);
  margin-bottom: -4px;
}
.mauth-captcha-label {
  font-size: .85rem;
  font-weight: 600;
  color: var(--sa-azul);
  background: #eef7f0;
  padding: 6px 12px;
  border-radius: 6px;
  border: 1px dashed var(--sa-verde-light);
}
.mauth-form input[type="text"],
.mauth-form input[type="email"],
.mauth-form input[type="password"],
.mauth-form input[type="number"] {
  width: 100%;
  min-width: 85px !important;
  padding: 10px 14px;
  border: 1.5px solid var(--sa-borde);
  border-radius: 8px;
  font-size: .95rem;
  font-family: var(--font-body);
  background: #fff;
  color: var(--sa-texto);
  box-sizing: border-box;
  transition: border-color .2s;
}
.mauth-form input:focus {
  outline: none;
  border-color: var(--sa-verde);
}
.mauth-submit {
  margin-top: 8px;
  width: 100%;
  justify-content: center;
}
.mauth-msg {
  min-height: 20px;
  font-size: .85rem;
  font-weight: 600;
  padding: 0 0 8px;
}
.mauth-msg.error { color: #c0392b; }
.mauth-msg.ok    { color: var(--sa-verde); }

/* Usuario logueado */
.mundial-auth-logueado {
  max-width: 420px;
  margin: 0 auto;
}
.mauth-user-info {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: var(--sa-crema);
  border-radius: var(--sa-radius);
  border: 1px solid var(--sa-borde);
}
.mauth-avatar {
  font-size: 2rem;
  line-height: 1;
}
.mauth-nombre {
  display: block;
  font-size: 1rem;
  color: var(--sa-texto);
}
.mauth-email {
  font-size: .78rem;
  color: var(--sa-muted);
}
.mundial-btn-outline {
  background: transparent;
  border: 2px solid var(--sa-verde);
  color: var(--sa-verde);
  padding: 6px 14px;
  font-size: .82rem;
}
.mundial-btn-outline:hover {
  background: var(--sa-verde);
  color: #fff;
}

/* Auth inline en quiniela */
.mauth-inline-wrap {
  margin-top: 20px;
}
.mundial-login-required {
  text-align: center;
  padding: 40px 20px;
}
.mundial-lock {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 12px;
}

/* Ranking sin avatar WP */
.ranking-avatar-emoji {
  font-size: 1.1rem;
  margin-right: 6px;
}

/* ── Fix: banderas emoji convertidas a <img> por wp-emoji ── */
/* WordPress reemplaza emojis con <img class="emoji"> y los temas
   suelen tener img { max-width:100%; height:auto } que las aplana. */
.bandera-cell img.emoji,
.mp-bandera img.emoji,
.gol-bandera img.emoji,
.qp-flag img.emoji,
.mstat-bandera img.emoji,
.mstat-detail-flag img.emoji,
.ranking-avatar-emoji img.emoji {
  width: auto !important;
  height: 1em !important;
  max-width: none !important;
  vertical-align: -0.1em;
  display: inline;
}

/* ── Tab Login / Perfil ─────────────────────────────────── */
.mundial-tab[data-tab="login"] {
  margin-left: auto;          /* empuja el tab login al extremo derecho */
  background: transparent;
  border: 2px solid rgba(255,255,255,0.35);
  border-radius: 20px;
  padding: 6px 14px;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.mundial-tab[data-tab="login"]:hover,
.mundial-tab[data-tab="login"].active {
  background: #27ae60;
  border-color: #27ae60;
  color: #fff;
}

/* ── Panel Login dentro del app ─────────────────────────── */
#mundial-tab-login .mundial-auth-wrap,
#mundial-tab-login .mundial-auth-logueado {
  max-width: 460px;
  margin: 24px auto;
}

/* ── Polla: bloque "ir al login" ─────────────────────────── */
#mundial-tab-polla .mundial-login-required {
  text-align: center;
  padding: 48px 20px;
}
#mundial-tab-polla .mundial-login-required .mundial-btn {
  margin-top: 12px;
  font-size: 1rem;
  padding: 10px 28px;
}
