/* ==========================================================================
   Mundial 2026 — tema "Transmisión deportiva"
   Barlow Condensed (display) + Barlow (texto) · navy de estadio nocturno
   ========================================================================== */
:root{
  --bg:#0b1020; --panel:#121933; --panel2:#1a2348; --line:#2a3666;
  --text:#e8ecff; --muted:#8a93b8;
  --cyan:#22d3ee; --violet:#a78bfa;
  --gold:#fbbf24; --silver:#cbd5e1; --bronze:#f59e0b;
  --win:#10b981; --warn:#fbbf24; --danger:#f87171;
  --display:'Barlow Condensed', 'Arial Narrow', sans-serif;
  --body:'Barlow', 'Helvetica Neue', sans-serif;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --glow-cyan:0 0 0 1px rgba(34,211,238,.4), 0 0 18px rgba(34,211,238,.25);
  --tabbar-h:62px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--text); font-family:var(--body); font-size:15px;
  background:
    radial-gradient(1100px 700px at 15% -5%, #1c2756 0%, var(--bg) 55%) fixed;
}
/* líneas de cancha: textura diagonal apenas visible */
body::before{
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:repeating-linear-gradient(55deg, transparent 0 46px, rgba(138,147,184,.05) 46px 47px);
}
#main{position:relative; z-index:1; max-width:1500px; margin:0 auto;
  padding:14px 14px calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 22px)}

