/* ============================================================
   Porra Mundial 2026 · estilos
   Estética: estadio nocturno · verde césped + acento magenta/ámbar
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Antonio:wght@500;600;700&family=Oswald:wght@500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#0a0a0b;            /* negro (identidad oficial 2026) */
  --bg2:#141416;
  --card:#17171a;
  --line:#2c2c31;
  --pitch:#1c7a4a;         /* verde solo para detalles puntuales */
  --pitch-dim:#15613b;
  --ink:#f4f3ee;           /* blanco hueso */
  --muted:#9a9a96;
  --accent:#caa12e;        /* oro/bronce (acento, botones) */
  --accent2:#ffd23f;       /* oro brillante (marca, títulos) */
  --ok:#3ddc84;
  --bad:#ff5a5a;
  --radius:16px;
  --shadow:0 18px 50px -22px rgba(0,0,0,.85);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--ink);
  font-family:'Outfit',system-ui,sans-serif;
  background:
    radial-gradient(1100px 600px at 80% -10%, rgba(255,210,63,.08), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(202,161,46,.08), transparent 55%),
    linear-gradient(rgba(0,0,0,.40), rgba(0,0,0,.40)),                                                /* oscurecido (noche) */
    repeating-linear-gradient(90deg, rgba(0,0,0,.18) 0 240px, rgba(255,255,255,.05) 240px 480px),     /* franjas de corte */
    url('cesped_liso_vivo_2.png') #1a6e2e;                                                             /* textura de césped seamless */
  background-size: auto, auto, auto, auto, 560px;
  background-repeat: no-repeat, no-repeat, no-repeat, repeat, repeat;
  background-attachment: fixed;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}

.wrap{width:100%;max-width:1080px;margin:0 auto;padding:0 20px 80px}

/* ---------- Cabecera ---------- */
header.top{
  position:relative; overflow:hidden;
  padding:34px 24px 34px; text-align:center;
  /* sin césped propio: se ve el del body (fijo) → un único campo continuo */
  background:transparent;
}
header.top .kicker{
  display:inline-block; letter-spacing:.32em; text-transform:uppercase;
  font-size:.72rem; color:var(--accent2); font-weight:700; margin-bottom:10px;
}
/* el kicker bajo el reloj: más grande pero sin ensanchar (acotado a la columna central) */
/* letras de países con la fuente oficial (condensada → ya alta y estrecha) */
header.top .top-center .kicker{font-size:clamp(1.5rem,3vw,2.2rem);margin:0;line-height:1;text-align:center;
  letter-spacing:.1em;display:inline-block;transform:none;padding:0}
header.top h1{
  font-family:'Anton',sans-serif; font-weight:400;
  font-size:clamp(2.6rem,7vw,5rem); line-height:.92; margin:0;
  letter-spacing:.01em; text-transform:uppercase;
}
header.top h1 .em{color:var(--accent2)}   /* 2026 in gold (official 2026 vibe) */
header.top h1.hero{display:flex;align-items:center;justify-content:center;
  gap:clamp(12px,2.5vw,26px);flex-wrap:nowrap;
  max-width:1080px;margin:0 auto;padding:0 20px;box-sizing:border-box}
.hero-cup{height:clamp(72px,10vw,104px);width:auto;flex:none;
  filter:drop-shadow(0 6px 18px rgba(255,210,63,.35))}
.hero-wm{flex:1 1 auto;min-width:0;width:auto;height:auto}
.brand-trophy{height:46px;vertical-align:middle}
header.top p.sub{color:var(--muted);margin:14px auto 0;max-width:1080px;padding:0 20px;box-sizing:border-box}
@media(max-width:680px){header.top p.sub{max-width:560px}}

/* fila bajo el logo: mascotas a la izquierda, reloj a la derecha */
/* fila bajo el título: logos de país (izq) · reloj (centro) · mascotas (der) */
.top-row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  max-width:1080px;margin:6px auto 0;padding:0 20px;flex-wrap:wrap}
.top-row .mascots{margin:0;gap:clamp(3px,.8vw,10px)}
.top-row .mascots img{height:clamp(80px,9.5vw,112px)}
/* logos oficiales de los tres países anfitriones */
.host-logos{display:flex;align-items:center;gap:clamp(8px,1.8vw,22px);margin:0}
.host-logos img{height:clamp(96px,11.5vw,132px);width:auto;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.5));transition:transform .25s ease}
.host-logos img:hover{transform:translateY(-5px) scale(1.04)}
/* columna central: reloj (subido) + kicker debajo */
.top-center{display:flex;flex-direction:column;align-items:center;gap:10px;align-self:flex-start;margin-top:2px}
.top-clock{font-family:'FWC26','Outfit',sans-serif;font-weight:400;
  white-space:nowrap;font-size:clamp(1.6rem,3.1vw,2.3rem);color:var(--accent2);letter-spacing:.04em;
  background:rgba(0,0,0,.42);border:1px solid var(--accent);border-radius:12px;
  padding:13px 18px;box-shadow:0 6px 18px -8px #000;
  min-width:0;text-align:center;box-sizing:border-box}
.top-clock .cd-d{display:inline-block;width:.6em;text-align:center}

/* franja con los colores de las 3 sedes: Canadá (rojo) · México (verde) · EEUU (azul), borde oro */
.flagstrip{height:6px;background:linear-gradient(90deg,
  #d52b1e 0 33%, #006847 33% 66%, #2a4b9b 66% 100%);
  border-bottom:2px solid var(--accent2);
  position:sticky;top:0;z-index:50;}

/* ---------- Barra de info / cuenta atrás ---------- */
.infobar{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:center;
  margin:26px auto 6px;max-width:900px;
}
.chip{
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:10px 18px;font-weight:600;font-size:.92rem;
  display:flex;gap:8px;align-items:center;
}
.chip b{color:var(--accent2)}
.countdown{font-variant-numeric:tabular-nums}

/* ---------- Tarjetas / secciones ---------- */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;margin:22px 0;box-shadow:var(--shadow);
}
.card h2{
  font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;
  letter-spacing:.08em;font-size:1.5rem;margin:0 0 4px;
}
.card h2 .num{color:var(--accent)}
.card .hint{color:var(--muted);font-size:.9rem;margin:0 0 18px}
/* bloques bloqueados en el flujo paso a paso (se revelan al validar el anterior) */
.locked{display:none!important}

/* bloque validado → readonly (no se puede tocar hasta pulsar "Editar") */
.card.ro{position:relative}
.card.ro::after{content:"✓";position:absolute;top:14px;right:18px;
  color:var(--ok);font-weight:800;font-size:1.1rem;opacity:.9}
.card.ro select,.card.ro input,.card.ro .cs-wrap,.card.ro .cs-trigger,
.card.ro #bracketArea,.card.ro #championBox,.card.ro .slot,
.card.ro .third-check,.card.ro .sel-third-check{
  pointer-events:none!important;
}
.card.ro select,.card.ro input,.card.ro .cs-trigger{opacity:.6}
.card.ro #bracketArea,.card.ro #championBox{opacity:.85}