/* ---------- header ---------- */
.app-header{position:sticky; top:0; z-index:50; display:flex; align-items:center;
  justify-content:space-between; gap:10px; padding:10px 16px;
  background:rgba(11,16,32,.86); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.brand{display:flex; align-items:center; gap:10px}
.brand-ball{font-size:26px; filter:drop-shadow(0 0 8px rgba(34,211,238,.45))}
.brand h1{margin:0; font-family:var(--display); font-weight:700; font-size:24px;
  letter-spacing:.06em; text-transform:uppercase; line-height:1;
  background:linear-gradient(100deg, var(--text) 60%, var(--cyan));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.brand-sub{margin:2px 0 0; font-size:11px; color:var(--muted); letter-spacing:.02em}

/* ---------- tabs: barra inferior en móvil ---------- */
.tabs{position:fixed; left:0; right:0; bottom:0; z-index:60; display:flex;
  height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:rgba(13,19,40,.92); 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:2px; background:none; border:none; color:var(--muted); cursor:pointer;
  font-family:var(--display); font-size:13px; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; position:relative; transition:color .18s}
.tab-icon{font-size:19px; transition:transform .18s}
.tab.active{color:var(--cyan)}
.tab.active .tab-icon{transform:translateY(-1px) scale(1.12);
  filter:drop-shadow(0 0 7px rgba(34,211,238,.6))}
.tab.active::before{content:''; position:absolute; top:0; left:22%; right:22%;
  height:2px; border-radius:0 0 3px 3px; background:var(--cyan);
  box-shadow:0 0 10px rgba(34,211,238,.8)}

/* ---------- desktop: tabs como barra fija bajo el título ---------- */
@media (min-width:900px){
  .tabs{position:static; height:auto; padding:8px 16px; gap:6px;
    justify-content:center; backdrop-filter:none;
    background:rgba(13,19,40,.6); border-top:none; border-bottom:1px solid var(--line)}
  .tab{flex:none; flex-direction:row; gap:7px; padding:9px 16px; border-radius:9px;
    border:1px solid transparent}
  .tab.active{background:var(--panel2); border-color:var(--line)}
  .tab.active::before{display:none}
  #main{padding-bottom:40px}
}

/* ---------- paneles y secciones ---------- */
.panel[hidden]{display:none}
.section-title{font-family:var(--display); font-weight:600; font-size:15px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
  margin:20px 2px 10px; padding-bottom:7px; border-bottom:1px solid var(--line)}
.hint{font-size:12px; color:var(--muted); line-height:1.55; margin:0 2px 12px}
.hint b{color:var(--text)}

/* ---------- grupos ---------- */
.thirds-bar{position:sticky; top:58px; z-index:40; display:flex; align-items:center;
  gap:8px; margin:0 0 12px; padding:9px 13px; border-radius:10px;
  background:rgba(18,25,51,.94); backdrop-filter:blur(8px);
  border:1px solid var(--line); font-size:12.5px}
.thirds-bar .count{font-family:var(--display); font-weight:700; font-size:18px;
  letter-spacing:.04em; color:var(--win)}
.thirds-bar.under .count{color:var(--warn)}
.thirds-bar .msg{color:var(--muted)}
.groups{display:grid; grid-template-columns:repeat(auto-fill,minmax(295px,1fr)); gap:13px}
.group{background:var(--panel); border:1px solid var(--line); border-radius:13px;
  padding:12px; box-shadow:var(--shadow); animation:fadeUp .45s both}
.group h3{margin:0 0 2px; font-family:var(--display); font-weight:700; font-size:19px;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cyan)}
.group .group-help{font-size:11px; color:var(--muted); margin-bottom:9px}
.team{display:flex; align-items:center; gap:9px; padding:8px 9px; margin-bottom:6px;
  border-radius:9px; background:var(--panel2); border:1px solid var(--line);
  transition:border-color .15s, box-shadow .15s, opacity .15s;
  user-select:none; -webkit-user-select:none; -webkit-touch-callout:none}
.team.dragging{opacity:.92; border-color:var(--cyan); box-shadow:var(--glow-cyan);
  position:relative; z-index:5} /* el transform lo aplica JS durante el gesto */
.pos{width:23px; height:23px; flex-shrink:0; display:inline-flex; align-items:center;
  justify-content:center; border-radius:6px; font-family:var(--display);
  font-size:13px; font-weight:700; color:#0b1020}
.pos-1{background:var(--gold)} .pos-2{background:var(--silver)}
.pos-3{background:var(--bronze)} .pos-4{background:#475569; color:#e2e8f0}
.team .flag{font-size:19px; flex-shrink:0}
.team .name{flex:1; font-family:var(--display); font-weight:600; font-size:16.5px;
  letter-spacing:.03em; text-transform:uppercase; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis}
.drag-handle{flex-shrink:0; width:42px; height:38px; display:inline-flex;
  align-items:center; justify-content:center; margin:-6px -6px -6px 0;
  color:var(--muted); font-size:17px; cursor:grab; touch-action:none;
  border:none; background:none; border-radius:8px}
.drag-handle:active{cursor:grabbing; color:var(--cyan)}
.qual-toggle{flex-shrink:0; font-size:10.5px; font-weight:600; letter-spacing:.05em;
  padding:3px 7px; border-radius:5px; border:1px solid transparent; cursor:pointer;
  background:none; font-family:var(--body); transition:.15s}
.qual-toggle.on{background:rgba(16,185,129,.16); color:var(--win);
  border-color:rgba(16,185,129,.4)}
.qual-toggle.off{background:rgba(248,113,113,.12); color:var(--danger);
  border-color:rgba(248,113,113,.35)}
.info-dot{flex-shrink:0; width:18px; height:18px; border-radius:50%; border:1px solid var(--line);
  background:var(--panel); color:var(--muted); font-size:10.5px; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; padding:0}
.tip-pop{position:absolute; z-index:80; max-width:260px; padding:10px 12px;
  border-radius:10px; background:#0e1430; border:1px solid var(--cyan);
  box-shadow:var(--shadow); font-size:12px; line-height:1.5; color:var(--text)}

/* ---------- eliminatorias ---------- */
.round-chips{position:sticky; top:58px; z-index:40; display:flex; gap:7px;
  padding:8px 2px; margin-bottom:6px; overflow-x:auto; scrollbar-width:none;
  background:linear-gradient(rgba(11,16,32,.95), rgba(11,16,32,.85)); backdrop-filter:blur(8px)}
.round-chips::-webkit-scrollbar{display:none}
.chip{flex-shrink:0; padding:7px 14px; border-radius:999px; border:1px solid var(--line);
  background:var(--panel); color:var(--muted); cursor:pointer;
  font-family:var(--display); font-weight:600; font-size:13.5px; letter-spacing:.09em;
  text-transform:uppercase; transition:.18s}
.chip.active{color:#0b1020; background:var(--cyan); border-color:var(--cyan);
  box-shadow:0 0 14px rgba(34,211,238,.5)}
.rounds{display:flex; gap:16px; overflow-x:auto; padding:6px 2px 18px;
  align-items:stretch; overscroll-behavior-x:contain}
.round{min-width:272px; flex-shrink:0; display:flex; flex-direction:column}
.round-title{font-family:var(--display); font-weight:600; font-size:14px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
  text-align:center; margin-bottom:10px}
.matches{display:flex; flex-direction:column; justify-content:space-around; flex:1; gap:9px}

/* ---------- móvil: páginas emparejadas (par de partidos → su siguiente) ---------- */
.pages{display:flex; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 0 18px;
  overscroll-behavior-x:contain; scrollbar-width:none}
.pages::-webkit-scrollbar{display:none}
.page{flex:0 0 100%; scroll-snap-align:start; padding:0 2px; min-width:0}
.page .round-title{margin:2px 0 12px}
.duo{display:grid; grid-template-columns:minmax(0,1fr) 13px minmax(0,.94fr);
  align-items:center; margin-bottom:16px}
.duo .feeders{display:flex; flex-direction:column; gap:10px; min-width:0}
.duo .lane{align-self:stretch; margin:52px 0; width:12px;
  border:1px solid var(--line); border-left:none; border-radius:0 10px 10px 0;
  position:relative}
.duo .lane::after{ /* muñón hacia el partido destino */
  content:''; position:absolute; top:50%; right:-2px; width:4px; height:1px;
  background:var(--line)}
.duo .next{min-width:0; display:flex; flex-direction:column; gap:10px}
.duo .match::after{display:none}        /* sin muñones sueltos: la guía es el lane */
.match{background:var(--panel); border:1px solid var(--line); border-radius:11px;
  padding:8px; font-size:12px; box-shadow:var(--shadow); position:relative}
.match::after{ /* muñón de conexión hacia la siguiente ronda */
  content:''; position:absolute; right:-17px; top:50%; width:16px; height:1px;
  background:var(--line)}
.round:last-child .match::after{display:none}
.match .mid{font-family:var(--display); font-size:11px; font-weight:600;
  letter-spacing:.14em; color:var(--muted); text-align:center; margin-bottom:3px;
  text-transform:uppercase}
.match .mvenue{font-size:9.5px; color:var(--cyan); text-align:center; opacity:.8;
  margin-bottom:6px; line-height:1.35}
.side{display:flex; align-items:center; gap:8px; padding:8px; border-radius:7px;
  cursor:pointer; border:1px solid transparent; transition:.14s; background:none;
  width:100%; text-align:left; color:var(--text); font-family:var(--body)}
.side:hover{background:var(--panel2); border-color:var(--line)}
.side .name{font-family:var(--display); font-weight:600; font-size:15px;
  letter-spacing:.03em; text-transform:uppercase}
.side.winner{background:rgba(16,185,129,.14); border-color:var(--win)}
.side.winner .name{color:#d1fae5}
.side.placeholder{color:var(--muted); cursor:default; font-style:italic}
.side.placeholder .name{font-family:var(--body); font-weight:400; font-size:12.5px;
  text-transform:none; letter-spacing:0}
.side.placeholder:hover{background:none; border-color:transparent}
.vs{font-size:9px; color:var(--muted); text-align:center; letter-spacing:.2em; padding:1px 0}
.champion{margin:18px 0 6px; padding:18px; text-align:center; border-radius:14px;
  border:1px solid var(--cyan); position:relative; overflow:hidden;
  background:linear-gradient(135deg, rgba(34,211,238,.13), rgba(167,139,250,.13))}
.champion::before{content:''; position:absolute; inset:0;
  background:linear-gradient(115deg, transparent 30%, rgba(232,236,255,.09) 50%, transparent 70%);
  animation:shine 3.2s linear infinite}
.champion .label{font-family:var(--display); font-size:12px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--muted)}
.champion .cname{font-family:var(--display); font-weight:700; font-size:30px;
  letter-spacing:.05em; text-transform:uppercase; margin-top:5px;
  display:flex; align-items:center; justify-content:center; gap:11px}
.champion .cname .flag{font-size:34px}

/* ---------- en vivo ---------- */
.live-match{display:flex; align-items:center; gap:10px; padding:11px 13px;
  margin-bottom:8px; border-radius:11px; background:var(--panel);
  border:1px solid var(--line); animation:fadeUp .4s both}
.live-team{flex:1; display:flex; align-items:center; gap:7px; min-width:0}
.live-team .name{font-family:var(--display); font-weight:600; font-size:15.5px;
  text-transform:uppercase; letter-spacing:.03em; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis}
.live-team.right{justify-content:flex-end; text-align:right}
.live-score{flex-shrink:0; font-family:var(--display); font-weight:700; font-size:24px;
  letter-spacing:.06em; min-width:64px; text-align:center;
  font-variant-numeric:tabular-nums}
.live-meta{flex-basis:100%; display:flex; justify-content:center; gap:8px;
  font-size:10.5px; color:var(--muted); margin-top:2px}
.badge-live{display:inline-flex; align-items:center; gap:5px; padding:2px 9px;
  border-radius:999px; font-size:10px; font-weight:600; letter-spacing:.12em;
  color:#0b1020; background:var(--win); text-transform:uppercase}
.badge-live::before{content:''; width:6px; height:6px; border-radius:50%;
  background:#0b1020; animation:pulse 1.1s ease-in-out infinite}
.badge-ft{padding:2px 9px; border-radius:999px; font-size:10px; letter-spacing:.12em;
  color:var(--muted); border:1px solid var(--line); text-transform:uppercase}
.live-table{width:100%; border-collapse:collapse; font-size:12.5px; margin-bottom:14px}
.live-table th{font-family:var(--display); font-weight:600; font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
  text-align:right; padding:5px 7px; border-bottom:1px solid var(--line)}
.live-table th:first-child{text-align:left}
.live-table td{padding:6px 7px; text-align:right; border-bottom:1px solid rgba(42,54,102,.45);
  font-variant-numeric:tabular-nums}
.live-table td:first-child{text-align:left; font-family:var(--display);
  font-weight:600; font-size:14px; text-transform:uppercase; letter-spacing:.03em}
.live-table tr:nth-child(-n+2) td:first-child{color:#d1fae5}
.notice{padding:11px 14px; border-radius:10px; font-size:13px; margin-bottom:12px;
  border:1px solid var(--line); background:var(--panel)}
.notice.warn{border-color:rgba(251,191,36,.45); color:var(--warn)}
.notice button:not(.linklike){margin-left:10px; padding:5px 12px; border-radius:7px;
  cursor:pointer; border:1px solid var(--line); background:var(--panel2);
  color:var(--text); font-size:12px}

/* ---------- compartir / banner / toast / botones ---------- */
.btn{display:inline-flex; align-items:center; gap:8px; padding:11px 18px;
  border-radius:10px; border:none; cursor:pointer; font-family:var(--display);
  font-weight:700; font-size:15px; letter-spacing:.08em; text-transform:uppercase;
  color:#0b1020; background:linear-gradient(120deg, var(--cyan), var(--violet));
  box-shadow:0 4px 18px rgba(34,211,238,.3); transition:transform .15s}
.btn:active{transform:scale(.97)}
.btn.ghost{background:var(--panel2); color:var(--text); border:1px solid var(--line);
  box-shadow:none}
.share-row{display:flex; justify-content:center; margin:16px 0 4px}
.shared-banner[hidden]{display:none} /* display:flex ganaría al atributo hidden */
.shared-banner{position:sticky; top:58px; z-index:45; display:flex; align-items:center;
  gap:10px; flex-wrap:wrap; margin:10px 14px 0; padding:11px 14px; border-radius:11px;
  border:1px solid var(--violet); background:rgba(167,139,250,.12);
  backdrop-filter:blur(8px); font-size:13px}
.toast{position:fixed; left:50%; transform:translateX(-50%);
  bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 14px); z-index:90;
  padding:11px 18px; border-radius:999px; background:#0e1430; color:var(--text);
  border:1px solid var(--cyan); box-shadow:var(--glow-cyan); font-size:13px;
  animation:fadeUp .25s both}
.empty{padding:34px 10px; text-align:center; color:var(--muted); font-size:13px}

/* ---------- animaciones ---------- */
@keyframes fadeUp{from{opacity:0; transform:translateY(9px)} to{opacity:1; transform:none}}
@keyframes pulse{0%,100%{opacity:1} 50%{opacity:.25}}
@keyframes shine{from{transform:translateX(-100%)} to{transform:translateX(100%)}}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important; transition:none !important}
  html{scroll-behavior:auto}
}

/* ---------- carrusel horizontal de partidos (En vivo / Partidos) ---------- */
.live-carousel{display:flex; gap:10px; overflow-x:auto; padding:2px 2px 12px;
  scroll-snap-type:x proximity; scrollbar-width:none; overscroll-behavior-x:contain}
.live-carousel::-webkit-scrollbar{display:none}
.live-carousel .live-match{flex:0 0 min(320px, 86vw); margin-bottom:0; scroll-snap-align:start}

/* ---------- pestaña Partidos: feed vertical con saltos por día ---------- */
.day-section{scroll-margin-top:118px}
.day-title{position:sticky; top:104px; z-index:30; margin-top:8px;
  background:linear-gradient(rgba(11,16,32,.97), rgba(11,16,32,.88));
  backdrop-filter:blur(6px)}

/* partido en juego: resaltado en la pestaña Partidos */
.live-match.is-live{border-color:var(--win); box-shadow:0 0 14px rgba(16,185,129,.25)}

/* ---------- tabla en vivo estilo marcador: posición, chip de score, movimiento ---------- */
.tpos{display:inline-flex; width:18px; height:18px; border-radius:50%; margin-right:7px;
  align-items:center; justify-content:center; vertical-align:middle;
  font-family:var(--display); font-size:10.5px; font-weight:700; color:#0b1020}
.tpos-1,.tpos-2{background:var(--cyan)}      /* clasifican directo */
.tpos-3{background:var(--warn)}              /* posible mejor tercero */
.tpos-4{background:#475569; color:#cbd5e1}   /* eliminado */
.tname{margin-left:4px}
.score-chip{display:inline-block; margin-left:7px; padding:1px 6px; border-radius:5px;
  font-size:10.5px; font-weight:700; font-variant-numeric:tabular-nums; color:#0b1020;
  vertical-align:middle}
.score-chip.w{background:var(--win)}
.score-chip.l{background:var(--danger)}
.score-chip.d{background:var(--silver)}
.mov{font-size:9.5px; font-weight:700; margin-left:6px; font-variant-numeric:tabular-nums}
.mov.up{color:var(--win)}
.mov.down{color:var(--danger)}
.live-table tr.rowlive td{color:#d7fbe9}
.live-table td:first-child{white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  max-width:0; width:100%}

/* ---------- modo "Así va": proyección real del cuadro ---------- */
.chips-stack{position:sticky; top:58px; z-index:40;
  background:linear-gradient(rgba(11,16,32,.97), rgba(11,16,32,.86)); backdrop-filter:blur(8px)}
.chips-stack .round-chips{position:static; background:none; backdrop-filter:none}
.mode-chips{padding-bottom:2px}
.mode-chips .chip{font-size:12.5px}
.notice.live-note{border-color:rgba(16,185,129,.45)}
.live-mode .mode-chips .chip.active,
.live-mode .round-chips .chip.active{background:var(--win); border-color:var(--win);
  color:#0b1020; box-shadow:0 0 14px rgba(16,185,129,.5)}
.live-mode .round-title{color:#86efac}
.live-mode .match.decided{border-color:rgba(16,185,129,.55)}
.live-mode .match.prov{border-style:dashed; opacity:.88}
.live-mode .side.winner{background:rgba(16,185,129,.2)}
.rgoals{margin-left:auto; padding-left:8px; font-family:var(--display); font-weight:700;
  font-size:16px; font-variant-numeric:tabular-nums}
.hit{color:var(--win); font-weight:700}
.miss{color:var(--danger); font-weight:700}

/* procedencia en 16avos: 1A/2B/3C con los colores de posición del Pronóstico */
.prov-tag{flex-shrink:0; padding:1px 5px; border-radius:5px; color:#0b1020;
  font-family:var(--display); font-size:11px; font-weight:700; letter-spacing:.04em;
  font-variant-numeric:tabular-nums}
.prov-1{background:var(--gold)}
.prov-2{background:var(--silver)}
.prov-3{background:var(--bronze)}

/* enlaces dentro de textos de ayuda */
.linklike{background:none; border:none; padding:0; cursor:pointer; font:inherit;
  color:var(--cyan); text-decoration:underline; text-underline-offset:2px}

/* instrucciones con jerarquía de "léeme" (feedback de usuarios) */
.hint{font-size:14px; color:var(--text); background:rgba(34,211,238,.07);
  border:1px solid rgba(34,211,238,.25); border-left:3px solid var(--cyan);
  border-radius:10px; padding:11px 14px; margin:0 2px 14px}
.notice{font-size:13.5px}
.team{touch-action:pan-y} /* scroll vertical natural; el drag llega por long-press o asa */