/* pantalla de éxito: logo fusionado con la hierba (de fondo) + banner dorado encima */
.success-hero{position:relative;text-align:center;padding:24px 16px 24px;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.success-logo{
  position:fixed;top:65%;left:50%;transform:translate(-50%,-50%);
  width:min(1080px,94vw);height:auto;z-index:0;pointer-events:none;
  opacity:.38;                      /* fusionado con la hierba: se ve el césped a través */
  animation:successFade 1.1s ease-out both}
.success-content{position:relative;z-index:1}   /* el banner y el botón van encima del logo */
/* mensaje de éxito con el look del banner de campeón: pastilla dorada metálica brillante */
.success-banner{
  display:inline-block;max-width:680px;margin:0 auto 6px;
  color:#3a2c00;font-weight:700;font-size:1.12rem;line-height:1.55;text-align:center;
  padding:18px 28px;border-radius:14px;
  background:linear-gradient(160deg,#fff7c4 0%,#ffd23f 42%,#e6a700 70%,#fff2af 100%);
  box-shadow:0 0 26px rgba(255,210,63,.65),inset 0 3px 7px rgba(255,255,255,.7),inset 0 -4px 8px rgba(120,80,0,.3);
}
.success-banner b{color:#2a2000}
.success-banner a{color:#5a3d00;font-weight:800;text-decoration:underline}
@keyframes successFade{ from{opacity:0} to{opacity:.38} }
@media(prefers-reduced-motion:reduce){.success-logo{animation:none}}
/* en la pantalla de pronóstico registrado sobra el reclamo de la cabecera */
.success-page header.top .sub{display:none}

/* ---------- Toast (avisos de éxito que se ocultan solos) ---------- */
.toast{
  position:fixed;bottom:24px;right:24px;transform:translateX(calc(100% + 24px));
  z-index:200;display:flex;align-items:center;gap:9px;
  background:linear-gradient(160deg,#2faa63,#1c7a4a);color:#fff;font-weight:700;
  padding:12px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.18);
  box-shadow:0 12px 30px -10px rgba(0,0,0,.7);
  opacity:0;pointer-events:none;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .4s ease;
  max-width:min(92vw,520px);font-size:.95rem;
}
.toast.show{opacity:1;transform:translateX(0)}
.toast::before{content:"✓";font-weight:900}
@media(prefers-reduced-motion:reduce){.toast{transition:none}}

/* ---------- Sedes (pósters) ---------- */
.posters{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:720px){.posters{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.posters{grid-template-columns:1fr}}
.poster{margin:0;display:flex;flex-direction:column;gap:8px}
.poster > img{width:100%;height:auto;border-radius:10px;border:1px solid var(--line);
  box-shadow:0 10px 26px -14px #000;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}
.poster > img:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 34px -14px #000}
.poster figcaption .flag-ico{height:18px;margin-right:6px;vertical-align:-4px}
.poster figcaption{text-align:center;font-weight:700;font-size:.86rem;color:var(--ink)}
/* lightbox del póster */
.poster-modal{background:transparent;border:none;padding:0;max-width:none;max-height:none;overflow:visible}
.poster-modal::backdrop{background:rgba(0,0,0,.85)}
.poster-modal img{max-width:92vw;max-height:88vh;width:auto;height:auto;display:block;
  border-radius:12px;box-shadow:0 24px 70px -12px #000;cursor:zoom-out}

/* ---------- Grupos ---------- */
.groups{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media(max-width:860px){.groups{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.groups{grid-template-columns:1fr}}
.group{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:14px}
.group .gtitle{
  font-family:'Anton',sans-serif;letter-spacing:.1em;font-size:1.05rem;
  color:var(--accent2);margin-bottom:10px;display:flex;align-items:center;gap:8px;
}
.group .gtitle .badge{
  background:var(--pitch-dim);color:#fff;border-radius:6px;
  width:26px;height:26px;display:grid;place-items:center;font-size:.9rem;
}
.field{margin:8px 0}
.field label{display:block;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#c7c7c1;margin-bottom:4px}

select,input[type=text],input[type=email],input[type=number],input[type=password],input[type=date]{
  width:100%;background:#000;color:var(--ink);
  border:1px solid var(--line);border-radius:9px;padding:10px 12px;
  font-family:inherit;font-size:.95rem;
}
/* dropdown list options: black background, light text */
select option{background:#000;color:var(--ink)}
select option:checked{background:#16271e}

/* custom dropdown (real black bg, works on Safari too) */
.cs-native{position:absolute!important;width:1px;height:1px;opacity:0;pointer-events:none;clip:rect(0 0 0 0);margin:0}
.cs-wrap{position:relative}
.cs-trigger{width:100%;background:#000;color:var(--ink);border:1px solid var(--line);border-radius:12px;
  padding:10px 34px 10px 12px;font-size:.95rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238fae9c' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center}
.cs-trigger.cs-empty{color:var(--muted)}
.cs-trigger{height:42px;box-sizing:border-box;line-height:20px;display:flex;align-items:center}   /* altura fija y contenido centrado: no salta al abrir el buscador */
.cs-trigger .shirt{height:18px;width:18px;vertical-align:-5px;margin-right:4px}
.flag-ico{height:20px;width:auto;vertical-align:-5px;margin-right:7px;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
/* tamaño de bandera por contexto */
.champion-box .who .flag-ico{height:1.25em;vertical-align:-.22em;margin-right:7px}
.fs-team .flag-ico{height:1.15em;vertical-align:-.2em;margin-right:5px}
.slot .flag-ico{height:18px;vertical-align:-4px;margin-right:6px}
.slot .flag-ico.flag-sm{height:16px;vertical-align:-3px}
.round-final .slot .flag-ico{height:30px;vertical-align:-8px}
.third-place .slot .flag-ico{height:15px;vertical-align:-3px}
.cs-trigger.cs-disabled{opacity:.5;cursor:not-allowed}
.cs-wrap.open .cs-trigger{border-color:var(--line)}
.cs-panel{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;
  background:#000;border:1px solid var(--line);border-radius:12px;max-height:280px;overflow-y:auto;
  box-shadow:0 16px 36px -14px #000;padding:4px}
.cs-wrap.open .cs-panel{display:block}
.cs-panel{scrollbar-width:thin;scrollbar-color:#2c4a39 #000}
.cs-panel::-webkit-scrollbar{width:10px}
.cs-panel::-webkit-scrollbar-track{background:#000;border-radius:0 9px 9px 0}
.cs-panel::-webkit-scrollbar-thumb{background:#2c4a39;border-radius:6px;border:2px solid #000}
.cs-option{padding:9px 12px;border-radius:6px;cursor:pointer;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cs-option:hover,.cs-option.sel{background:#16271e}
.cs-option.cs-placeholder{color:var(--muted)}
.cs-input{width:100%;background:transparent;border:none;outline:none;color:var(--ink);
  font:inherit;padding:0;margin:0}
.cs-input::placeholder{color:var(--muted)}

/* validación: resalta campo en rojo + modal de aviso */
.cs-trigger.invalid,select.invalid,input.invalid{
  border-color:var(--bad)!important;box-shadow:0 0 0 2px rgba(229,72,72,.35)!important}
.msg-dialog{max-width:440px}
.msg-dialog .msg-text{font-size:1.05rem;color:var(--ink);margin:2px 0 18px;line-height:1.5}
.msg-dialog .dialog-close{display:flex;justify-content:center}

/* modal resumen antes de enviar */
.confirm-dialog{max-width:880px}
.confirm-dialog .summary{margin:6px 0 4px}
.sum-row{display:flex;justify-content:space-between;gap:14px;padding:9px 2px;border-bottom:1px solid var(--line)}
.sum-row span{color:var(--muted)}
.sum-row b{color:var(--ink);text-align:right;display:inline-flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.sum-trophy{height:1.1em;vertical-align:-.15em;margin:0 .15em}
.sg-val .shirt{height:24px;width:24px;vertical-align:-7px}
.sg-val{color:var(--ink)}
.sum-sec{margin:9px 0 4px;color:var(--accent2);font-weight:700;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.06em}
/* datos/pronóstico: icono | etiqueta | valor  (×2 por fila) */
.sum-grid{display:grid;grid-template-columns:auto auto 1fr auto auto 1fr;gap:4px 10px;align-items:baseline;font-size:.84rem}
.sg-icon{white-space:nowrap;text-align:center}
.sg-label{font-weight:700;color:var(--accent2);white-space:nowrap}
.sg-val{color:var(--ink)}
.sg-val.sg-wide{grid-column:3 / -1}
/* grupos: etiqueta | 1º | 2º  (×2 por fila), con cabecera */
.sum-grid-groups{display:grid;grid-template-columns:auto 1fr 1fr auto 1fr 1fr;gap:3px 14px;align-items:baseline;font-size:.84rem}
.sum-grid-groups .sg-h{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.sum-divider{height:1px;background:var(--line);margin:9px 0}
@media(max-width:600px){
  .sum-grid{grid-template-columns:auto auto 1fr}
  .sum-grid-groups{grid-template-columns:auto 1fr 1fr}
  .sg-hcell{display:none}                     /* sin cabecera 1º/2º en móvil (1 grupo por fila) */
  .rules-dialog{padding:20px 16px}
  .confirm-actions{justify-content:stretch}
  .confirm-actions .btn{flex:1}
}
.sum-thirds{font-size:.9rem;color:var(--ink);line-height:1.6}
.sum-thirds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px 16px;font-size:.84rem;color:var(--ink)}
@media(max-width:600px){.sum-thirds-grid{grid-template-columns:repeat(2,1fr)}}
.confirm-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:12px;flex-wrap:wrap}
.confirm-dialog h2{margin-bottom:2px}
.confirm-dialog .hint{margin-bottom:8px}
@media(max-width:520px){.sum-grid{grid-template-columns:1fr}}
/* shirt icon + number inside the player dropdown */
.shirt{vertical-align:-10px;margin-right:6px}
select:focus,input:focus{outline:none;border-color:var(--accent)}
/* custom chevron (the native one looks off on the dark theme) */
select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  padding-right:34px;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238fae9c' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
select:disabled{opacity:.5;cursor:not-allowed}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px}
.row-final{display:grid;grid-template-columns:1fr 120px 120px 1fr;gap:12px;align-items:end}
.row-final > .field label{white-space:nowrap}   /* títulos de goles en una sola línea */
/* barra de filtros de la tabla de pronósticos */
.tbl-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 16px}
.tbl-filters #fSearch{flex:1 1 180px;min-width:150px}   /* flexible: cede espacio para que todo quepa en una fila */
.tbl-filters select,.tbl-filters .cs-wrap{width:auto;min-width:140px;flex:none}
/* el select se convierte en .cs-wrap (dropdown custom); el ancho hay que darlo al wrap visible */
.tbl-filters .cs-wrap:has(#fState){width:188px;min-width:188px}   /* "✅ Validados" no se corta */
.tbl-filters input[type=date]{width:auto;min-width:138px;color-scheme:dark}  /* calendario nativo en modo oscuro */
.tbl-filters input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.8)}  /* icono visible sobre fondo negro */
.tbl-filters .tbl-count{margin-left:auto;color:var(--muted);font-size:.85rem;font-variant-numeric:tabular-nums;white-space:nowrap}

.row-actions{white-space:nowrap}
.row-actions .btn{white-space:nowrap}                          /* el texto del botón no se parte en 2 líneas */
.row-actions form:first-child .btn{min-width:172px;text-align:center}  /* "Validar"/"Desvalidar" ocupan igual → no salta */
.row-actions form + form{margin-left:10px}       /* separa "validar" del botón de borrar */
.row-scorer{display:grid;grid-template-columns:minmax(0,1fr) 120px 120px minmax(0,1fr);gap:12px;align-items:end}
.row-scorer > .field label{white-space:nowrap}   /* título de goles del goleador en una línea */
.row-scorer .cs-wrap,.row-scorer .cs-trigger{min-width:0}

/* ---------- Cuadro eliminatorio ---------- */
.bracket-note{color:var(--muted);font-size:.88rem;margin-bottom:16px}
.bracket{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px}
.round{flex:1 0 130px;min-width:0;display:flex;flex-direction:column}
.round-head{height:34px;flex:none}
.round-body{flex:1;display:flex;flex-direction:column;justify-content:space-around}
/* the final stands out (bigger), with the 3rd-place play-off tucked right below it */
.round-final{flex:1 0 210px;margin-right:10px}   /* wider base; same grow → doesn't steal width from the others */
.round-final .round-body{justify-content:center}
.round-final .slot{font-size:1.35rem;padding:10px 12px;font-weight:700}
.round-final .fl{font-size:2.6rem}
/* gold label above the final tie (mirrors the 3rd-place label) */
.fp-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent2);
  text-align:center;margin-bottom:6px;font-weight:700}
.third-place{margin-top:20px}
.third-place .tp-title{font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);text-align:center;margin-bottom:5px}
.third-place .slot{font-size:1.0rem;padding:4px 7px;font-weight:400}
.third-place .fl{font-size:.9rem}

/* final score selector */
.final-score{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:10px 0 4px}
.fs-team{font-family:'Anton',sans-serif;font-size:1.05rem;min-width:130px;text-align:center;color:var(--ink);
  padding:6px 14px;border-radius:10px;font-weight:700;letter-spacing:.1em}
.fs-team{display:inline-flex;align-items:center;justify-content:center;gap:5px}
.fs-team .trophy-ico{height:22px;margin-right:0}
#fsChampion{color:#3a2c00;background:linear-gradient(160deg,#fff7c4 0%,#ffd23f 42%,#e6a700 70%,#fff2af 100%);
  box-shadow:0 0 14px rgba(255,210,63,.5),inset 0 2px 6px rgba(255,255,255,.7),inset 0 -3px 7px rgba(120,80,0,.3)}
#fsRunnerUp{color:#f3f6f8;background:linear-gradient(160deg,#cdd5db 0%,#7e8893 42%,#39444d 70%,#b3bcc2 100%);
  box-shadow:0 0 12px rgba(110,122,133,.4),inset 0 2px 6px rgba(255,255,255,.55),inset 0 -3px 7px rgba(0,0,0,.3);text-shadow:0 1px 2px rgba(0,0,0,.45)}
.fs-goals{width:66px;text-align:center}
.final-score .cs-wrap{flex:none;width:74px}
.final-score .cs-trigger{text-align:right}
.fs-sep{font-size:1.3rem;color:var(--muted)}
.round-title{font-family:'Anton',sans-serif;letter-spacing:.14em;color:var(--accent2);
  text-transform:uppercase;font-size:.85rem;text-align:center;margin-bottom:4px}
.tie{background:var(--bg2);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.slot{
  display:flex;align-items:center;gap:5px;padding:4px 7px;cursor:pointer;min-width:0;
  border-bottom:1px solid var(--line);font-size:1.0rem;transition:background .15s;
  user-select:none;
}
.slot span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.slot:last-child{border-bottom:none}
.slot:hover{background:#16271e}
.slot.empty{color:var(--muted);cursor:default;font-style:italic}
.slot.empty:hover{background:transparent}
.slot.sel{background:linear-gradient(90deg,rgba(255,210,63,.22),transparent);font-weight:700}
.slot .fl{font-size:.9rem}
/* highlight the final so it's clear you click your champion there */
.round-final .tie{border-color:var(--accent2);box-shadow:inset 0 0 0 1px var(--accent2)}
.slot-trophy{height:50px;flex:none}
.slot-medal{flex:none;font-size:1.1em}
.champion-box{
  margin-top:16px;text-align:center;background:linear-gradient(135deg,var(--pitch-dim),#0c1812);
  border:1px solid var(--pitch);border-radius:12px;padding:18px;
}
.cb-main{display:flex;gap:14px;align-items:flex-start;justify-content:center;flex-wrap:wrap;max-width:100%}
.cb-slot{display:flex;flex-direction:column;text-align:center;flex:0 0 auto;min-width:0}
.cb-champ{flex:1 1 auto;min-width:25%;max-width:40%}   /* champion: 25–40% wide; others fit their content */
.champion-box .lbl{text-transform:uppercase;letter-spacing:.08em;font-size:.64rem;color:var(--accent2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}
.trophy-ico{height:30px;margin-right:8px;flex:none}
.bflag{font-size:1.45em;vertical-align:-3px}   /* flag emoji bigger than the text */
#runnerUpName .bflag,#thirdName .bflag,#fourthName .bflag{margin-right:6px}
.champion-box .who{font-family:'Anton',sans-serif}
/* badges fill their slot — widths distributed 40/25/20/15, same height, spaced letters */
#championName,#runnerUpName,#thirdName,#fourthName{display:flex;align-items:center;justify-content:center;
  width:auto;height:52px;padding:0 22px;border-radius:12px;font-weight:700;font-size:1.35rem;letter-spacing:.07em;
  box-sizing:border-box;white-space:nowrap;overflow:hidden}
#championName{width:100%;font-size:1.6rem;color:#3a2c00;background:linear-gradient(160deg,#fff7c4 0%,#ffd23f 42%,#e6a700 70%,#fff2af 100%);
  box-shadow:0 0 26px rgba(255,210,63,.65),inset 0 3px 7px rgba(255,255,255,.7),inset 0 -4px 8px rgba(120,80,0,.3)}
#runnerUpName{color:#f3f6f8;background:linear-gradient(160deg,#cdd5db 0%,#7e8893 42%,#39444d 70%,#b3bcc2 100%);
  box-shadow:0 0 15px rgba(110,122,133,.45),inset 0 3px 7px rgba(255,255,255,.55),inset 0 -4px 8px rgba(0,0,0,.3);text-shadow:0 1px 2px rgba(0,0,0,.45)}
#thirdName{color:#2a1600;background:linear-gradient(160deg,#ffd0a0 0%,#c87f3c 42%,#8f561f 70%,#e8b182 100%);
  box-shadow:0 0 15px rgba(200,127,60,.55),inset 0 3px 7px rgba(255,255,255,.5),inset 0 -4px 8px rgba(60,30,0,.3)}
#fourthName{border:1px solid var(--line);color:var(--ink)}
.cb-minor{display:flex;gap:14px;align-items:flex-start}
/* shiny medals on the bracket slots (champion/runner-up in the final, 3rd-place winner) */
.slot.slot-gold{background:linear-gradient(135deg,#fff3b0,#ffd23f 45%,#e6a700);color:#3a2c00;font-weight:700;
  box-shadow:inset 0 0 18px rgba(255,210,63,.55)}
.slot.slot-silver{background:linear-gradient(135deg,#cdd5db,#9aa6af 50%,#7c8893);color:#10171c;font-weight:700}
.slot.slot-bronze{background:linear-gradient(135deg,#f0b27a,#c87f3c 50%,#a86327);color:#2a1600;font-weight:700}
.slot.slot-gold:hover,.slot.slot-silver:hover,.slot.slot-bronze:hover{filter:brightness(1.05)}

/* ---------- Botón ---------- */
.btn{
  appearance:none;-webkit-appearance:none;
  display:inline-block;background:var(--accent);color:#1f1803;border:none;font-weight:700;
  font-family:'Anton',sans-serif;letter-spacing:.12em;text-transform:uppercase;
  font-size:1.05rem;line-height:1.25;padding:14px 34px;border-radius:12px;cursor:pointer;
  text-align:center;box-shadow:0 12px 30px -12px var(--accent);transition:transform .12s,filter .12s;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);text-decoration:none}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink);box-shadow:none}
.btn.amber{background:var(--accent2);color:#221a00;box-shadow:0 12px 30px -12px var(--accent2)}
.center{text-align:center}

/* ---------- Tabla puntuación / clasificación ---------- */
table.tabla{width:100%;border-collapse:collapse;font-size:.95rem}
table.tabla th,table.tabla td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line)}
table.tabla th{color:var(--muted);text-transform:uppercase;font-size:.72rem;letter-spacing:.08em}
table.tabla tr:hover td{background:#16271e}
table.tabla td.pts{font-family:'Anton',sans-serif;color:var(--accent2);font-size:1.05rem;text-align:right}
.rank{font-family:'Anton',sans-serif;color:var(--accent);width:42px}
.rank.top1{color:#ffd23f}.rank.top2{color:#cfd8dc}.rank.top3{color:#e0915a}
.scoring{display:grid;grid-template-columns:1fr auto;gap:6px 18px;max-width:520px}
.scoring .c{color:var(--muted)} .scoring .p{font-weight:700;color:var(--accent2);text-align:right}

/* ---------- Navegación superior ---------- */
nav.menu{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:22px}
nav.menu a{background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:8px 18px;color:var(--ink);font-weight:600;font-size:.9rem}
nav.menu a:hover{border-color:var(--accent);text-decoration:none}
nav.menu a.active{background:var(--accent);color:#1f1803;border-color:var(--accent)}

/* ---------- Avisos ---------- */
.alert{border-radius:12px;padding:14px 18px;margin:18px 0;border:1px solid}
.alert.ok{background:rgba(61,220,132,.1);border-color:var(--ok);color:#bdf5d4}
.alert.warn{background:rgba(255,210,63,.1);border-color:var(--accent2);color:#ffe9a3}
.alert.err{background:rgba(255,90,90,.1);border-color:var(--bad);color:#ffc9c9}

footer{margin-top:auto;text-align:center;color:var(--muted);font-size:.82rem;
  padding:18px 20px 14px}
.mascots{display:flex;justify-content:center;align-items:flex-end;gap:clamp(16px,5vw,56px);margin:18px 0 4px}
.mascots figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:6px}
.mascots img{height:clamp(74px,11vw,118px);width:auto;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.5));transition:transform .25s ease}
.mascots figure:hover img{transform:translateY(-6px) scale(1.04)}
.mascots figcaption{font-size:.8rem;font-weight:700;color:var(--text);letter-spacing:.02em}
.mascots figcaption .flag-ico{height:15px;width:auto;margin-right:4px;vertical-align:-3px;filter:none}

/* sticky progress bars (groups & thirds) */
.progress-bars{position:sticky;top:8px;z-index:5;display:flex;gap:18px;flex-wrap:wrap;
  background:var(--bg);padding:12px 0 14px;margin-bottom:10px;border-bottom:1px solid var(--line)}
.pbar{flex:1;min-width:200px}
.pbar-label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:5px;font-weight:700}
.pbar-track{height:9px;background:var(--bg2);border:1px solid var(--line);border-radius:99px;overflow:hidden}
.pbar-fill{height:100%;width:0;background:var(--accent2);border-radius:99px;transition:width .25s}
.pbar-fill.thirds{background:var(--accent)}

/* group validation feedback */
.group.group-ok{border-color:var(--accent2)}
.group.group-bad{border-color:var(--bad)!important;box-shadow:0 0 0 3px rgba(255,90,90,.55)!important}

/* third-placed pick inside each group */
.third-row{margin-top:10px;padding-top:10px;border-top:1px dashed var(--line)}
.third-check{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);
  text-transform:none;letter-spacing:0;margin-bottom:6px;cursor:pointer}
.third-check input{width:auto}
.sel-third:disabled{opacity:.45}

/* collapsible "Rules" card */
details.rules{padding:0;overflow:hidden}
details.rules summary{cursor:pointer;list-style:none;padding:18px 22px;font-family:'Anton',sans-serif;
  letter-spacing:.04em;font-size:1.15rem;color:var(--accent2);
  display:flex;align-items:center;justify-content:space-between;gap:10px}
details.rules summary::-webkit-details-marker{display:none}
details.rules summary::after{content:'▾';color:var(--muted);font-size:.85rem}
details.rules[open] summary::after{content:'▴'}
details.rules .rules-body{padding:0 22px 22px}
details.rules .rules-body h2{margin-top:0}

/* left sidebar layout */
.layout{display:flex;align-items:flex-start;min-height:calc(100vh - 8px)}
.sidebar{width:190px;flex-shrink:0;position:sticky;top:0;height:calc(100vh - 8px);
  background:rgba(20,20,22,.8);border-right:1px solid var(--line);   /* panel al 80%: deja ver el césped del fondo */
  display:flex;flex-direction:column;padding:22px 14px}
.side-top{display:flex;align-items:center;justify-content:center;margin-bottom:26px}
.sidebar .brand{display:flex;align-items:center;gap:9px;justify-content:center;
  font-family:'Anton',sans-serif;letter-spacing:.04em;color:var(--ink);text-decoration:none}
.brand-txt{font-size:1.1rem;line-height:.95;text-transform:uppercase}
.brand-txt .num{color:var(--accent2)}
.brand-logo{width:100%;max-width:155px;height:auto;display:block}
.hamburger{display:none;background:none;border:1px solid var(--line);color:var(--ink);
  border-radius:8px;font-size:1.3rem;line-height:1;padding:4px 11px;cursor:pointer}
.side-nav{display:flex;flex-direction:column;gap:6px}
.side-nav a,.side-nav .side-link{padding:11px 14px;border-radius:10px;color:var(--ink);font-weight:600;font-size:.95rem;
  display:flex;align-items:center;gap:10px}
.side-nav a:hover,.side-nav .side-link:hover{background:var(--card);text-decoration:none}
.side-nav a.active{background:var(--accent);color:#1f1803}
.side-nav .side-link{background:none;border:none;width:100%;text-align:left;cursor:pointer;font-family:inherit}
.side-nav .disabled{opacity:.4;cursor:not-allowed}

/* rules modal */
.rules-dialog{background:var(--bg2);color:var(--ink);border:1px solid var(--line);border-radius:16px;
  padding:28px 32px;max-width:760px;width:92%;max-height:90vh;overflow-y:auto}
.rules-dialog .scoring{max-width:none}
.rules-dialog::backdrop{background:rgba(0,0,0,.6)}
.rules-dialog h2{margin-top:0}
.dialog-close{margin-top:18px;text-align:right}
.howto{margin:0;padding-left:20px;line-height:1.7}
.howto li{margin-bottom:8px}
.howto b{color:var(--accent2);font-weight:600}
.side-foot{margin-top:auto;padding-top:20px;display:flex;flex-direction:column;gap:14px}
.side-nav-admin{padding:11px 14px;border-radius:10px;color:var(--ink);font-weight:600;font-size:.95rem;
  display:flex;align-items:center;gap:10px;border:1px dashed var(--line)}
.side-nav-admin:hover{background:var(--card);text-decoration:none}
.side-nav-admin.active{background:var(--accent);color:#1f1803;border-style:solid;border-color:var(--accent)}
/* sub-opción de Admin: cerrar sesión */
.side-sublink{margin-top:-8px;padding:7px 14px 7px 30px;border-radius:8px;
  color:var(--muted);font-size:.85rem;display:flex;align-items:center;gap:8px}
.side-sublink:hover{background:var(--card);color:var(--ink);text-decoration:none}
.content{flex:1;min-width:0;display:flex;flex-direction:column;min-height:calc(100vh - 8px)}

/* language switcher (in the sidebar foot) — flag emojis */
.langswitch{display:flex;gap:10px;justify-content:center}
.langswitch a{font-size:1.5rem;line-height:1;opacity:.4;filter:grayscale(.5);transition:opacity .12s,filter .12s}
.langswitch a:hover{opacity:.85;filter:grayscale(0)}
.langswitch a.active{opacity:1;filter:none}

/* sidebar collapses to a top bar on small screens */
@media(max-width:720px){
  .layout{flex-direction:column}
  .sidebar{width:auto;height:auto;position:static;padding:10px 16px}
  .side-top{margin:0;justify-content:space-between}
  .sidebar .brand{font-size:1.3rem}
  .hamburger{display:block}
  .side-nav,.side-foot{display:none;width:100%}
  .sidebar.open .side-nav{display:flex;flex-direction:column;margin-top:10px}
  .sidebar.open .side-foot{display:flex;margin-top:8px;padding-top:8px}
}

@media(max-width:560px){
  .row3,.row-scorer,.row-final{grid-template-columns:1fr}
  .card{padding:18px}
  .cb-main{flex-wrap:wrap;overflow-x:visible}
  .cb-minor{border-left:none;padding-left:0}
}

/* ===== Fuente display oficial: FWC2026 UltraCondensed Black ===== */
@font-face{font-family:'FWC26';src:url('fwc26/FWC2026-UltraCondensedBlack.8e6ba053.ttf') format('truetype');font-display:swap}
.card h2,.group .gtitle,.fs-team,.round-title,.champion-box .who,
table.tabla td.pts,.rank,.btn,.sidebar .brand,header.top h1,.top-center .kicker{
  font-family:'FWC26',sans-serif !important;
  font-weight:400 !important;
}
