:root{
  --acc:#c6ff2e;--acc-2:#19e3ff;--acc-3:#ff3d7f;--on-acc:#04140a;
  /* ===== Paleta "cancha" (verde oscuro estilo césped de fútbol). =====
     Para REVERTIR al gris-negro original descomentar la línea de abajo
     y comentar la actual (los valores originales están preservados):
       --bg:#0d0d0f;--bg-2:#141417;...
     y borrar `display:none` de #modeToggle (más abajo). */
  --bg:#0a1f12;--bg-2:#0e2a17;--surface:rgba(140,255,180,.045);--surface-2:rgba(140,255,180,.075);
  --text:#f4f5f0;--text-dim:rgba(244,245,240,.65);--line:rgba(180,255,200,.13);--nav-bg:rgba(10,31,18,.86);
  /* --- Paleta original (gris-negro) — comentada por si querés revertir ---
  --bg:#0d0d0f;--bg-2:#141417;--surface:rgba(255,255,255,.04);--surface-2:rgba(255,255,255,.07);
  --text:#f4f5f0;--text-dim:rgba(244,245,240,.62);--line:rgba(255,255,255,.1);--nav-bg:rgba(13,13,15,.85); */
  --acc-text:color-mix(in srgb,var(--acc) 72%,var(--text) 28%);
  --acc2-text:color-mix(in srgb,var(--acc-2) 72%,var(--text) 28%);
}
/* Avatares cartoon — el SVG llena el contenedor en círculo. Los containers que
   ya tienen w/h+border-radius+overflow:hidden lo recortan con esquinas redondas. */
.fb-avatar{position:relative;line-height:0;vertical-align:middle;border-radius:50%;overflow:hidden}
.fb-avatar svg{width:100%;height:100%;display:block}
.fb-avatar-legacy{line-height:1}

html[data-mode="light"]{
  --bg:#f3f4ee;--bg-2:#e9ebe0;--surface:rgba(0,0,0,.04);--surface-2:rgba(0,0,0,.07);
  --text:#15170f;--text-dim:rgba(21,23,15,.6);--line:rgba(0,0,0,.12);--nav-bg:rgba(243,244,238,.85);
  /* En light mode mezclamos MÁS con --text (que es oscuro) para forzar contraste. */
  --acc-text:color-mix(in srgb,var(--acc) 45%,var(--text) 55%);
  --acc2-text:color-mix(in srgb,var(--acc-2) 45%,var(--text) 55%);
}
*{margin:0;padding:0;box-sizing:border-box}
/* Touch UX: elimina el 300ms tap-delay en móviles y limpia el flash gris
   de iOS/Android. Aplicado a controles para no afectar texto seleccionable. */
button,a,input,select,textarea,[role="button"]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
/* Fondo "aurora" — gradientes radiales superpuestos en distintos lugares,
   color levemente teñido al acento del tema. Modo: visual moderno tipo
   "vapor", sin patrón repetitivo de líneas. Para REVERTIR a césped verde:
   restaurar el bloque anterior con `repeating-linear-gradient(180deg,...)`. */
body{
  font-family:'Archivo',sans-serif;color:var(--text);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;transition:background .5s,color .5s;
  background:var(--bg);
}
/* Capa de "granito" / noise textil sutil para que el fondo no se vea
   demasiado plano (1px stipple pattern). Generado con linear gradients. */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;
  background-image:
    radial-gradient(circle at 25% 25%,rgba(255,255,255,.025) 1px,transparent 1.5px),
    radial-gradient(circle at 75% 75%,rgba(255,255,255,.02) 1px,transparent 1.5px);
  background-size:32px 32px,42px 42px;
  background-position:0 0,16px 16px;
}
/* Background decorativo por página (noticias, estadios). Vive detrás del
   contenido principal, fixed, no captura clicks. Hereda color del tema vía
   `currentColor` y opacidad baja. */
.page-decor{position:fixed;inset:0;pointer-events:none;z-index:0;color:var(--acc-text);opacity:.5;mix-blend-mode:screen}
.page-decor svg{width:100%;height:100%;display:block}
.page-bg-news  .page-decor{opacity:.4}
.page-bg-stad  .page-decor{opacity:.45}
.page-bg-cal   .page-decor{opacity:.42}
.page-bg-stats .page-decor{opacity:.4}
/* Asegurar que el contenido real quede por encima de la decoración (page-decor
   tiene z-index:0). NO incluimos .modal-bg ni .fb-modal-lay acá: esos tienen
   que mantener su position:fixed para overlayar el viewport entero.
   Si se incluyen, el modal pasa a estar en document flow y "no se ve nada"
   al clickear sobre estadios / grupos / etc. */
body > nav, body > section, body > footer{position:relative;z-index:1}
@media (max-width:760px){
  .page-decor{opacity:.28}
}
/* Toggle modo claro/oscuro — OCULTO (modo único cancha). Para REVERTIR borrar este bloque. */
#modeToggle{display:none !important}
::selection{background:var(--acc);color:var(--on-acc)}

/* === iOS SAFARI ZOOM FIX (GLOBAL) ========================================
   iOS hace zoom automático al enfocar un input con font-size < 16px y NO
   vuelve a unzoom. Esto se ve como "tenés que pinch-zoom para volver".
   Solución universal: TODOS los inputs/textareas con font-size:16px mínimo
   en mobile. Se aplica a chat en vivo, chat de grupos, formularios de
   login, registro, prode, prediccion, y cualquier input futuro. */
@media (max-width:760px){
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="search"],
  input[type="tel"],
  input[type="url"],
  input:not([type]),
  textarea,
  select,
  #inp,
  .gp-chat-input,
  .pi-row input,
  .auth-email-form input,
  .g-action input,
  .sim-match input,
  .sim-table input,
  .pm-input,
  .pm-scores .pm-input,
  .search-wrap input,
  .tk-identity-register .pi-row input,
  .custom-amount input{font-size:16px !important}
  /* Inputs de "chat en vivo" (chat.html) — específico para no romper el visual */
  #inp{padding:13px 18px !important;border-radius:24px !important}
  /* Tap targets globales: cualquier botón de envío con ≥44px */
  .btn,button[type="submit"]{min-height:44px}
  /* Sin scroll horizontal accidental en ninguna página */
  html,body{max-width:100vw;overflow-x:hidden}
  body{overscroll-behavior-x:none}
  /* Smooth scroll touch en cualquier scrollable */
  .gp-chat-list,.gp-chat-body,.chat-list,.muro-list,.scroll-touch{-webkit-overflow-scrolling:touch}
}
a{color:inherit}
/* El atributo HTML `hidden` debe ganarle a display:flex/inline-flex. */
[hidden]{display:none !important}

/* Logo decorativo (footer) — el navbar usa .pill-logo aparte */
.logo{display:flex;align-items:center;gap:7px;font-style:italic;font-weight:900;font-size:26px;letter-spacing:-1px;color:var(--text);text-decoration:none}
.logo-ball{width:auto;height:48px;flex:none;object-fit:contain;display:block}
.logo-wrap{position:relative;display:inline-flex;flex-direction:column;align-items:center}
.crown{display:flex;gap:2px;margin-bottom:2px;height:9px}
.crown i{width:7px;height:9px;clip-path:polygon(50% 0,100% 100%,0 100%);display:block}
.crown i:nth-child(1){background:#006847}.crown i:nth-child(2){background:#fff}
.crown i:nth-child(3){background:#ce1126}.crown i:nth-child(4){background:#3c3b6e}.crown i:nth-child(5){background:#ff0000}

/* ============================================================
   NAVBAR — Píldora flotante (reemplaza el navbar barra de antes)
   Estructura: logo + nav (7 links) + tools (live + modo + tema +
   idioma + perfil/entrar). Responsive: <860px hamburguesa.
   ============================================================ */
/* Wrapper nav: FIJO arriba (no sticky) — sticky se rompía con overflow del body
   en mobile y dejaba al user sin acceso al menú al scrollear. Con fixed + alto
   z-index, el navbar SIEMPRE está accesible. La hamburguesa hereda este z-index. */
nav#nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0;transition:background .25s,border-color .25s;background:transparent;border:none}
/* === Navbar — desktop con tamaños originales, mobile achicado === */
/* Desktop: tamaños iguales a los originales (height 72 / brand 54 / gap 13) */
body{padding-top:72px}
@media (max-width:920px){
  /* Tablet: navbar más compacto */
  .navbar{height:54px !important;padding:0 14px !important}
  .nav-brand{gap:7px !important;margin-right:14px !important}
  .nav-brand img{height:38px !important}
  .nav-brand .bn{font-size:18px !important;letter-spacing:-.3px}
  body{padding-top:54px}
  .nav-links{top:54px !important;max-height:calc(100vh - 54px) !important}
}
@media (max-width:560px){
  /* Mobile: navbar mini con Fulbazo pegado al logo */
  .navbar{height:50px !important;padding:0 10px !important;gap:6px !important;justify-content:space-between !important}
  .nav-brand{gap:5px !important;margin-right:auto !important;flex:0 1 auto !important;min-width:0 !important}
  .nav-brand img{height:32px !important}
  .nav-brand .bn{font-size:15px !important}
  body{padding-top:50px}
  .nav-links{top:50px !important;max-height:calc(100vh - 50px) !important}
  .nav-tools{gap:5px !important;flex:0 0 auto !important;align-items:center !important}
}
/* === Mobile profile pill: ocultar @username, dejar SOLO avatar + flechita.
   Tamaños balanceados para que se vea proporcional a "TU CUENTA" (logged out)
   y no queden huecos raros cuando estás logueado. */
@media (max-width:760px){
  .profile-pill .pp-name{display:none !important}
  .profile-pill{padding:4px 10px 4px 4px !important;gap:5px !important}
  .profile-pill .pp-av{width:28px !important;height:28px !important}
  .profile-pill .pp-chev{width:13px;height:13px;opacity:.85}
}
@media (max-width:420px){
  .profile-pill{padding:3px 8px 3px 3px !important;gap:4px !important}
  .profile-pill .pp-av{width:26px !important;height:26px !important}
}
/* === Z-INDEX FIX: dropdown del profile NO se ponga detrás del menú hamburguesa.
   .nav-links abierto está en z:99 pero como es position:fixed, crea stacking
   context que aisla. Para que el profile-menu (z:160) gane, hay que subir
   z-index del padre .nav-tools por encima de nav-links. */
.nav-tools{position:relative;z-index:101}
.profile-menu{z-index:200 !important}
/* === HAMBURGUESA: SIEMPRE visible y CENTRADA, con buen contraste === */
@media (max-width:920px){
  .nav-burger{display:inline-flex !important;flex:0 0 auto;width:38px !important;height:38px !important;align-items:center !important;justify-content:center !important;align-self:center !important;background:color-mix(in srgb,var(--text) 8%,transparent) !important;border:1px solid color-mix(in srgb,var(--text) 18%,var(--line)) !important;border-radius:9px !important;color:var(--text) !important;cursor:pointer;padding:0 !important;margin:0 0 0 4px !important;order:99}
  .nav-burger:hover,.nav-burger:focus-visible{background:color-mix(in srgb,var(--acc) 20%,transparent) !important;border-color:var(--acc) !important}
  .nav-burger svg{width:22px !important;height:22px !important;stroke:currentColor;stroke-width:2.5 !important;display:block !important}
}
@media (max-width:560px){
  .nav-burger{width:34px !important;height:34px !important;margin:0 0 0 2px !important;align-self:center !important}
  .nav-burger svg{width:19px !important;height:19px !important}
}

/* === NAVBAR RECTO === */
.navbar{display:flex;align-items:center;gap:6px;padding:0 28px;height:72px;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
html[data-mode="light"] .navbar{background:rgba(255,255,255,.92)}

/* Marca (logo + Fulbazo) */
.nav-brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--text);margin-right:24px;flex:0 0 auto}
.nav-brand img{height:54px;width:auto;display:block;object-fit:contain}
.nav-brand .bn{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:26px;letter-spacing:-.5px;color:var(--text)}

/* Links (tira del medio) */
.nav-links{display:flex;align-items:center;gap:0;height:100%;flex:1 1 auto;min-width:0}
.nav-link{position:relative;display:flex;align-items:center;gap:5px;height:100%;padding:0 16px;font-family:'Archivo',sans-serif;font-size:15px;font-weight:700;color:var(--text-dim);text-decoration:none;border-bottom:3px solid transparent;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
.nav-link:hover{color:var(--text)}
.nav-link.active{color:var(--text);border-bottom-color:var(--acc)}
/* Dot rojo al lado de "Chat en vivo" — SIEMPRE visible y SIEMPRE pulsando.
   Indica que esa sección es "en vivo" 24/7. Cuando hay partidos en juego,
   el dot pulsa más fuerte (clase .live) pero igual está siempre pulsando
   de fondo así nunca queda apagado. */
.nav-live-dot{
  display:inline-block;width:9px;height:9px;border-radius:50%;
  background:#ef4444;margin-left:6px;flex:none;vertical-align:middle;
  box-shadow:0 0 0 0 rgba(239,68,68,.6);
  animation:navLivePulse 1.8s ease-in-out infinite;
}
.nav-live-dot.live{animation:navLivePulse 1s ease-in-out infinite}
@keyframes navLivePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.55);transform:scale(1)}
  50%   {box-shadow:0 0 0 8px rgba(239,68,68,0);transform:scale(1.25)}
}
.nav-link .chev{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2;transition:transform .2s}

/* Submenú "Partidos" — hover/focus → desplegable.
   El .nav-link del "Partidos" tiene una mini línea punteada debajo del
   chevron para insinuar al user "hay más abajo". */
.has-dd{position:relative;height:100%;display:flex;align-items:center}
.has-dd > .nav-link::after{content:'';position:absolute;left:50%;bottom:18px;transform:translateX(-50%);width:18px;height:2px;background:repeating-linear-gradient(90deg,currentColor 0,currentColor 3px,transparent 3px,transparent 6px);opacity:.45;transition:.15s}
.has-dd:hover > .nav-link::after,.has-dd.open > .nav-link::after,.has-dd.active > .nav-link::after{opacity:.95;color:var(--acc-text)}
.dd-menu{position:absolute;top:calc(100% - 1px);left:0;min-width:215px;background:color-mix(in srgb,var(--bg) 96%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:0 0 12px 12px;box-shadow:0 18px 40px rgba(0,0,0,.45);padding:7px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .15s,transform .15s,visibility .15s;z-index:120}
html[data-mode="light"] .dd-menu{background:rgba(255,255,255,.98);box-shadow:0 12px 32px rgba(0,0,0,.12)}
/* Dropdown abre SOLO con hover (mouse) o explícito .open (JS / mobile).
   Removido :focus-within porque cualquier programático focus de elementos
   internos lo disparaba — causaba que se abriera "solo" cuando el user
   estaba en otra parte del prode/grupos sin tocar el nav. */
.has-dd:hover .dd-menu,.has-dd.open .dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
.has-dd:hover .chev,.has-dd.open .chev{transform:rotate(180deg)}
.dd-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--text-dim);text-decoration:none;cursor:pointer;transition:.12s}
.dd-item:hover{background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--text)}
.dd-item.active{background:color-mix(in srgb,var(--acc) 22%,transparent);color:var(--acc-text)}
.dd-item .di{width:18px;height:18px;stroke:var(--acc-text);flex:none}
html[data-mode="light"] .dd-item .di{stroke:var(--acc-text)}

/* Tools a la derecha */
.nav-tools{display:flex;align-items:center;gap:8px;flex:0 0 auto;margin-left:8px;position:relative}

/* === SEGMENTED GLASS CLUSTER (tema + idioma + perfil unificados) === */
.nav-cluster{position:relative;display:flex;align-items:center;gap:0;padding:4px;border-radius:999px;background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--acc) 18%,rgba(255,255,255,.06)),0 0 0 .5px color-mix(in srgb,var(--acc) 10%,transparent),0 8px 24px -10px color-mix(in srgb,var(--acc) 25%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.nav-cluster-glow{position:absolute;inset:-50% -15%;background:radial-gradient(50% 60% at 72% 50%,color-mix(in srgb,var(--acc) 28%,transparent),transparent 72%);filter:blur(22px);pointer-events:none;z-index:-1;opacity:.55;animation:nc-breathe 6s ease-in-out infinite alternate}
@keyframes nc-breathe{from{opacity:.4}to{opacity:.7}}
.nc-sep{display:block;width:1px;height:22px;background:color-mix(in srgb,var(--text) 12%,transparent);margin:0 2px;flex:0 0 auto}
/* Botones del cluster: transparent background, padding ajustado, hover sutil */
.nav-cluster .nc-btn{background:transparent !important;border:none !important;box-shadow:none !important;min-height:38px;border-radius:999px;transition:background .15s,transform .12s}
.nav-cluster .nc-btn:hover{background:rgba(255,255,255,.08) !important;transform:none}
/* btn-login dentro del cluster: usa fondo dorado sutil + texto blanco (no negro)
   para que se lea bien sobre el fondo verde de la app. */
.nav-cluster .btn-login{background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 78%,#000) 0%,color-mix(in srgb,var(--acc) 60%,#000) 100%) !important;color:#fff !important;padding:8px 18px !important;font-weight:900;font-style:italic;letter-spacing:.4px;box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 25%,transparent) !important}
.nav-cluster .btn-login:hover{filter:brightness(1.12);background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 85%,#000) 0%,color-mix(in srgb,var(--acc) 70%,#000) 100%) !important}
.nav-cluster .btn-login svg{color:#fff}
.nav-cluster .ibtn{width:auto;padding:7px 10px}
.nav-cluster #themeBtn{padding:5px 9px;display:inline-flex;align-items:center;gap:6px}
.nav-cluster #langBtn{padding:7px 12px;gap:7px}
.nav-cluster .lang-current-label{font-weight:700;font-size:12.5px;letter-spacing:.5px}
.nav-cluster .profile-pill{padding:4px 14px 4px 4px;border:0;background:transparent}
.nav-cluster .profile-pill:hover{background:rgba(255,255,255,.08)}
.nav-cluster .nc-item{display:flex;align-items:center}
@media (max-width:560px){
  .nav-cluster{padding:3px}
  .nc-sep{height:20px}
  .nav-cluster #themeBtn{padding:4px 7px}
  .nav-cluster #langBtn{padding:6px 9px;gap:5px}
  .nav-cluster .lang-current-label{font-size:11.5px}
  .nav-cluster .profile-pill .pp-name{max-width:60px}
}

/* Botones circulares (modo + tema) */
.ibtn{width:42px;height:42px;border-radius:50%;background:color-mix(in srgb,var(--text) 8%,transparent);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;color:var(--text);padding:0}
.ibtn:hover{background:color-mix(in srgb,var(--acc) 18%,transparent);border-color:color-mix(in srgb,var(--acc) 50%,var(--line))}
.ibtn svg{width:18px;height:18px;display:block}
.ibtn .tflag{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.ibtn .tflag svg,.ibtn .tflag img{display:block}

/* Selector de idioma */
.pill .lang{display:flex;background:color-mix(in srgb,var(--text) 8%,transparent);border:1px solid var(--line);border-radius:30px;overflow:hidden;padding:0}
.pill .lang button{background:none;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-weight:700;font-size:11.5px;padding:8px 11px;cursor:pointer;transition:.15s;letter-spacing:.5px}
.pill .lang button:hover{color:var(--text)}
.pill .lang button.active{background:var(--acc);color:var(--on-acc)}

/* EN VIVO chip (oculto por default, JS lo muestra cuando haya partidos) */
.pill .live-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:30px;background:color-mix(in srgb,#ef4444 16%,transparent);border:1px solid color-mix(in srgb,#ef4444 45%,transparent);cursor:pointer;text-decoration:none;color:#ff7575;font-family:'Archivo',sans-serif;font-weight:800;font-style:italic;font-size:11px;text-transform:uppercase;letter-spacing:.8px;transition:.15s}
.pill .live-chip:hover{background:color-mix(in srgb,#ef4444 24%,transparent)}
.pill .live-chip .lc-dot{width:7px;height:7px;border-radius:50%;background:#ef4444;animation:lcPulse 1.2s ease-in-out infinite;box-shadow:0 0 0 0 rgba(239,68,68,.7)}
@keyframes lcPulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.7)}70%{box-shadow:0 0 0 8px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}

/* Botón "Entrar" (Estado A — sin sesión) */
.btn-login{display:inline-flex;align-items:center;gap:8px;background:#ffd400;color:#1a1300;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14px;padding:10px 18px;border-radius:30px;cursor:pointer;border:none;transition:.18s;white-space:nowrap;letter-spacing:.3px;box-shadow:0 4px 14px rgba(255,212,0,.28)}
.btn-login:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 6px 18px rgba(255,212,0,.4)}
.btn-login svg{width:16px;height:16px}

/* Píldora de perfil (Estado B — con sesión) */
.profile-pill{position:relative;display:flex;align-items:center;gap:9px;background:color-mix(in srgb,var(--text) 8%,transparent);border:1px solid var(--line);border-radius:30px;padding:4px 12px 4px 4px;cursor:pointer;transition:.15s}
.profile-pill:hover{background:color-mix(in srgb,var(--acc) 14%,transparent);border-color:color-mix(in srgb,var(--acc) 40%,var(--line))}
.profile-pill .pp-av{width:32px;height:32px;border-radius:50%;background:color-mix(in srgb,var(--acc) 28%,var(--surface-2));display:flex;align-items:center;justify-content:center;font-size:17px;flex:none;overflow:hidden}
.profile-pill .pp-av .fb-avatar{width:100%!important;height:100%!important}
.profile-pill .pp-name{font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;color:var(--text);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-pill .pp-chev{color:var(--text-dim);transition:transform .2s}

/* Menú desplegable del perfil */
.profile-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:0 20px 50px rgba(0,0,0,.35);z-index:160;display:flex;flex-direction:column;gap:1px;animation:pmPop .18s ease-out}
@keyframes pmPop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.profile-menu[hidden]{display:none}
.profile-menu .pm-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:13.5px;padding:10px 12px;border-radius:9px;cursor:pointer;text-align:left;text-decoration:none;transition:.12s}
.profile-menu .pm-item:hover{background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--acc-text)}
.profile-menu .pm-ico{flex:none;width:16px;height:16px;color:var(--text-dim);transition:color .12s}
.profile-menu .pm-item:hover .pm-ico{color:var(--acc-text)}
.profile-menu .pm-signout{margin-top:2px;border-top:1px solid var(--line);border-radius:0 0 9px 9px;color:#ff5b5b}
.profile-menu .pm-signout:hover{background:color-mix(in srgb,#ff5b5b 14%,transparent);color:#ff5b5b}
.profile-menu .pm-signout .pm-ico{color:#ff5b5b}
.profile-menu .pm-signout:hover .pm-ico{color:#ff5b5b}

/* Hamburguesa (oculta en desktop) */
.nav-burger{display:none;background:none;border:1px solid var(--line);border-radius:50%;width:38px;height:38px;align-items:center;justify-content:center;color:var(--text);cursor:pointer;padding:0;margin-left:4px}
.nav-burger:hover{background:color-mix(in srgb,var(--acc) 14%,transparent);border-color:var(--acc)}

/* Bloques mobile-only dentro del menú desplegable (login, perfil, idioma).
   Ocultos en desktop. En mobile se muestran como items del dropdown. */
.mob-only{display:none}
@media (max-width:920px){
  .mob-only{display:flex}
  .mob-divider{height:1px;background:var(--line);margin:6px 8px}
  .mob-auth-btn{display:flex;align-items:center;gap:9px;padding:11px 14px;background:#ffd400;color:#1a1300;border:none;border-radius:11px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14px;cursor:pointer;width:100%;text-align:left}
  .mob-auth-btn svg{width:18px;height:18px;flex:none}
  .mob-auth-btn[data-mode="complete"]{background:color-mix(in srgb,var(--acc) 90%,#fff);color:var(--on-acc)}
  .mob-profile{flex-direction:column;gap:6px;padding:10px 12px;background:var(--surface);border:1px solid var(--line);border-radius:12px}
  .mob-prof-info{display:flex;align-items:center;gap:10px}
  .mob-prof-av{width:36px;height:36px;border-radius:50%;background:color-mix(in srgb,var(--acc) 24%,var(--surface-2));display:inline-flex;overflow:hidden;flex:none}
  .mob-prof-av .fb-avatar{width:100%!important;height:100%!important}
  .mob-prof-name{font-weight:800;font-size:14px;color:var(--text)}
  .mob-prof-acts{display:flex;flex-direction:column;gap:2px}
  .mob-prof-link{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;padding:9px 10px;border-radius:8px;cursor:pointer;text-align:left;text-decoration:none}
  .mob-prof-link:hover{background:color-mix(in srgb,var(--acc) 14%,transparent)}
  .mob-prof-link .pm-ico{flex:none;color:var(--text-dim)}
  .mob-prof-link:hover .pm-ico{color:var(--acc-text)}
  .mob-prof-link.mob-signout{color:#ff5b5b}
  .mob-prof-link.mob-signout .pm-ico{color:#ff5b5b}
  .mob-signout{color:#ff5b5b}
  .mob-langs{display:flex;background:var(--surface-2);border:1px solid var(--line);border-radius:30px;overflow:hidden;padding:0;align-self:flex-start;margin:0 8px}
  .mob-langs button{background:none;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-weight:700;font-size:12px;padding:8px 14px;cursor:pointer}
  .mob-langs button.active{background:var(--acc);color:var(--on-acc)}
}

/* Responsive: live-chip se colapsa a círculo en pantallas medias */
@media (max-width:1180px){
  .live-chip .lc-txt{display:none}
  .live-chip{padding:8px;width:32px;height:32px;border-radius:50%;justify-content:center}
}
/* Mejora touch: targets mínimos 44×44 en links del navbar mobile */
@media (max-width:920px) and (pointer:coarse){
  .nav-link,.mob-auth-btn,.mob-prof-link{min-height:44px}
}
/* El dropdown mobile NO debería dejar al menú duplicado de idioma cuando
   ya está visible en la barra. Ocultamos `.mob-langs` siempre — el switcher
   de idioma vive en la barra del navbar móvil. */
.mob-langs{display:none !important}
.theme-pop{position:fixed;top:60px;right:24px;z-index:150;width:300px;max-width:calc(100vw - 32px);background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 20px 60px rgba(0,0,0,.5);display:none;animation:pop .25s}
.theme-pop.open{display:block}
@keyframes pop{from{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:none}}
.theme-pop h4{font-style:italic;font-weight:900;font-size:18px;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.search-wrap{position:relative;margin-bottom:12px}
.search-wrap .ico{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:15px;opacity:.7;pointer-events:none}
.search-wrap input{width:100%;background:var(--surface-2);border:1px solid var(--line);color:var(--text);padding:12px 14px 12px 38px;border-radius:30px;font-family:'Archivo';font-size:14px;font-weight:600;transition:.2s}
.search-wrap input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 25%,transparent)}
.theme-reset{width:100%;margin-bottom:10px;background:color-mix(in srgb,var(--acc) 12%,transparent);color:var(--acc-text);border:1px solid var(--line);border-radius:10px;padding:8px;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:.2s}
.theme-reset:hover{background:var(--acc);color:var(--on-acc)}
.country-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:3px;scrollbar-width:thin}
.country-list::-webkit-scrollbar{width:6px}.country-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px}
.country-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;cursor:pointer;transition:.15s;border:1px solid transparent}
.country-item:hover{background:var(--surface-2)}
.country-item.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 10%,transparent)}
.country-item .cflag{display:inline-flex;align-items:center;justify-content:center;min-width:36px}
.country-item .cname{font-weight:600;font-size:14px;flex:1}
.country-item .cswatch{display:flex;gap:3px}
.country-item .cswatch i{width:11px;height:11px;border-radius:3px;display:block;border:1px solid rgba(255,255,255,.2)}
.country-empty{text-align:center;padding:20px;color:var(--text-dim);font-size:13px}
section{padding:78px 24px;position:relative}
.page-top{padding-top:48px}
.wrap{max-width:1200px;margin:0 auto}
.sec-head{margin-bottom:42px}
.sec-tag{font-family:'Archivo',sans-serif;color:var(--acc-text);font-size:12px;letter-spacing:3px;text-transform:uppercase}
.sec-title{font-style:italic;font-weight:900;font-size:clamp(36px,6.5vw,74px);line-height:.9;text-transform:uppercase;letter-spacing:-2px;margin-top:6px}
.sec-desc{margin-top:12px;max-width:620px;color:var(--text-dim);font-size:16px}
.reveal{opacity:0;transform:translateY(40px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.btn{font-family:'Archivo';font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.5px;padding:15px 28px;border-radius:50px;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:.25s}
.btn-primary{background:var(--acc);color:var(--on-acc);box-shadow:0 8px 30px color-mix(in srgb,var(--acc) 35%,transparent)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02)}
.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--acc)}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.strip{background:var(--acc);color:var(--on-acc);overflow:hidden;padding:14px 0;white-space:nowrap;transition:.5s}
.strip-track{display:inline-block;animation:marq 32s linear infinite;font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.6px}
.strip-item{display:inline-flex;align-items:center;gap:10px;margin:0 22px;vertical-align:middle}
.strip-ico{width:22px;height:22px;flex:none;display:block}
.strip-txt{display:inline-block;line-height:1}
/* B (números) — usamos --on-acc oscuro + opacidad para resaltar con contraste
   estable independientemente del tema. Antes usaba --acc-3 (rosa fijo) que
   sobre acentos azules quedaba ilegible. */
.strip-track b{color:var(--on-acc);background:color-mix(in srgb,var(--on-acc) 12%,transparent);padding:0 6px;border-radius:6px;font-style:normal;letter-spacing:0}
@keyframes marq{to{transform:translateX(-50%)}}
@media (max-width:560px){
  .strip-track{font-size:17px}
  .strip-ico{width:18px;height:18px}
  .strip-item{gap:8px;margin:0 16px}
}
footer{background:var(--bg-2);padding:50px 24px 30px;text-align:center;border-top:1px solid var(--line)}
.foot-links{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:18px 0}
.foot-links a{color:var(--text-dim);text-decoration:none;font-size:12px;text-transform:uppercase;letter-spacing:1px;transition:.2s}
.foot-links a:hover{color:var(--acc-text)}
.foot-copy{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);margin-top:14px;line-height:1.7}

/* === Modal "ver perfil de usuario" (fbOpenUserProfile) === */
.fb-up-lay{position:fixed;inset:0;background:rgba(5,15,10,.84);backdrop-filter:blur(10px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s}
.fb-up-lay.open{opacity:1}
.fb-up-card{position:relative;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface) 88%,#000));border:1px solid var(--line);border-radius:26px;width:100%;max-width:720px;min-height:auto;padding:42px 44px 32px;box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.04);transform:translateY(10px) scale(.97);transition:transform .25s cubic-bezier(.2,.7,.2,1);font-family:'Archivo',sans-serif;display:flex;flex-direction:column;overflow:hidden}
/* Decoración de fondo: bandera del país que apoya (low opacity, esquina sup
   derecha, desvanecida hacia el centro). Si no hay pais_apoya, no muestra nada.
   La URL la setea fbOpenUserProfile vía --fb-up-flag-url. */
.fb-up-card::before{
  content:"";position:absolute;top:0;right:0;width:55%;height:100%;
  background-image:var(--fb-up-flag-url,none);
  background-size:cover;background-position:center;background-repeat:no-repeat;
  opacity:.12;
  -webkit-mask-image:linear-gradient(to left,#000 0%,#000 30%,transparent 80%);
          mask-image:linear-gradient(to left,#000 0%,#000 30%,transparent 80%);
  pointer-events:none;z-index:0;
  transition:opacity .3s;
}
/* Si no hay bandera, mostramos líneas diagonales tenues de fallback */
.fb-up-card:not([data-has-flag])::before{
  background-image:repeating-linear-gradient(135deg,color-mix(in srgb,var(--acc) 22%,transparent) 0,color-mix(in srgb,var(--acc) 22%,transparent) 1px,transparent 1px,transparent 14px);
  opacity:.5;
  -webkit-mask-image:linear-gradient(to bottom left,#000 0%,transparent 80%);
          mask-image:linear-gradient(to bottom left,#000 0%,transparent 80%);
}
.fb-up-lay.open .fb-up-card{transform:translateY(0) scale(1)}
.fb-up-x{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.35);border:1px solid var(--line);color:var(--text-dim);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s;line-height:0;padding:0;font-weight:600;z-index:3}
.fb-up-x:hover{background:color-mix(in srgb,#ef4444 18%,rgba(0,0,0,.4));color:#fff;border-color:color-mix(in srgb,#ef4444 50%,var(--line))}
.fb-up-loading{padding:90px 30px;text-align:center;color:var(--text-dim);font-style:italic;position:relative;z-index:1}
.fb-up-head{display:flex;gap:32px;align-items:center;padding-right:50px;position:relative;z-index:1}
/* Wrapper relative para colgar el badge de bandera sobre el círculo */
.fb-up-photo-wrap{position:relative;flex:none}
.fb-up-photo{width:170px;height:170px;border-radius:50%;overflow:hidden;background:color-mix(in srgb,var(--acc) 14%,var(--surface-2));border:4px solid color-mix(in srgb,var(--acc) 35%,var(--line));box-shadow:0 14px 40px rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;box-sizing:border-box}
/* Forzamos que el contenido (avatar SVG, foto google) llene el círculo perfectamente.
   El user reportó que el SVG se desencuadra — esto lo deja centrado por flex + tamaños 100%. */
.fb-up-photo > *{width:100% !important;height:100% !important;display:flex !important;align-items:center !important;justify-content:center !important;border-radius:50%;flex:none}
.fb-up-photo img{object-fit:cover}
.fb-up-photo svg{width:100% !important;height:100% !important}
/* Bandera del país que apoya: badge circular superpuesto en la esquina
   inferior derecha del avatar (estilo Discord status indicator). */
.fb-up-pais-badge{position:absolute;right:-2px;bottom:6px;width:54px;height:54px;border-radius:50%;background:var(--surface);border:3px solid color-mix(in srgb,var(--acc) 40%,var(--line));overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,.55);z-index:2}
.fb-up-pais-badge img{width:100%;height:100%;object-fit:cover;display:block}
.fb-up-head-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}
.fb-up-name{font-style:italic;font-weight:900;font-size:36px;color:var(--text);margin:0;letter-spacing:-.6px;word-break:break-word;line-height:1.1}
.fb-up-pais-label{font-family:'Archivo',sans-serif;font-size:13px;font-weight:600;color:var(--text-dim);letter-spacing:.5px;display:flex;align-items:center;gap:6px;opacity:.85}
.fb-up-pais-label::before{content:"♥";color:color-mix(in srgb,#ef4444 80%,var(--acc));font-size:14px}
.fb-up-body{margin-top:28px;padding-top:22px;border-top:1px solid color-mix(in srgb,var(--line) 55%,transparent);position:relative;z-index:1}
.fb-up-body-label{font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px;opacity:.7}
.fb-up-desc{font-size:16px;color:var(--text);line-height:1.65;margin:0;white-space:pre-wrap;word-break:break-word}
.fb-up-desc-empty{font-style:italic;color:var(--text-dim);font-size:14px}
@media (max-width:560px){
  .fb-up-lay{padding:14px}
  .fb-up-card{padding:28px 22px 24px;border-radius:20px;min-height:auto;max-width:none}
  .fb-up-card::before{width:70%}
  .fb-up-head{gap:18px;padding-right:44px;flex-direction:column;align-items:flex-start;text-align:left}
  .fb-up-head-info{align-items:flex-start;width:100%}
  .fb-up-photo{width:130px;height:130px;border-width:3px}
  .fb-up-pais-badge{width:44px;height:44px;border-width:2.5px;right:-2px;bottom:4px}
  .fb-up-name{font-size:26px}
  .fb-up-desc{font-size:14.5px}
}
.foot-social a{transition:transform .15s,color .15s,background .15s,border-color .15s}
.foot-social a:hover{color:var(--acc)!important;border-color:color-mix(in srgb,var(--acc) 45%,var(--line))!important;background:color-mix(in srgb,var(--acc) 10%,var(--surface))!important;transform:translateY(-2px)}
.foot-copy a:hover{opacity:.85;text-decoration:underline!important}
/* HERO */
.hero{position:relative;min-height:calc(100vh - 72px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:50px 20px 70px;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.3}
.hero-fallback{position:absolute;inset:0;z-index:0;background:radial-gradient(circle at 20% 25%,color-mix(in srgb,var(--acc-3) 45%,transparent),transparent 42%),radial-gradient(circle at 82% 30%,color-mix(in srgb,var(--acc-2) 40%,transparent),transparent 45%),radial-gradient(circle at 50% 85%,color-mix(in srgb,var(--acc) 45%,transparent),transparent 52%);animation:drift 16s ease-in-out infinite alternate;transition:.5s}
@keyframes drift{to{transform:scale(1.1);filter:hue-rotate(12deg)}}
.hero-mesh{position:absolute;inset:0;z-index:0;opacity:.5;background-image:repeating-linear-gradient(115deg,transparent 0 58px,color-mix(in srgb,var(--text) 4%,transparent) 58px 59px)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at center,transparent 25%,var(--bg) 100%)}
.hero-content{position:relative;z-index:2;max-width:1000px}
.hero-kicker{font-family:'Archivo',sans-serif;color:var(--acc-text);font-size:12px;letter-spacing:4px;text-transform:uppercase;margin-bottom:20px;opacity:0;animation:rise .8s .1s forwards}
.hero h1{font-style:italic;font-weight:900;font-size:clamp(36px,8.5vw,110px);line-height:.88;letter-spacing:-2px;text-transform:uppercase}
.hero h1 .l1{display:block;opacity:0;animation:rise .8s .25s forwards}
.hero h1 .l2{display:block;color:var(--acc-text);opacity:0;animation:rise .8s .4s forwards;text-shadow:0 0 50px color-mix(in srgb,var(--acc) 45%,transparent)}
.hero-sub{font-size:clamp(15px,2.3vw,22px);font-weight:500;max-width:560px;margin:26px auto 0;opacity:0;animation:rise .8s .55s forwards;color:var(--text-dim)}
.hero-sub b{color:var(--acc2-text)}

/* CONTADOR INAUGURAL */
.kickoff{margin:32px auto 0;max-width:580px;padding:18px 22px;border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line));background:color-mix(in srgb,var(--surface) 60%,transparent);backdrop-filter:blur(10px);border-radius:18px;opacity:0;animation:rise .8s .65s forwards;box-shadow:0 12px 40px rgba(0,0,0,.25)}
.kickoff .ko-label{font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--acc-text);text-align:center;margin-bottom:14px}
.kickoff .ko-grid{display:flex;align-items:flex-end;justify-content:center;gap:6px}
.kickoff .ko-cell{display:flex;flex-direction:column;align-items:center;min-width:64px}
.kickoff .ko-num{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:clamp(40px,8vw,64px);line-height:1;color:var(--text);letter-spacing:-2px;font-variant-numeric:tabular-nums}
.kickoff .ko-unit{font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-top:6px}
.kickoff .ko-sep{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:clamp(34px,6vw,52px);line-height:1;color:var(--acc-text);opacity:.6;padding-bottom:18px;animation:koBlink 1s ease-in-out infinite}
.kickoff .ko-foot{margin-top:14px;text-align:center;font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);letter-spacing:.5px}
.kickoff.live{border-color:#ef4444;background:color-mix(in srgb,#ef4444 12%,var(--surface))}
.kickoff .ko-live{display:flex;align-items:center;justify-content:center;gap:10px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:clamp(20px,3.5vw,30px);color:var(--text);letter-spacing:-.5px}
.kickoff .ko-live-dot{width:12px;height:12px;border-radius:50%;background:#ef4444;animation:koPulse 1.2s ease-in-out infinite;box-shadow:0 0 0 0 rgba(239,68,68,.7)}
@keyframes koBlink{0%,100%{opacity:.25}50%{opacity:.75}}
@keyframes koPulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.7)}70%{box-shadow:0 0 0 12px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}
@media (max-width:560px){
  .kickoff{padding:14px 12px;margin-top:24px}
  .kickoff .ko-cell{min-width:54px}
  .kickoff .ko-grid{gap:2px}
  .kickoff .ko-sep{padding-bottom:14px}
}
@media (max-width:920px){.hero{min-height:calc(100vh - 64px);padding-top:36px}}
/* Mobile: hero ocupa toda la pantalla con el botón "IR AL PRODE" como CTA.
   Una flecha de scroll abajo indica que hay más contenido scrolleando. */
@media (max-width:560px){.hero{min-height:calc(100vh - 60px);padding:28px 20px 80px}}

/* === Flecha "Bajá para explorar" — solo mobile, bottom del hero === */
/* Scroll hint — vive justo debajo del botón "IR AL PRODE", no flotando.
   Solo aparece en mobile. */
.hero-scroll-hint{display:none;background:transparent;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;margin:18px auto 0;animation:hshBob 1.8s ease-in-out infinite;opacity:.75;transition:opacity .3s;-webkit-tap-highlight-color:transparent}
.hero-scroll-hint:hover{opacity:1;color:var(--acc-text)}
.hero-scroll-hint svg{color:var(--acc)}
.hsh-txt{display:block}
@keyframes hshBob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media (max-width:560px){
  .hero-scroll-hint{display:flex}
  .hero-scroll-hint[data-scrolled="1"]{opacity:0;pointer-events:none}
}

.hero-cta{margin-top:36px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap;opacity:0;animation:rise .8s .85s forwards}
/* === Hero CTA "Ir al prode" — más grande y notorio, con pulse sutil === */
.hero-cta-prode{margin-top:44px}
.hero-prode-btn{display:inline-flex;align-items:center;gap:14px;padding:18px 38px;font-size:18px;font-weight:900;letter-spacing:.3px;text-transform:uppercase;border-radius:60px;background:linear-gradient(135deg,var(--acc) 0%,color-mix(in srgb,var(--acc) 80%,#0a4d2e) 100%)!important;color:var(--on-acc)!important;box-shadow:0 12px 40px color-mix(in srgb,var(--acc) 45%,transparent),0 0 0 0 color-mix(in srgb,var(--acc) 35%,transparent)!important;animation:heroPulse 2.4s ease-in-out infinite;position:relative;overflow:hidden;transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s}
.hero-prode-btn:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 18px 50px color-mix(in srgb,var(--acc) 55%,transparent),0 0 0 4px color-mix(in srgb,var(--acc) 25%,transparent)!important;animation:none}
.hero-prode-btn:active{transform:translateY(-2px) scale(1.02)}
.hpb-ico{font-size:22px;animation:heroBall 1.6s ease-in-out infinite;display:inline-block}
.hpb-arrow{font-size:22px;font-weight:900;transition:transform .25s}
.hero-prode-btn:hover .hpb-arrow{transform:translateX(6px)}
.hero-prode-btn::after{content:"";position:absolute;top:0;left:-150%;width:80%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transform:skewX(-22deg);animation:heroShine 3.5s ease-in-out infinite;pointer-events:none}
@keyframes heroPulse{
  0%,100%{box-shadow:0 12px 40px color-mix(in srgb,var(--acc) 45%,transparent),0 0 0 0 color-mix(in srgb,var(--acc) 35%,transparent)}
  50%   {box-shadow:0 12px 40px color-mix(in srgb,var(--acc) 45%,transparent),0 0 0 12px color-mix(in srgb,var(--acc) 0%,transparent)}
}
@keyframes heroBall{0%,100%{transform:rotate(0)}50%{transform:rotate(15deg)}}
@keyframes heroShine{0%,30%{left:-150%}60%,100%{left:150%}}
@media (max-width:520px){
  .hero-prode-btn{padding:16px 30px;font-size:16px;gap:11px}
  .hpb-ico{font-size:19px}
}

/* === Sección EN VIVO — pegada al TOP-LEFT, a la altura del logo Fulbazo === */
.hero-live-section{
  position:absolute;
  left:14px;
  top:14px;          /* arriba a la izquierda, a la altura del logo */
  transform:none;
  width:290px;
  max-width:24vw;
  z-index:6;
  font-family:'Archivo',sans-serif;
  animation:hlsIn .4s cubic-bezier(.2,.7,.2,1);
}
@media (min-width:1400px){
  .hero-live-section{left:32px;width:320px;max-width:22vw}
}
@media (max-width:1100px) and (min-width:921px){
  .hero-live-section{left:10px;width:240px;max-width:20vw}
  .hero-live-section .hls-name{font-size:12.5px}
  .hero-live-section .hls-score{font-size:21px}
  .hero-live-section .hls-flag img{width:20px;height:14px}
}
.hero-live-section[hidden]{display:none}
.hls-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:0 2px}
.hls-badge{display:inline-flex;align-items:center;gap:6px;background:#ef4444;color:#fff;padding:4px 11px;border-radius:30px;font-size:10px;font-weight:900;letter-spacing:1.3px;text-transform:uppercase;box-shadow:0 4px 14px rgba(239,68,68,.4)}
.hls-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:hlsDotPulse 1.2s ease-in-out infinite}
.hls-meta{color:rgba(255,255,255,.65);font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.hls-link{margin-left:auto;color:#fbbf24;text-decoration:none;font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;transition:opacity .15s}
.hls-link:hover{opacity:.7}

/* Stack vertical de cards (siempre) — más limpio para sidebar */
.hls-grid{display:flex;flex-direction:column;gap:11px;max-height:calc(100vh - 200px);overflow-y:auto;scrollbar-width:thin;padding-right:4px}
.hls-grid::-webkit-scrollbar{width:5px}
.hls-grid::-webkit-scrollbar-thumb{background:color-mix(in srgb,#ef4444 45%,transparent);border-radius:4px}

/* Card minimalista, marcador prominente */
.hls-card{
  display:block;
  background:linear-gradient(135deg, rgba(20,30,25,.92) 0%, rgba(15,25,20,.88) 100%);
  border:1px solid rgba(239,68,68,.3);
  border-radius:14px;
  padding:14px 16px;
  text-decoration:none;
  color:#fff;
  box-shadow:0 8px 28px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.04);
  transition:transform .2s cubic-bezier(.2,.7,.2,1),border-color .2s,box-shadow .2s;
  backdrop-filter:blur(8px);
  position:relative;
  overflow:hidden;
}
.hls-card::before{
  /* Indicador rojo a la izquierda — barra lateral fina */
  content:"";position:absolute;left:0;top:14%;bottom:14%;width:3px;
  background:linear-gradient(180deg,#ef4444,#dc2626);
  border-radius:0 3px 3px 0;
  box-shadow:0 0 12px rgba(239,68,68,.6);
}
.hls-card:hover{
  transform:translateX(3px);
  border-color:rgba(239,68,68,.55);
  box-shadow:0 12px 32px rgba(0,0,0,.55),0 0 24px rgba(239,68,68,.18);
}
.hls-card-min{
  font-size:9.5px;font-weight:900;color:#ef4444;letter-spacing:1.6px;
  margin-bottom:11px;text-transform:uppercase;font-variant-numeric:tabular-nums;
  display:flex;align-items:center;gap:5px;
}
.hls-card-min::before{content:"";width:5px;height:5px;border-radius:50%;background:#ef4444;animation:hlsDotPulse 1s ease-in-out infinite;box-shadow:0 0 6px rgba(239,68,68,.7)}
.hls-card-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:5px 0}
.hls-card-row + .hls-card-row{border-top:1px solid rgba(255,255,255,.06);padding-top:9px;margin-top:3px}
.hls-team{display:flex;align-items:center;gap:9px;min-width:0;flex:1;font-weight:700;font-style:italic;font-size:14px;letter-spacing:.1px}
.hls-flag{display:inline-flex;align-items:center;flex:none}
.hls-flag img{width:22px;height:16px;border-radius:3px;object-fit:cover;box-shadow:0 1px 4px rgba(0,0,0,.5)}
.hls-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;color:#fff}
.hls-score{
  font-family:'Archivo',sans-serif;font-weight:900;font-size:24px;
  color:#fff;font-variant-numeric:tabular-nums;line-height:1;flex:none;
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}

@keyframes hlsIn{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes hlsDotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}

/* En tablets/mobile dejamos de flotar y va abajo del hero, full width */
@media (max-width:920px){
  .hero-live-section{
    position:static;
    transform:none;
    width:100%;
    max-width:520px;
    margin:24px auto 0;
    right:auto;top:auto;
  }
  .hls-grid{max-height:none;overflow:visible}
  @keyframes hlsIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
}
.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;font-family:'Archivo',sans-serif;font-size:10px;letter-spacing:2px;color:var(--text-dim);display:flex;flex-direction:column;align-items:center;gap:8px;animation:bob 2s infinite}
.scroll-hint span{width:1px;height:30px;background:linear-gradient(var(--acc),transparent)}
@keyframes bob{50%{transform:translate(-50%,7px)}}
.video-note{position:absolute;bottom:16px;right:16px;z-index:3;font-family:'Archivo',sans-serif;font-size:10px;color:var(--text-dim);border:1px dashed var(--line);padding:6px 10px;border-radius:8px;max-width:210px;text-align:left}
/* NAV CARDS (index) */
.nav-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:10px}
.nav-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px 22px;text-decoration:none;color:var(--text);transition:.3s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.nav-card:hover{transform:translateY(-6px);border-color:var(--acc)}
.nav-card .nc-ico{width:96px;height:96px;display:flex;align-items:center;justify-content:center;flex:none;margin-bottom:6px;position:relative;z-index:1}
.nav-card .nc-ico img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
.nav-card .nc-ico.nc-ico-svg svg{width:60px;height:60px;color:var(--acc-text)}
.nav-card h3{font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;margin:6px 0 4px;line-height:1.15}
.nav-card p{font-size:13px;color:var(--text-dim);line-height:1.5;flex:1}
.nav-card .nc-go{margin-top:12px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;color:var(--acc-text);text-transform:uppercase;letter-spacing:1px}
/* GROUPS */
.group-filter{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:32px}
.group-filter button{font-style:italic;font-weight:900;font-size:17px;width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;transition:.2s}
.group-filter button:hover{border-color:var(--acc);color:var(--acc-text)}
.group-filter button.active{background:var(--acc);color:var(--on-acc);border-color:var(--acc)}
.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.group-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px 14px 12px;transition:.3s;position:relative;overflow:hidden}
.group-card:hover{transform:translateY(-5px);border-color:var(--acc)}
.group-card h3{font-style:italic;font-weight:900;font-size:18px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.group-card h3 .badge{background:var(--acc);color:var(--on-acc);font-size:13px;padding:2px 9px;border-radius:7px;font-style:normal}
.team-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}
.team-row:last-child{border:none}

/* Standings table — 8 columnas (#, equipo, PJ, G, E, P, DG, PT).
   Eliminamos GF/GC porque DG ya cuenta la historia y no entraban en el card
   sin scroll horizontal. La columna equipo flex-shrinkea con ellipsis. */
.stand-table{display:flex;flex-direction:column;gap:0;margin-bottom:14px;font-family:'Archivo',sans-serif;overflow:hidden;width:100%;min-width:0}
.stand-row{display:grid;grid-template-columns:14px minmax(0,1fr) 20px 18px 18px 18px 24px 26px;align-items:center;gap:3px;padding:8px 2px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);font-size:12.5px;color:var(--text);min-width:0;width:100%;box-sizing:border-box}
.stand-row:last-child{border-bottom:none}
.stand-row.stand-head{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;font-weight:700;padding:6px 2px;border-bottom:1.5px solid var(--line)}
.stand-row.stand-top2{background:color-mix(in srgb,var(--acc) 8%,transparent);border-radius:5px}
.st-pos{font-family:'Archivo',sans-serif;font-weight:800;color:var(--text-dim);text-align:center;font-size:11px}
.stand-top2 .st-pos{color:var(--acc-text)}
.st-team{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}
.st-team .flag{flex:none;width:18px;height:13px;display:inline-flex;align-items:center}
.st-team .flag .fb-flag{height:13px!important;width:18px!important}
.st-name{font-weight:600;font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.st-num{text-align:center;font-variant-numeric:tabular-nums;font-weight:600;color:var(--text-dim);font-size:11.5px}
.st-num.st-pts{font-weight:900;color:var(--text);font-style:italic;font-size:13px}
.stand-top2 .st-num{color:var(--text)}

/* Boton "Ver partidos" con pelota.png */
.view-matches{margin-top:10px;display:flex;align-items:center;justify-content:center;gap:8px}
.view-matches .vm-ball{width:34px;height:34px;object-fit:contain;flex:none;display:inline-block}
.view-matches span{display:inline-block;line-height:1}

@media (max-width:520px){
  .stand-row{grid-template-columns:12px minmax(0,1fr) 18px 16px 16px 16px 22px 24px;gap:2px;font-size:11.5px;padding:7px 1px}
  .stand-row.stand-head{font-size:9.5px;letter-spacing:.2px}
  .st-name{font-size:12px}
  .st-num{font-size:11px}
  .st-num.st-pts{font-size:12.5px}
  .st-team{gap:5px}
}
.flag{display:inline-flex;align-items:center;justify-content:center;min-width:34px}
.team-name{font-weight:600;font-size:15px;flex:1}
.team-pts{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim)}
.view-matches{margin-top:10px;width:100%;background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--acc-text);border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:.2s}
.view-matches:hover{background:var(--acc);color:var(--on-acc)}
/* STADIUMS */
/* ===== ESTADIOS — Cards pro ===== */
.stadiums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}
/* Indicador visual de que la card es clickable */
.stad:focus-visible{outline:2px solid var(--acc);outline-offset:3px}

/* ===== Modal de estadio (foto + datos + dirección + partidos) ===== */
.stad-modal{max-width:680px;width:100%;max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;display:flex;flex-direction:column;padding:0;touch-action:pan-y}
.stad-modal .modal-close{position:absolute;top:14px;right:14px;z-index:10;background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(8px);border:none;width:38px;height:38px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}
.stad-modal .modal-close:hover{background:rgba(0,0,0,.75)}
.sm-hero{position:relative;height:260px;flex:none;overflow:hidden;background:var(--bg-2)}
.sm-photo{width:100%;height:100%;object-fit:cover;display:block}
.sm-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--acc-text)}
.sm-photo-ph svg{width:80px;height:80px;opacity:.4}
.sm-hero-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.1) 100%);pointer-events:none}
.sm-hero-meta{position:absolute;top:14px;left:14px;display:flex;gap:8px;z-index:2}
.sm-hero-meta .sm-flag{width:38px;height:auto;display:block;border-radius:5px;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.sm-hero-meta .badge{background:var(--acc);color:var(--on-acc);font-size:11px;padding:5px 10px;border-radius:6px;font-weight:900;font-style:italic;display:inline-flex;align-items:center;gap:5px}
.sm-hero-meta .badge svg{width:11px;height:11px}
.sm-hero-title{position:absolute;left:22px;right:22px;bottom:18px;z-index:2;color:#fff}
.sm-hero-title .sm-name{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:28px;line-height:1.05;letter-spacing:-.8px;margin:0 0 6px;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.sm-hero-title .sm-city{display:flex;align-items:center;gap:7px;font-size:14px;opacity:.95;font-weight:600}
.sm-hero-title .sm-city svg{width:16px;height:16px;color:#fff}
.sm-body{padding:20px 24px 24px;flex:1;display:flex;flex-direction:column;gap:18px}
.sm-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sm-stat{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.sm-stat-l{display:flex;align-items:center;gap:7px;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}
.sm-stat-l svg{width:14px;height:14px}
.sm-stat-v{font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;color:var(--text)}
.sm-stat-v small{font-size:11px;font-style:normal;font-weight:600;color:var(--text-dim);text-transform:lowercase;letter-spacing:0;margin-left:2px}
.sm-addr{background:color-mix(in srgb,var(--acc) 7%,var(--surface));border:1px solid color-mix(in srgb,var(--acc) 25%,var(--line));border-radius:12px;padding:14px 16px}
.sm-addr-label{display:flex;align-items:center;gap:7px;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--acc-text);margin-bottom:6px}
.sm-addr-label svg{width:14px;height:14px}
.sm-addr-link{display:block;color:var(--text);font-weight:600;font-size:14px;line-height:1.45;text-decoration:none;border-bottom:1px dashed transparent;transition:border-color .15s,color .15s}
.sm-addr-link:hover{color:var(--acc-text);border-bottom-color:var(--acc-text)}
.sm-matches-h{font-style:italic;font-weight:900;font-size:16px;letter-spacing:-.3px;color:var(--text);margin:0 0 10px;display:flex;align-items:baseline;gap:7px}
.sm-matches-h::before{content:"⚽";font-size:18px}
.sm-matches-list{display:flex;flex-direction:column;gap:8px}
.sm-match{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:10px 14px;transition:border-color .15s}
.sm-match:hover{border-color:color-mix(in srgb,var(--acc) 35%,var(--line))}
.sm-match-when{font-family:'Archivo',sans-serif;font-size:11.5px;font-weight:700;color:var(--acc-text);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}
.sm-match-teams{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--text);min-width:0;flex-wrap:wrap;justify-content:center}
.sm-mt-h,.sm-mt-a{display:inline-flex;align-items:center;gap:6px}
.sm-mt-sep{color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;padding:0 4px}
.sm-mt-flag{display:inline-flex;line-height:0}
.sm-match-g{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);background:var(--surface-2);padding:3px 8px;border-radius:6px}
.sm-empty{padding:18px;background:var(--surface-2);border:1px dashed var(--line);border-radius:12px;text-align:center;font-size:13px;color:var(--text-dim);font-style:italic}
@media (max-width:560px){
  .sm-hero{height:200px}
  .sm-hero-title .sm-name{font-size:22px}
  .sm-body{padding:16px 18px 18px;gap:14px}
  .sm-stats{grid-template-columns:1fr 1fr;gap:8px}
  .sm-stat{padding:10px 12px}
  .sm-stat-v{font-size:18px}
  .sm-match{grid-template-columns:1fr;gap:6px;text-align:center;padding:10px 12px}
  .sm-match-teams{justify-content:center}
}
.stad{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s;cursor:pointer}
.stad:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--acc) 50%,var(--line));box-shadow:0 20px 50px rgba(0,0,0,.35)}
html[data-mode="light"] .stad:hover{box-shadow:0 18px 40px rgba(0,0,0,.18)}

/* foto / placeholder */
.stad .photo{position:relative;height:185px;overflow:hidden;background:var(--bg-2)}
.stad .photo img.bg{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.stad:hover .photo img.bg{transform:scale(1.08)}
.stad .photo .ph{position:absolute;inset:0;background:
  radial-gradient(ellipse 120% 80% at 50% 120%, color-mix(in srgb,var(--acc) 22%,transparent), transparent 60%),
  linear-gradient(160deg, color-mix(in srgb,var(--bg-2) 92%,var(--acc)), var(--bg-2));
  display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--text) 30%,transparent)}
.stad .photo .ph svg{width:64px;height:64px;opacity:.5}
.stad .photo .ph .lbl{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-family:'Archivo',sans-serif;font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text);opacity:.85;text-shadow:0 2px 8px rgba(0,0,0,.6),0 0 20px color-mix(in srgb,var(--acc) 40%,transparent)}
.stad .photo .ph{color:var(--acc-text)}
.stad .photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,color-mix(in srgb,var(--surface) 70%,transparent) 78%,var(--surface));pointer-events:none}

/* bandera chip */
.stad .flag{position:absolute;top:12px;right:12px;z-index:3;width:34px;height:24px;border-radius:5px;object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.5);border:1.5px solid rgba(255,255,255,.5)}

/* badge de rol — colores semánticos fijos (verde/dorado/rojo) intencionalmente */
.stad .badge{position:absolute;top:12px;left:12px;z-index:3;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:11px;letter-spacing:.4px;text-transform:uppercase;padding:5px 11px;border-radius:30px;display:inline-flex;align-items:center;gap:5px;backdrop-filter:blur(8px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.stad .badge.ina{background:rgba(25,195,125,.92);color:#04210f}
.stad .badge.fin{background:rgba(255,212,0,.92);color:#1a1500}
.stad .badge.ter{background:rgba(255,49,49,.92);color:#fff}
.stad .badge svg{width:11px;height:11px}

/* título sobre la foto */
.stad .info .stad-name{font-style:italic;font-weight:900;font-size:21px;line-height:1.05;letter-spacing:-.4px;color:var(--text);margin-bottom:8px}

/* info inferior */
.stad .info{padding:14px 16px 16px}
.stad .info .city{color:var(--text-dim);font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:7px}
.stad .info .city svg{width:14px;height:14px;color:var(--acc-text);flex:none}
.stad .info .divline{height:1px;background:var(--line);margin:12px 0}
.stad .info .cap{display:flex;align-items:center;justify-content:space-between}
.stad .info .cap .l{display:flex;align-items:center;gap:7px;color:var(--text-dim);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.stad .info .cap .l svg{width:14px;height:14px}
.stad .info .cap .v{font-family:'Archivo',sans-serif;font-weight:700;font-size:18px;color:#ffd400}
.stad .info .cap .v small{font-size:11px;color:var(--text-dim);font-weight:600;margin-left:3px}
/* PREDICTION */
.pred-intro{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch;margin-bottom:28px}
.pred-step{flex:1;min-width:240px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.pred-step b{color:var(--acc-text)}

/* ============================================================
   SIMULADOR MUNDIAL 2026 (prediccion.html nuevo)
   Colores 100% theme-aware: usa --acc-text / --acc2-text para
   evitar invisibilidad con acentos blancos / muy claros.
   ============================================================ */
.sim-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0 22px}
.sim-step{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px;font-size:14px}
.sim-step .ss-num{flex:none;width:36px;height:36px;border-radius:50%;background:var(--acc);color:var(--on-acc);display:flex;align-items:center;justify-content:center;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:18px}
.sim-step b{font-style:italic;color:var(--text)}
.sim-step span{color:var(--text-dim);font-size:13px}

.sim-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;margin-bottom:24px}

/* ===== Página COMPACTA (prediccion): aplastamos verticalmente para que
   los grupos aparezcan above-the-fold sin scrollear. =====
   - Title más chico (no aprieta el navbar pero deja espacio)
   - Sec-head con menos margen abajo
   - Sim-steps en 1 línea horizontal más compacta
   - Sim-mode-tabs más bajas
   - Sim-actions inline con menos margen
   - Section title pegado arriba */
.page-compact .page-top{padding-top:36px;padding-bottom:18px}
.page-compact .sec-head-compact{margin-bottom:18px}
.page-compact .sec-title-compact{font-size:clamp(36px,5vw,62px);line-height:.95;letter-spacing:-1.5px}
.page-compact .sec-desc-compact{font-size:16px;line-height:1.5;margin-top:12px;max-width:720px}
.page-compact .sec-tag{font-size:12.5px;letter-spacing:2.5px}
.page-compact .sim-steps{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px;margin:12px 0 14px}
.page-compact .sim-step{padding:10px 12px;font-size:12.5px;gap:10px}
.page-compact .sim-step .ss-num{width:28px;height:28px;font-size:14px}
.page-compact .sim-step span{font-size:11.5px;line-height:1.3}
.page-compact .sim-step b{font-size:13px}
.page-compact .sim-mode-tabs{margin:0 auto 14px;max-width:580px}
.page-compact .smt{padding:9px 14px;flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px 10px}
.page-compact .smt .smt-ico{font-size:18px}
.page-compact .smt .smt-label{font-size:14px}
.page-compact .smt .smt-sub{font-size:11px;width:100%;line-height:1.3}
.page-compact .sim-actions{margin-bottom:14px;gap:10px}
.page-compact .sim-actions .btn{padding:10px 16px;font-size:13px}
.page-compact .sim-section-title{margin:6px 0 10px;font-size:18px}
@media (max-width:760px){
  .page-compact .page-top{padding-top:24px}
  .page-compact .sec-title-compact{font-size:clamp(30px,8vw,42px)}
  .page-compact .sec-desc-compact{font-size:15px}
  .page-compact .sim-steps{grid-template-columns:1fr 1fr;gap:6px}
  .page-compact .sim-step:nth-child(3){grid-column:span 2}
  .page-compact .sim-mode-tabs{grid-template-columns:1fr;gap:6px}
}

/* Selector de modo Simple vs Completo */
.sim-mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:680px;margin:0 auto 24px;padding:0 4px}
.smt{display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:4px;padding:14px 16px;background:var(--surface);border:1.5px solid var(--line);border-radius:14px;cursor:pointer;transition:.18s;font-family:'Archivo',sans-serif;color:var(--text);position:relative}
.smt:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line));background:var(--surface-2)}
.smt.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 14%,var(--surface));box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 22%,transparent)}
.smt .smt-ico{font-size:22px}
.smt .smt-label{font-style:italic;font-weight:900;font-size:16px;letter-spacing:-.3px}
.smt .smt-sub{font-size:12px;color:var(--text-dim);line-height:1.35;font-weight:500}
.smt.active .smt-label{color:var(--acc-text)}
@media (max-width:560px){.sim-mode-tabs{grid-template-columns:1fr}}

/* Ranking simple (4 selecciones con flechas) */
.sim-group-simple .sim-rank{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.sim-rank-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-2);border:1.5px solid var(--line);border-radius:12px;transition:.15s}
.sim-rank-row.qualify{border-color:color-mix(in srgb,#22c55e 45%,var(--line));background:color-mix(in srgb,#22c55e 6%,var(--surface-2))}
.sim-rank-row.third{border-color:color-mix(in srgb,#fbbf24 55%,var(--line));background:color-mix(in srgb,#fbbf24 7%,var(--surface-2))}
.srr-pos{font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;color:var(--text-dim);width:30px;flex:none;text-align:center}
.sim-rank-row.qualify .srr-pos{color:var(--acc-text)}
.sim-rank-row.third .srr-pos{color:#fbbf24}
.srr-flag{flex:none;line-height:0}
.srr-name{flex:1;font-weight:700;color:var(--text);font-size:15px}
.srr-actions{display:flex;gap:4px;flex:none}
.srr-arrow{width:34px;height:34px;border-radius:9px;background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:14px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;justify-content:center}
.srr-arrow:hover:not(:disabled){background:color-mix(in srgb,var(--acc) 18%,var(--surface));border-color:var(--acc)}
.srr-arrow:disabled{opacity:.3;cursor:not-allowed}
.sgh-hint{font-family:'Archivo',sans-serif;font-weight:400;font-style:normal;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px}
.sim-progress{display:flex;align-items:center;gap:10px;flex:1;min-width:200px;max-width:380px;font-family:'Archivo',sans-serif;font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}
.sim-progress .sp-bar{flex:1;height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}
.sim-progress .sp-fill{display:block;height:100%;background:linear-gradient(90deg,var(--acc),var(--acc-2));border-radius:999px;transition:width .25s ease-out}
.sim-progress .sp-num{white-space:nowrap}
.sim-progress .sp-num b{font-size:14px;color:var(--text)}

.sim-section-title{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:clamp(20px,3.2vw,28px);letter-spacing:-.5px;margin:32px 0 14px;color:var(--text);text-transform:uppercase}
.sim-bracket-info{padding:14px 18px;background:color-mix(in srgb,var(--acc) 8%,var(--surface));border:1px dashed color-mix(in srgb,var(--acc) 50%,var(--line));border-radius:12px;color:var(--text);font-size:14px;margin-bottom:14px}

.sim-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:18px}
.sim-group{background:var(--surface);border:1.5px solid var(--line);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s}
.sim-group.complete{border-color:color-mix(in srgb,var(--acc) 60%,var(--line));background:color-mix(in srgb,var(--acc) 5%,var(--surface))}
.sim-group-head{display:flex;align-items:center;gap:10px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:18px;color:var(--text)}
.sim-group-head .badge{background:var(--acc);color:var(--on-acc);font-size:13px;padding:3px 10px;border-radius:7px;font-style:normal;font-weight:900}
.sim-group-head .sgh-title{flex:1}
.sim-done{color:var(--acc-text);font-size:20px;font-weight:900}

/* Tabla del grupo */
.sim-table-wrap{overflow:hidden;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);width:100%;min-width:0}
.sim-table{width:100%;border-collapse:collapse;font-family:'Archivo',sans-serif;font-size:12px;table-layout:fixed}
.sim-table thead th{padding:8px 2px;text-align:center;color:var(--text-dim);font-weight:700;text-transform:uppercase;letter-spacing:.3px;font-size:10px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--surface-2) 50%,var(--bg));width:24px}
.sim-table thead th.th-team{width:auto}
.sim-table tbody td{padding:7px 2px;text-align:center;color:var(--text);border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent);font-variant-numeric:tabular-nums;font-size:11.5px}
.sim-table tbody tr:last-child td{border-bottom:none}
.sim-table td.team{text-align:left;padding-left:8px;display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}
.sim-table td.team .st-flag{display:inline-flex;align-items:center;justify-content:center;flex:none}
.sim-table td.team .st-name{font-family:'Archivo',sans-serif;font-weight:600;font-size:12.5px;letter-spacing:-.1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.sim-table td.pos{font-weight:700;color:var(--text-dim);font-size:11px}
.sim-table td.pts{font-weight:900;font-size:13px;color:var(--text);font-style:italic}
.sim-table tr.qualify{background:color-mix(in srgb,#22c55e 8%,transparent)}
.sim-table tr.qualify td.pos,.sim-table tr.qualify td.pts{color:#86efac}
.sim-table tr.qualify td.team .st-name{color:var(--text);font-weight:700}
.sim-table tr.third{background:color-mix(in srgb,var(--acc-2) 10%,transparent)}
.sim-table tr.third td.pos{color:var(--acc2-text)}

/* Inputs de score */
.sim-matches{display:flex;flex-direction:column;gap:8px}
.sim-match{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;padding:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px}
.sim-match .sm-team{display:flex;align-items:center;gap:8px;font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;color:var(--text);min-width:0}
.sim-match .sm-home{justify-content:flex-end;text-align:right}
.sim-match .sm-away{justify-content:flex-start;text-align:left}
.sim-match .sm-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sim-match .sm-flag{flex:none}
.sim-match .sm-score{display:flex;align-items:center;gap:6px;flex:none}
.sim-match .sm-score input{width:42px;height:42px;text-align:center;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:18px;background:var(--bg);border:2px solid var(--line);color:var(--text);border-radius:10px;padding:0;-moz-appearance:textfield}
.sim-match .sm-score input::-webkit-outer-spin-button,.sim-match .sm-score input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
/* Foco más suave (sin glow neón) */
.sim-match .sm-score input:focus{outline:none;border-color:color-mix(in srgb,#22c55e 50%,var(--line));background:color-mix(in srgb,#22c55e 6%,var(--bg));box-shadow:0 0 0 2px color-mix(in srgb,#22c55e 12%,transparent)}
.sim-match .sm-dash{color:var(--text-dim);font-weight:700;font-size:14px}

/* Mejores 3ros */
.sim-thirds-wrap{margin-bottom:14px}
.sim-thirds-empty{padding:18px;text-align:center;color:var(--text-dim);font-size:14px;background:var(--surface);border:1px dashed var(--line);border-radius:12px}
.badge-mini{display:inline-block;padding:2px 8px;border-radius:6px;font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-mini-acc{background:var(--acc);color:var(--on-acc)}

@media (max-width:560px){
  .sim-groups{grid-template-columns:1fr}
  .sim-match{grid-template-columns:1fr auto 1fr;gap:6px;padding:8px}
  .sim-match .sm-name{font-size:12px}
  .sim-match .sm-score input{width:38px;height:38px;font-size:16px}
  .sim-table thead th,.sim-table tbody td{padding:6px 1px;font-size:10px}
  .sim-table thead th{width:20px}
  .sim-table td.team{padding-left:4px;gap:4px}
  .sim-table td.team .st-name{font-size:11px}
}
.pred-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:28px}
.pgcard{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px}
.pgcard h4{font-style:italic;font-weight:900;font-size:19px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.pgcard h4 .badge{background:var(--acc);color:var(--on-acc);font-size:13px;padding:2px 9px;border-radius:7px;font-style:normal}
.prow{display:flex;align-items:center;gap:9px;padding:8px;border-radius:10px;transition:.15s;border:1px solid transparent;margin-bottom:4px;background:var(--surface-2)}
.prow.pos1{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 12%,transparent)}
.prow.pos2{border-color:var(--acc-2);background:color-mix(in srgb,var(--acc-2) 10%,transparent)}
.prow .pnum{font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;width:30px;text-align:center;color:var(--text-dim)}
.prow.pos1 .pnum{color:var(--acc-text)}.prow.pos2 .pnum{color:var(--acc2-text)}
.prow .pflag{display:inline-flex;align-items:center;justify-content:center;min-width:34px}.prow .pname{flex:1;font-weight:600;font-size:14px}
.prow .phand{opacity:.55;font-size:13px;cursor:pointer;padding:2px 5px;border-radius:6px}
.prow .phand:hover{opacity:1;background:var(--surface)}
.pg-hint{font-family:'Archivo',sans-serif;font-size:10px;color:var(--text-dim);margin-top:6px;text-align:center}
.pred-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:10px}
.bracket-wrap{margin-top:30px;overflow-x:auto;padding-bottom:14px}
.bracket{display:flex;min-width:900px;gap:24px;padding:10px 0}
.bcol{display:flex;flex-direction:column;justify-content:space-around;gap:14px;flex:1;min-width:150px}
.bcol-title{font-family:'Archivo',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--acc-text);text-align:center;margin-bottom:6px;font-weight:700}
.btie{background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.bteam{display:flex;align-items:center;gap:7px;padding:8px 10px;cursor:pointer;transition:.15s;font-size:13px;font-weight:600}
.bteam:first-child{border-bottom:1px solid var(--line)}
.bteam:hover{background:var(--surface-2)}
.bteam.win{background:color-mix(in srgb,var(--acc) 20%,var(--surface-2));color:var(--acc-text);border-color:color-mix(in srgb,var(--acc) 55%,var(--line))}
.bteam .bflag{display:inline-flex;align-items:center;justify-content:center;min-width:28px}.bteam .bname{flex:1}
.bteam.empty{color:var(--text-dim);font-style:italic;cursor:default;opacity:.5}
.champion-box{text-align:center;margin-top:24px;padding:26px;border:1px dashed var(--line);border-radius:18px;background:color-mix(in srgb,var(--acc) 6%,transparent)}
.champion-box .ctitle{font-family:'Archivo',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim)}
.champion-box .cwinner{font-style:italic;font-weight:900;font-size:clamp(30px,6vw,54px);letter-spacing:-1px;margin-top:6px;color:var(--acc-text)}
.champion-box .cwinner.empty{color:var(--text-dim);opacity:.5;font-size:24px}
/* MODAL */
.modal-bg{position:fixed;inset:0;z-index:200;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:16px;overflow:hidden;overscroll-behavior:contain;touch-action:none}
.modal-bg.open{display:flex}
.modal{background:var(--bg-2);border:1px solid var(--line);border-radius:20px;max-width:720px;width:100%;padding:28px;position:relative;animation:rise .4s}
.modal-close{position:absolute;top:16px;right:16px;background:var(--surface-2);border:none;color:var(--text);width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;transition:.2s}
.modal-close:hover{background:var(--acc-3);color:#fff}
.modal h3{font-style:italic;font-weight:900;font-size:32px;letter-spacing:-1px;margin-bottom:6px}
.modal .modal-sub{color:var(--text-dim);font-size:14px;margin-bottom:20px}
/* ============================================================
   MATCH CARD — versión pro (modal de Grupo).
   Layout: header con estado + fecha/hora, body con equipos VS
   centrado y marcador grande, footer con estadio + canales TV.
   ============================================================ */
.match{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:0;margin-bottom:14px;overflow:hidden;transition:.2s}
.match:hover{border-color:color-mix(in srgb,var(--acc) 30%,var(--line))}

/* Header: estado + fecha/hora */
.m-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 16px;background:color-mix(in srgb,var(--text) 4%,transparent);border-bottom:1px solid var(--line);flex-wrap:wrap}
.m-status{display:inline-flex;align-items:center;gap:6px;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:4px 10px;border-radius:30px}
.m-status-upcoming{background:color-mix(in srgb,var(--acc-2) 14%,transparent);color:var(--acc2-text);border:1px solid color-mix(in srgb,var(--acc-2) 28%,var(--line))}
.m-status-live{background:color-mix(in srgb,#e0322a 18%,transparent);color:#ff6b65;border:1px solid color-mix(in srgb,#e0322a 35%,var(--line))}
.m-status-live .ms-dot{width:7px;height:7px;border-radius:50%;background:#e0322a;animation:livePulse 1.1s infinite}
.m-status-ft{background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--acc-text);border:1px solid color-mix(in srgb,var(--acc) 28%,var(--line))}
.m-when{display:inline-flex;align-items:center;gap:8px;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:12.5px;font-weight:500;letter-spacing:.1px}
.m-when .m-ico{width:14px;height:14px;color:var(--text-dim);flex:none}
.m-when-date{color:var(--text);font-weight:600}
.m-when-time{color:var(--acc-text);font-weight:700}

/* Body: equipos VS marcador */
.m-body{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;padding:18px 16px}
.m-side{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:0}
.m-side-h{order:1}
.m-side-a{order:3}
.m-flag{display:flex;align-items:center;justify-content:center}
.m-flag .fb-flag,.m-flag img,.m-flag svg{width:48px !important;height:34px !important;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.m-team{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:16px;letter-spacing:-.3px;color:var(--text);text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 2px}
.m-center{order:2;display:flex;align-items:center;justify-content:center;min-width:90px}
.m-score-big{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:36px;letter-spacing:-1.5px;color:var(--text);line-height:1;display:inline-flex;align-items:center;gap:8px}
.m-score-sep{color:var(--text-dim);font-size:.7em;font-weight:700;letter-spacing:0}
.m-vs{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:18px;letter-spacing:1px;color:var(--text-dim);padding:8px 14px;background:color-mix(in srgb,var(--text) 5%,transparent);border-radius:30px;border:1px solid var(--line)}

/* Venue */
.m-venue{display:flex;align-items:center;gap:7px;padding:0 16px 14px;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:11.5px;font-weight:600;letter-spacing:.3px}
.m-venue .m-ico{width:13px;height:13px;color:var(--text-dim);flex:none}

/* Footer TV — Dónde verlo */
.tv-row{padding:12px 16px;border-top:1px solid var(--line);background:color-mix(in srgb,var(--text) 3%,transparent)}
.tv-label{display:flex;align-items:center;gap:7px;font-family:'Archivo',sans-serif;font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--acc2-text);font-weight:700;margin-bottom:9px}
.tv-label .m-ico{width:14px;height:14px;flex:none}
.tv-label b{color:var(--acc-text);font-weight:800}

@media(max-width:560px){
  .m-body{grid-template-columns:1fr auto 1fr;gap:8px;padding:16px 12px}
  .m-team{font-size:13px}
  .m-flag .fb-flag,.m-flag img,.m-flag svg{width:40px !important;height:28px !important}
  .m-score-big{font-size:28px}
  .m-vs{font-size:15px;padding:6px 11px}
  .m-header,.m-venue,.tv-row{padding-left:12px;padding-right:12px}
}
.tv-tags,.tv-chips{display:flex;flex-wrap:wrap;gap:7px}
.tv-tag{background:color-mix(in srgb,var(--acc-2) 14%,transparent);border:1px solid color-mix(in srgb,var(--acc-2) 35%,transparent);color:var(--acc2-text);font-size:11px;font-weight:600;padding:4px 10px;border-radius:30px}
/* Chip emisora estilo wordmark: el chip ENTERO pintado con el color de marca,
   el nombre tipográfico dentro. Más reconocible que un monograma genérico. */
.tv-chip2{display:inline-flex;align-items:center;gap:7px;border-radius:10px;padding:9px 16px;font-family:'Archivo',sans-serif;font-size:14px;line-height:1;letter-spacing:-.3px;transition:.18s cubic-bezier(.2,.8,.2,1);cursor:default;text-transform:none;border:1px solid rgba(255,255,255,.08);box-shadow:0 2px 6px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.08);text-decoration:none;position:relative}
.tv-chip2:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.12)}
.tv-chip2-link{cursor:pointer}
.tv-chip2-link:hover{filter:brightness(1.1)}
.tv-chip2-link:active{transform:translateY(0)}
.tv-chip2-text{display:inline-block;white-space:nowrap}
.tv-chip2-ico{display:inline-flex;align-items:center;justify-content:center;flex:none}
.tv-chip2-ico svg{display:block}
.tv-chip2-dot{display:inline-block;width:5px;height:5px;border-radius:50%;margin-left:1px;align-self:center}
.tv-chip2-ext{display:inline-flex;align-items:center;justify-content:center;opacity:.6;margin-left:2px;transition:opacity .15s;flex:none}
.tv-chip2-link:hover .tv-chip2-ext{opacity:1}
.country-pick{margin-bottom:18px}
.country-pick label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);display:block;margin-bottom:6px}
.country-pick select{width:100%;background:var(--surface-2);border:1px solid var(--line);color:var(--text);padding:11px 14px;border-radius:10px;font-family:'Archivo';font-size:14px;cursor:pointer}
/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:38px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;text-align:center}
.stat-num{font-style:italic;font-weight:900;font-size:52px;color:var(--acc-text);line-height:1}
.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin-top:6px}
/* DONATE */
.donate-card{background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 8%,transparent),color-mix(in srgb,var(--acc-2) 5%,transparent));border:1px solid var(--line);border-radius:24px;padding:40px;text-align:center;max-width:680px;margin:0 auto;position:relative;overflow:hidden}
.donate-card::after{content:'⚽';position:absolute;font-size:200px;opacity:.05;bottom:-50px;right:-30px}
.donate-card h3{font-style:italic;font-weight:900;font-size:clamp(30px,5.5vw,50px);line-height:.95;letter-spacing:-1px;margin-bottom:14px}
.donate-card p{color:var(--text-dim);font-size:16px;max-width:440px;margin:0 auto 24px}
.reward-head{margin-bottom:14px}
.reward-head b{font-size:15px;display:block}
.reward-head span{font-size:13px;color:var(--text-dim)}
.wp-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0 auto 22px;max-width:480px}
.wp-card{position:relative;border-radius:10px;overflow:hidden;border:2px solid var(--line);cursor:pointer;transition:.2s;aspect-ratio:16/10}
.wp-card:hover{transform:translateY(-3px)}
.wp-card.active{border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 30%,transparent)}
.wp-card canvas{width:100%;height:100%;display:block}
.wp-card .wp-pick{position:absolute;top:3px;right:3px;width:16px;height:16px;border-radius:50%;background:var(--acc);color:var(--on-acc);font-size:10px;display:none;align-items:center;justify-content:center;font-weight:900}
.wp-card.active .wp-pick{display:flex}
@media(max-width:560px){.wp-gallery{grid-template-columns:repeat(2,1fr)}}
.amounts{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.amount-btn{background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:700;font-size:16px;padding:13px 20px;border-radius:12px;cursor:pointer;transition:.2s}
.amount-btn:hover{border-color:var(--acc);color:var(--acc-text)}
.amount-btn.active{background:var(--acc);color:var(--on-acc);border-color:var(--acc)}
.custom-amount{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:22px}
.custom-amount span{font-family:'Archivo',sans-serif;font-size:19px;color:var(--acc-text)}
.custom-amount input{background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-size:17px;padding:12px 16px;border-radius:12px;width:160px;text-align:center}
.custom-amount input:focus{outline:none;border-color:var(--acc)}
.mp-btn{background:#00b1ea;color:#fff;font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.5px;padding:16px 34px;border-radius:50px;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:.25s;box-shadow:0 8px 30px rgba(0,177,234,.4)}
.mp-btn:hover{transform:translateY(-3px) scale(1.02)}
.dl-btn{margin-top:14px;background:var(--surface-2);color:var(--text);border:1px solid var(--line);font-weight:700;font-size:13px;padding:11px 22px;border-radius:50px;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;gap:8px}
.dl-btn:hover{border-color:var(--acc);color:var(--acc-text)}
.dl-btn.locked{opacity:.55;cursor:not-allowed;border-style:dashed}
.dl-btn.locked:hover{border-color:var(--line);color:var(--text)}
.dl-btn.unlocked{border-color:var(--acc);color:var(--acc-text);animation:dlPulse 1.6s ease-out 2}
@keyframes dlPulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--acc) 60%,transparent)}100%{box-shadow:0 0 0 14px transparent}}
.wp-card.locked::after{content:"🔒";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.55);font-size:28px;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.mp-btn.disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.mp-btn.disabled:hover{transform:none}
.amt-hint{font-family:'Archivo',sans-serif;font-size:11px;color:var(--acc-3);margin:-12px 0 14px;min-height:14px;text-align:center}
.mp-thanks{margin:14px 0 0;font-family:'Archivo',sans-serif;font-size:12px;color:var(--acc-text);font-weight:700;text-align:center}
.donate-foot{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);margin-top:18px}

/* ===== TICKET "Bancá Fulbazo" — entrada de hincha ===== */
.ticket{margin:0 auto;background:linear-gradient(150deg, color-mix(in srgb,var(--acc) 12%,var(--surface)), color-mix(in srgb,var(--acc-2) 8%,var(--surface-2)));border-radius:22px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4);position:relative;border:1px solid var(--line)}
html[data-mode="light"] .ticket{box-shadow:0 20px 50px rgba(0,0,0,.15)}
.ticket .tk-top{padding:32px 32px 28px;border-bottom:2px dashed var(--line);position:relative;text-align:center}
.ticket .tk-top>*{max-width:760px;margin-left:auto;margin-right:auto}
.ticket .tk-top::after,.ticket .tk-top::before{content:'';position:absolute;bottom:-13px;width:26px;height:26px;border-radius:50%;background:var(--bg)}
.ticket .tk-top::before{left:-13px}.ticket .tk-top::after{right:-13px}
.tk-head{display:flex;align-items:center;gap:16px;margin-bottom:6px;justify-content:center;text-align:left}
.tk-head .tk-logo{flex:none;width:84px;height:84px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 4px 10px rgba(0,0,0,.35))}
.tk-head .tk-logo svg,.tk-head .tk-logo img{width:100%;height:100%;object-fit:contain;display:block}
.tk-head .tk-ttl{font-style:italic;font-weight:900;font-size:30px;line-height:1;color:var(--text)}
.tk-head .tk-ttl small{display:block;font-style:normal;font-family:'Archivo',sans-serif;font-weight:700;font-size:11.5px;color:var(--acc-text);letter-spacing:2px;text-transform:uppercase;margin-top:6px}
.tk-sub{color:var(--text-dim);font-size:14.5px;line-height:1.55;margin-top:14px;max-width:560px;margin-left:auto;margin-right:auto}

.ticket .tk-mid{padding:30px 32px}
.ticket .tk-mid>*{max-width:760px;margin-left:auto;margin-right:auto}
.ticket .tk-mid .tk-amounts{max-width:none}
.tk-label{font-family:'Archivo',sans-serif;font-size:11.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--acc-text);margin-bottom:14px;text-align:center}
.tk-label.tk-label-acc{color:var(--acc-text)}
.tk-amounts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
/* Cuando el ticket es ancho (desktop), los 4 montos van en 1 fila y "Otro" abajo full */
@media (min-width:760px){
  .tk-amounts{grid-template-columns:repeat(4,1fr)}
  .tk-amounts .tk-amt.tk-other{grid-column:2 / 4}
}
.tk-amt{background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);border-radius:13px;padding:14px 16px;cursor:pointer;transition:.18s;display:flex;align-items:center;justify-content:space-between;font-family:'Archivo',sans-serif}
.tk-amt:hover{border-color:var(--acc)}
.tk-amt:focus-visible{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 30%,transparent)}
.tk-amt .v{font-style:italic;font-weight:900;font-size:20px;letter-spacing:-.3px}
.tk-amt .tk{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.tk-amt.sel{background:var(--acc);color:var(--on-acc);border-color:var(--acc)}
.tk-amt.sel .tk{color:color-mix(in srgb,var(--on-acc) 70%,transparent)}
.tk-amt.tk-other{grid-column:span 2;justify-content:center;align-items:center;flex-direction:column;gap:3px;color:var(--text-dim);font-weight:700;font-size:14px;padding:12px 16px;text-align:center}
.tk-amt.tk-other .v{font-size:22px}
.tk-amt.tk-other .tk{font-size:10.5px;letter-spacing:.8px}
.tk-amt.tk-other:hover{color:var(--acc-text)}

.tk-amt-note{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);line-height:1.5;margin:-4px 0 14px;text-align:center}

/* Identidad del donante en el ticket */
.tk-identity-slot{margin-bottom:6px}
.tk-identity{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;font-size:13.5px}
.tk-identity-anon{background:color-mix(in srgb,var(--acc) 8%,var(--surface-2));border:1.5px dashed color-mix(in srgb,var(--acc) 35%,var(--line));justify-content:center;flex-wrap:wrap;gap:14px;padding:18px 20px;text-align:center}
.tk-identity-anon .tk-id-msg{color:var(--text);font-weight:700;font-size:14px;line-height:1.4}
.tk-identity-anon .tk-id-btn{background:var(--acc);border:none;color:var(--on-acc);font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14px;padding:11px 22px;border-radius:30px;cursor:pointer;text-decoration:none;transition:.18s;white-space:nowrap;box-shadow:0 8px 20px color-mix(in srgb,var(--acc) 30%,transparent);letter-spacing:.3px}
.tk-identity-anon .tk-id-btn:hover{transform:translateY(-1px);filter:brightness(1.06);box-shadow:0 12px 26px color-mix(in srgb,var(--acc) 38%,transparent)}
.tk-identity-anon .tk-id-btn:focus-visible{outline:2px solid var(--acc);outline-offset:3px}
.tk-identity-anon .tk-id-link{color:var(--text-dim);font-family:'Archivo',sans-serif;font-weight:600;font-size:12px;text-decoration:none;border-bottom:1px dashed var(--text-dim);padding-bottom:1px;white-space:nowrap;transition:.15s}
.tk-identity-anon .tk-id-link:hover{color:var(--acc-text);border-color:var(--acc)}
.tk-identity-logged{background:color-mix(in srgb,var(--acc) 12%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line))}
.tk-identity-register{background:color-mix(in srgb,var(--acc) 8%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 30%,var(--line));border-radius:12px;padding:16px}
.tk-identity-register .tk-reg-head{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.tk-identity-register .tk-reg-icon{font-size:28px;line-height:1}
.tk-identity-register .tk-reg-title{font-style:italic;font-weight:900;font-size:15px;color:var(--text);letter-spacing:-.2px}
.tk-identity-register .tk-reg-help{font-size:12px;color:var(--text-dim);margin-top:3px;line-height:1.4}
.tk-identity-register .pi-label{display:block;font-family:'Archivo',sans-serif;font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:8px}
.tk-identity-register .pi-avatars{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.tk-identity-register .pi-av{width:48px;height:48px;font-size:20px;padding:0;border:1.5px solid var(--line);background:var(--surface-2);border-radius:50%;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;justify-content:center;line-height:1;overflow:hidden}
.tk-identity-register .pi-av .fb-avatar{width:100%!important;height:100%!important}
.tk-identity-register .pi-av:hover{border-color:var(--acc)}
.tk-identity-register .pi-av.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 22%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--acc) 22%,transparent)}
.tk-identity-register .pi-row{display:flex;gap:8px}
.tk-identity-register .pi-row input{flex:1;background:var(--surface);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-size:14px;font-weight:700;padding:10px 12px;border-radius:9px}
.tk-identity-register .pi-row input:focus{outline:none;border-color:var(--acc)}
.tk-identity-register .pi-row .btn{padding:10px 14px;font-size:13px;border-radius:9px;white-space:nowrap}
.tk-identity-register .pi-feedback{margin-top:10px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;min-height:14px}
.tk-identity-register .pi-feedback.ok{color:var(--acc-text)}
.tk-identity-register .pi-feedback.err{color:var(--acc-3)}
.tk-identity-logged .tk-id-avatar{font-size:28px;line-height:1;flex:none;display:inline-flex;width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--surface-2);border:1.5px solid var(--line)}
.tk-identity-logged .tk-id-avatar .fb-avatar{width:100%!important;height:100%!important}
.tk-identity-logged .tk-id-name{font-style:italic;font-weight:900;font-size:16px;letter-spacing:-.2px;color:var(--text)}
.tk-identity-logged .tk-id-note{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);margin-top:2px}

/* ============================================================
   EN VIVO AHORA — sección hero que aparece cuando hay partidos
   del Mundial 2026 en curso (Fase 4).
   ============================================================ */
.live-now-section{padding:40px 0 10px;border-top:1px solid var(--line);background:linear-gradient(180deg,color-mix(in srgb,#e0322a 4%,transparent) 0%,transparent 80%)}
.live-now-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.ln-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#e0322a;color:#fff;font-family:'Archivo';font-style:italic;font-weight:900;font-size:11.5px;border-radius:30px;text-transform:uppercase;letter-spacing:.8px}
.ln-badge .ln-pulse{width:8px;height:8px;border-radius:50%;background:#fff;animation:lnPulse 1.2s infinite}
@keyframes lnPulse{0%,100%{opacity:1}50%{opacity:.35}}
.live-now-title{font-family:'Archivo';font-style:italic;font-weight:900;font-size:clamp(22px,3.6vw,30px);color:var(--text);margin:0;letter-spacing:-.5px}
.live-now-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.ln-card{background:var(--surface);border:1.5px solid color-mix(in srgb,#e0322a 30%,var(--line));border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;cursor:pointer;transition:.2s;text-decoration:none;color:inherit}
.ln-card:hover{transform:translateY(-3px);border-color:#e0322a;box-shadow:0 12px 28px color-mix(in srgb,#e0322a 18%,transparent)}
.ln-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:#e0322a}
.ln-card .ln-min{display:inline-flex;align-items:center;gap:6px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;color:#ff6b65;text-transform:uppercase;letter-spacing:.8px}
.ln-card .ln-min .d{width:6px;height:6px;border-radius:50%;background:#e0322a;animation:lnPulse 1.2s infinite}
.ln-team{display:flex;align-items:center;gap:11px;padding:6px 0}
.ln-team img,.ln-team .fb-flag{width:32px;height:22px;border-radius:3px;flex:none;object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.ln-team .ln-name{font-family:'Archivo';font-weight:800;font-size:15px;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ln-team .ln-score{font-family:'Archivo';font-style:italic;font-weight:900;font-size:24px;color:var(--text);letter-spacing:-.5px;min-width:24px;text-align:center}
.ln-team-sep{height:1px;background:var(--line);margin:2px 0}

@media(max-width:560px){
  .live-now-section{padding:28px 0 4px}
  .ln-card{padding:14px}
  .ln-team .ln-name{font-size:14px}
  .ln-team .ln-score{font-size:20px}
}

/* ============================================================
   MURO DE HINCHAS — versión pro
   Cada card: avatar + nombre + medalla por tier + tiempo + monto.
   Top contributors destacados con borde de color del tier.
   ============================================================ */
.muro-section{padding-top:0}
.muro-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:18px;align-items:stretch}
.muro-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px 16px;display:flex;align-items:center;gap:12px;transition:transform .2s,border-color .2s,box-shadow .2s;overflow:hidden}
.muro-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:.2s}
.muro-card:hover{border-color:color-mix(in srgb,var(--acc) 40%,var(--line));transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.18)}
/* Borde lateral coloreado según el tier */
.muro-card[data-tier="hincha"]::before{background:#cd7f32}
.muro-card[data-tier="capitan"]::before{background:#c0c0c0}
.muro-card[data-tier="mvp"]::before{background:#ffd700}
.muro-card[data-tier="leyenda"]::before{background:#7fdfff}
.muro-card[data-tier="crack"]::before{background:linear-gradient(180deg,#ff9d00,#ff3d7f)}
.muro-card[data-tier="leyenda"],.muro-card[data-tier="crack"]{border-color:color-mix(in srgb,var(--acc) 35%,var(--line));box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 12%,transparent)}

.muro-avatar{position:relative;flex:none;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--acc) 14%,var(--surface-2));border-radius:50%;overflow:hidden;border:1.5px solid var(--line)}
.muro-avatar .fb-avatar{width:100%!important;height:100%!important}
.muro-info{min-width:0;flex:1}
.muro-name-row{display:flex;align-items:center;gap:6px;min-width:0}
.muro-name{font-style:italic;font-weight:900;font-size:15px;letter-spacing:-.2px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.muro-meta{display:flex;align-items:center;gap:8px;margin-top:2px}
.muro-date{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim)}
.muro-amount{font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;color:var(--acc-text);letter-spacing:.2px}
.muro-empty{grid-column:1/-1;padding:24px;text-align:center;background:var(--surface);border:1px dashed var(--line);border-radius:14px;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:13px}

/* Tier badge: SVG con color por nivel + pulso sutil en el top tier */
.tier-badge{display:inline-flex;align-items:center;justify-content:center;flex:none;color:var(--tier-c,#cd7f32);filter:drop-shadow(0 1px 2px color-mix(in srgb,var(--tier-a,#000) 60%,transparent))}
.tier-badge svg{width:100%;height:100%;display:block}
.tier-crack{animation:tierShine 2.5s ease-in-out infinite}
@keyframes tierShine{0%,100%{filter:drop-shadow(0 0 3px var(--tier-c))}50%{filter:drop-shadow(0 0 8px var(--tier-c)) drop-shadow(0 0 14px var(--tier-c))}}

/* === HEADER CENTRADO (sec-head-center) === */
.sec-head.sec-head-center{text-align:center;max-width:680px;margin-left:auto;margin-right:auto}
.sec-head.sec-head-center .sec-desc{margin-left:auto;margin-right:auto}

/* === BLOQUE HERO DEL MURO — stats + leyenda unificados === */
.muro-hero{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:22px 28px;margin-top:22px;overflow:hidden;position:relative}
.muro-hero::before{content:'';position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,#cd7f32 0%,#c0c0c0 25%,#ffd700 50%,#7fdfff 75%,#ff9d00 100%);opacity:.6}

.mh-stats{display:flex;align-items:center;justify-content:center;gap:32px;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:18px}
.mh-stat{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:90px}
.mh-n{font-family:'Archivo';font-style:italic;font-weight:900;font-size:clamp(28px,4vw,36px);letter-spacing:-1px;color:var(--text);line-height:1;display:inline-flex;align-items:center;gap:8px}
.ms-top-badge{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}
.ms-top-lbl{font-size:.7em;color:var(--acc-text);line-height:1}
.mh-l{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-dim);line-height:1}
.mh-stat-sep{width:1px;height:42px;background:var(--line);flex:none}

.mh-tiers-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.mh-tiers-title>span:first-child{font-family:'Archivo';font-style:italic;font-weight:900;font-size:15px;color:var(--text);letter-spacing:-.2px}
.mh-tiers-hint{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim)}

/* === LEYENDA DE TIERS — chips con buena respiración === */
.muro-tiers-key{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.mtk-item{display:flex;align-items:center;gap:10px;padding:9px 14px 9px 9px;background:color-mix(in srgb,var(--text) 3%,var(--surface));border:1.5px solid var(--line);border-radius:999px;cursor:pointer;transition:.15s;font-family:'Archivo';color:var(--text)}
.mtk-item:hover{border-color:color-mix(in srgb,var(--tier-c) 55%,var(--line));transform:translateY(-1px)}
.mtk-item.active{border-color:var(--tier-c);background:color-mix(in srgb,var(--tier-c) 14%,var(--surface));box-shadow:0 0 0 2px color-mix(in srgb,var(--tier-c) 25%,transparent)}
.mtk-badge{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--tier-c) 18%,var(--surface-2));border-radius:50%}
.mtk-text{display:flex;flex-direction:column;line-height:1.05;gap:2px}
.mtk-name{font-style:italic;font-weight:900;font-size:13px;letter-spacing:-.2px}
.mtk-min{font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;color:var(--text-dim);letter-spacing:.4px}
.mtk-clear{background:transparent;border:1px solid var(--line);color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:7px 12px;border-radius:999px;cursor:pointer;transition:.15s;margin-left:auto}
.mtk-clear:hover{color:var(--text);border-color:var(--text-dim)}
.mtk-clear.hidden{display:none}

@media (max-width:680px){
  .muro-hero{padding:18px 16px}
  .mh-stats{gap:18px;padding-bottom:14px;margin-bottom:14px}
  .mh-stat{min-width:70px}
  .mh-n{font-size:24px}
  .mh-l{font-size:9.5px;letter-spacing:.8px}
  .mh-tiers-title{margin-bottom:10px}
  .muro-tiers-key{gap:8px}
  .mtk-item{padding:7px 12px 7px 7px;gap:8px}
  .mtk-badge{width:22px;height:22px}
  .mtk-name{font-size:12px}
  .mtk-min{font-size:9.5px}
}

@media (max-width:560px){
  .tk-identity-anon{flex-direction:column;align-items:stretch;text-align:center}
  .muro-list{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px}
  .muro-card{padding:12px 14px}
  .muro-avatar{width:42px;height:42px}
}

.tk-mp{width:100%;border:none;border-radius:14px;cursor:pointer;background:#009ee3;height:68px;display:flex;align-items:center;justify-content:center;gap:13px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:19px;color:#fff;transition:.2s;box-shadow:0 12px 32px rgba(0,158,227,.4);letter-spacing:.3px}
.tk-mp:hover{transform:translateY(-2px);box-shadow:0 16px 38px rgba(0,158,227,.55)}
.tk-mp:active{transform:translateY(0)}
.tk-mp svg{height:34px;width:auto;flex:none}
.tk-mp .tk-mp-logo{height:40px;width:auto;flex:none;display:block;background:#fff;border-radius:50%;padding:3px;box-shadow:0 2px 8px rgba(0,0,0,.18)}
@media (max-width:560px){
  .tk-mp .tk-mp-logo{height:34px}
  .tk-mp{font-size:16px;gap:10px;height:60px}
}

/* Callout MURO DE HINCHAS dentro de la card de MP — destaca que al pagar
   tu nombre va al muro. Estilo "premium ticket badge" con borde brillante,
   estrella pulsante y flecha apuntando al ancla #muroHinchas. */
.tk-muro-cta{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 22%,transparent),color-mix(in srgb,var(--acc-2) 18%,transparent));
  border:1.5px solid color-mix(in srgb,var(--acc) 60%,var(--line));
  border-radius:14px;
  padding:14px 16px;margin-bottom:14px;
  text-decoration:none;color:var(--text);
  position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s,border-color .2s;
  box-shadow:0 4px 18px color-mix(in srgb,var(--acc) 22%,transparent);
}
.tk-muro-cta::before{
  /* "Sweep" de brillo de izquierda a derecha — anima cada 4s */
  content:"";position:absolute;top:0;bottom:0;width:60%;left:-100%;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--acc) 55%,transparent),transparent);
  transform:skewX(-20deg);animation:muroSweep 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes muroSweep{
  0%,15%{left:-100%}
  50%{left:140%}
  50.001%,100%{left:140%}
}
.tk-muro-cta:hover{transform:translateY(-2px);border-color:var(--acc);box-shadow:0 8px 24px color-mix(in srgb,var(--acc) 32%,transparent)}
.tk-muro-star{
  flex:none;width:42px;height:42px;border-radius:50%;
  background:var(--acc);color:var(--on-acc);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 0 color-mix(in srgb,var(--acc) 50%,transparent);
  animation:muroPulse 2s ease-in-out infinite;
}
.tk-muro-star svg{width:22px;height:22px;display:block}
@keyframes muroPulse{
  0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--acc) 55%,transparent)}
  50%{box-shadow:0 0 0 8px color-mix(in srgb,var(--acc) 0%,transparent)}
}
.tk-muro-txt{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;position:relative;z-index:1}
.tk-muro-txt strong{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14.5px;color:var(--text);letter-spacing:-.2px;line-height:1.15}
.tk-muro-txt small{font-size:11.5px;color:var(--text-dim);line-height:1.35}
.tk-muro-arrow{flex:none;width:22px;height:22px;color:var(--acc-text);animation:muroBob 1.8s ease-in-out infinite}
@keyframes muroBob{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}
@media (max-width:560px){
  .tk-muro-cta{padding:12px 14px;gap:11px;border-radius:12px}
  .tk-muro-star{width:36px;height:36px}
  .tk-muro-star svg{width:18px;height:18px}
  .tk-muro-txt strong{font-size:13.5px}
  .tk-muro-txt small{font-size:11px}
}

.tk-secure{text-align:center;color:var(--text-dim);font-size:12px;margin-top:12px;font-family:'Archivo',sans-serif}

/* Sugerencias de monto (informativas, no clickeables) */
.tk-suggestions{margin-top:18px;text-align:center}
.tk-sug-label{display:inline-block;font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--text-dim);margin-bottom:10px}
.tk-sug-amts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.tk-sug{padding:6px 13px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:13px;color:var(--text-dim)}
.tk-sug-any{font-style:normal;font-weight:600;background:transparent;border-color:transparent;color:var(--acc-text)}

.tk-stub-desc{font-size:13.5px;color:var(--text-dim);margin:6px 0 14px;line-height:1.5;max-width:560px;margin-left:auto;margin-right:auto;text-align:center}

/* stub (talón con beneficios) */
.ticket .tk-stub{padding:24px 32px 26px;border-top:2px dashed var(--line);background:color-mix(in srgb,var(--bg) 30%,transparent);position:relative;text-align:center}
.ticket .tk-stub>*{max-width:560px;margin-left:auto;margin-right:auto}
.ticket .tk-stub .tk-label{text-align:center}
.ticket .tk-stub .tk-id-pending{justify-content:center;flex-wrap:wrap;text-align:center;margin-top:6px}
.ticket .tk-stub .tk-author{text-align:left}
.ticket .tk-stub::after,.ticket .tk-stub::before{content:'';position:absolute;top:-13px;width:26px;height:26px;border-radius:50%;background:var(--bg)}
.ticket .tk-stub::before{left:-13px}.ticket .tk-stub::after{right:-13px}
.tk-perk{display:flex;gap:13px;align-items:center;padding:9px 0}
.tk-perk .tk-ic{width:40px;height:40px;border-radius:11px;background:color-mix(in srgb,var(--acc) 16%,transparent);display:flex;align-items:center;justify-content:center;flex:none;color:var(--acc-text)}
.tk-perk .tk-ic svg{width:20px;height:20px}
.tk-perk h4{font-style:italic;font-weight:900;font-size:15px;letter-spacing:-.2px}
.tk-perk p{font-size:13px;color:var(--text-dim);margin-top:1px}

@media (max-width:560px){
  .ticket .tk-top,.ticket .tk-mid,.ticket .tk-stub{padding-left:22px;padding-right:22px}
  .tk-amounts{grid-template-columns:1fr}
  .tk-amt.tk-other{grid-column:span 1}
  .tk-head .tk-logo{width:50px;height:50px}
  .tk-head .tk-ttl{font-size:22px}
}
.scorers{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:24px;margin-top:24px}
.scorers h3{font-style:italic;font-weight:900;font-size:26px;margin-bottom:16px}
.scorer-row{display:flex;align-items:center;gap:13px;padding:12px 0;border-bottom:1px solid var(--line)}
.scorer-row:last-child{border:none}
.scorer-rank{font-family:'Archivo',sans-serif;font-weight:700;color:var(--acc-3);width:24px}
.scorer-flag{display:inline-flex;align-items:center;justify-content:center;min-width:32px}.scorer-name{flex:1;font-weight:600}
.scorer-team{font-size:12px;color:var(--text-dim)}
.scorer-goals{font-family:'Archivo',sans-serif;font-weight:700;color:var(--acc-text)}
.note-box{margin-top:16px;font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);border:1px dashed var(--line);padding:10px 14px;border-radius:10px}
@media(max-width:760px){
  .theme-pop{top:auto;bottom:20px;right:50%;transform:translateX(50%)}.theme-pop.open{animation:none}
}
/* ===== CALENDARIO estilo Sofascore/Promiedos ===== */
.cal-filters{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:24px}
.cal-filters button{background:var(--surface);border:1px solid var(--line);color:var(--text);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:9px 16px;border-radius:30px;cursor:pointer;transition:.2s}
.cal-filters button:hover{border-color:var(--acc);color:var(--acc-text)}
.cal-filters button.active{background:var(--acc);color:var(--on-acc);border-color:var(--acc)}
.cal-filters button .lv{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--acc-3);margin-right:5px;animation:pulse 1.3s infinite}
@keyframes pulse{50%{opacity:.3}}
.day-group{margin-bottom:36px}
.day-head{font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--acc-text);padding:10px 4px;border-bottom:1px solid var(--line);margin-bottom:8px}

/* Day header BIG estilo calendario (calendario.html) */
.day-head-big{display:flex;align-items:center;gap:18px;padding:10px 0 14px;margin:0 0 14px;border-bottom:2px solid var(--line);position:relative}
.day-head-big::after{content:'';position:absolute;left:0;bottom:-2px;width:64px;height:2px;background:var(--acc)}
.day-head-num{display:flex;flex-direction:column;align-items:center;justify-content:center;background:color-mix(in srgb,var(--acc) 15%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line));border-radius:12px;padding:8px 16px;min-width:78px;flex:none}
.day-head-num .day-num{font-style:italic;font-weight:900;font-size:42px;line-height:1;color:var(--acc-text);letter-spacing:-2px}
.day-head-num .day-mon{font-family:'Archivo',sans-serif;font-weight:600;font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin-top:3px}
.day-head-meta{flex:1;min-width:0}
.day-head-meta .day-name{font-style:italic;font-weight:900;font-size:24px;letter-spacing:-.5px;color:var(--text);text-transform:capitalize;line-height:1.1}
.day-head-meta .day-count{font-family:'Archivo',sans-serif;font-size:12.5px;color:var(--text-dim);letter-spacing:.1px;font-weight:500;margin-top:4px}

@media (max-width:560px){
  .day-head-big{gap:12px}
  .day-head-num{min-width:62px;padding:6px 12px}
  .day-head-num .day-num{font-size:32px}
  .day-head-meta .day-name{font-size:18px}
}
.cal-match{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:7px;cursor:pointer;transition:.15s}
.cal-match:hover{border-color:var(--acc);transform:translateX(3px)}
.cal-time{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:20px;letter-spacing:-.5px;color:var(--text);width:64px;flex:none;text-align:center;line-height:1}
.cal-time .cm-status{font-family:'Archivo',sans-serif;font-style:normal;font-size:10px;font-weight:600;display:block;letter-spacing:.2px;margin-top:3px;text-transform:uppercase}
.cal-time .cm-status.live{color:var(--acc-3);animation:pulse 1.3s infinite}
.cal-time .cm-status.ft{color:var(--text-dim)}
.cal-teams{flex:1;display:flex;flex-direction:column;gap:5px}
.cal-team{display:flex;align-items:center;gap:9px;font-weight:600;font-size:14px}
.cal-team .ct-flag{display:inline-flex;align-items:center;justify-content:center;min-width:34px}
.cal-team .ct-name{flex:1}
.cal-team .ct-score{font-family:'Archivo',sans-serif;font-weight:700;font-size:16px;min-width:22px;text-align:center}
.cal-team.winner .ct-name{color:var(--acc-text)}
.cal-gchip{font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;background:var(--surface-2);color:var(--text-dim);padding:3px 8px;border-radius:6px;flex:none}
.cal-arrow{color:var(--text-dim);font-size:18px;flex:none}
/* MATCH DETAIL MODAL */
.md-head{text-align:center;padding:10px 0 18px;border-bottom:1px solid var(--line);margin-bottom:18px}
.md-status{font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;letter-spacing:1px;margin-bottom:12px}
.md-status.live{color:var(--acc-3)}.md-status.ft{color:var(--text-dim)}.md-status.up{color:var(--acc-text)}
.md-teams{display:flex;align-items:center;justify-content:space-around;gap:10px}
.md-team{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}
.md-team .mt-flag{display:inline-flex;align-items:center;justify-content:center}
.md-team .mt-name{font-weight:700;font-size:15px;text-align:center}
.md-score{font-style:italic;font-weight:900;font-size:46px;letter-spacing:-1px}
.md-score .sc-min{display:block;font-size:12px;font-style:normal;font-weight:700;color:var(--acc-3);font-family:'Archivo',sans-serif}
.md-meta{font-family:'Archivo',sans-serif;font-size:12px;color:var(--text-dim);text-align:center;margin-top:14px;line-height:1.8}
/* Dónde verlo: selector de país + chips de emisoras */
.md-where{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:14px}
.md-where-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.md-where-label{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14px;color:var(--text);letter-spacing:-.2px}
.md-country-sel{background:var(--bg);border:1px solid var(--line);color:var(--text);padding:7px 12px;border-radius:30px;font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;cursor:pointer;outline:none;transition:.15s}
.md-country-sel:hover,.md-country-sel:focus{border-color:var(--acc)}
.md-tabs{display:flex;gap:6px;margin:18px 0 14px;border-bottom:1px solid var(--line)}
.md-tab{background:none;border:none;color:var(--text-dim);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:9px 12px;cursor:pointer;border-bottom:2px solid transparent;transition:.2s}
.md-tab.active{color:var(--acc-text);border-bottom-color:var(--acc)}
.md-panel{display:none}.md-panel.active{display:block}
.stat-line{margin-bottom:14px}
.stat-line .sl-top{display:flex;justify-content:space-between;font-family:'Archivo',sans-serif;font-size:13px;font-weight:700;margin-bottom:5px}
.sl-bar{height:7px;border-radius:6px;background:var(--surface-2);overflow:hidden;display:flex}
.sl-bar i{display:block;height:100%}
.sl-bar .sl-h{background:var(--acc)}.sl-bar .sl-a{background:var(--acc-2)}
.ev-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.ev-row:last-child{border:none}
.ev-min{font-family:'Archivo',sans-serif;font-size:12px;color:var(--text-dim);width:38px}
.ev-ico{font-size:16px}.ev-txt{flex:1}
.lineup-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.lineup-col h5{font-size:13px;font-weight:800;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.lineup-col .lp{font-size:13px;padding:6px 0;border-bottom:1px solid var(--line);color:var(--text-dim)}
/* BANDERAS — flagcdn.com (SVG) */
.fb-flag{display:inline-block;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,.18),0 1px 2px rgba(0,0,0,.25);vertical-align:-4px;background:var(--surface-2);object-fit:cover}
.fb-flag-fallback{display:inline-flex;align-items:center;justify-content:center;font-family:'Archivo',sans-serif;font-weight:700;font-size:10px;background:var(--surface-2);border:1px solid var(--line);color:var(--text);border-radius:3px;vertical-align:-4px;letter-spacing:.5px;box-sizing:border-box}
.live-banner{background:color-mix(in srgb,var(--acc-3) 12%,transparent);border:1px solid color-mix(in srgb,var(--acc-3) 30%,transparent);color:var(--acc-3);font-size:12px;font-weight:600;padding:10px 14px;border-radius:10px;margin-bottom:18px;text-align:center}
.live-status{display:inline-flex;align-items:center;gap:8px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;padding:6px 12px;border-radius:30px;margin-bottom:14px;border:1px solid var(--line);background:var(--surface)}
.live-status .ls-dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim)}
.live-status[data-state="loading"]{color:var(--acc2-text);border-color:color-mix(in srgb,var(--acc-2) 35%,transparent)}
.live-status[data-state="loading"] .ls-dot{background:var(--acc-2);animation:lsPulse 1s ease-in-out infinite}
.live-status[data-state="ok"]{color:var(--acc-text);border-color:color-mix(in srgb,var(--acc) 35%,transparent)}
.live-status[data-state="ok"] .ls-dot{background:var(--acc)}
.live-status[data-state="error"]{color:var(--acc-3);border-color:color-mix(in srgb,var(--acc-3) 35%,transparent)}
.live-status[data-state="error"] .ls-dot{background:var(--acc-3)}
@keyframes lsPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
/* NOTICIAS */
/* NOTICIAS — Cards con escenas SVG */
.news-status{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:7px 14px;border-radius:999px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;background:var(--surface-2);border:1px solid var(--line);color:var(--text-dim)}
.news-status .ns-dot{width:7px;height:7px;border-radius:50%;background:var(--text-dim)}
.news-status[data-state="loading"] .ns-dot{background:#ffd400;animation:nsPulse 1s ease-in-out infinite}
.news-status[data-state="live"]{background:color-mix(in srgb,#22c55e 18%,var(--surface-2));border-color:color-mix(in srgb,#22c55e 40%,var(--line));color:#22c55e}
.news-status[data-state="live"] .ns-dot{background:#22c55e}
.news-status[data-state="cache"] .ns-dot{background:#19e3ff}
.news-status[data-state="error"],.news-status[data-state="local"]{background:color-mix(in srgb,#ffd400 12%,var(--surface-2));border-color:color-mix(in srgb,#ffd400 30%,var(--line));color:#ffd400}
.news-status[data-state="error"] .ns-dot,.news-status[data-state="local"] .ns-dot{background:#ffd400}
@keyframes nsPulse{0%,100%{opacity:.4}50%{opacity:1}}
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.news-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;cursor:pointer;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.news-card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--acc) 50%,var(--line));box-shadow:0 22px 50px rgba(0,0,0,.45)}
html[data-mode="light"] .news-card:hover{box-shadow:0 18px 40px rgba(0,0,0,.18)}

.news-photo{position:relative;height:200px;overflow:hidden;background:var(--bg-2)}
.news-photo svg{width:100%;height:100%;display:block;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.news-card:hover .news-photo svg{transform:scale(1.06)}
/* Foto real de la noticia */
.news-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.2,.8,.2,1);z-index:2}
.news-card:hover .news-img{transform:scale(1.06)}
.news-photo-has-img .news-photo-svg{position:absolute;inset:0;opacity:0;z-index:1}
.news-photo-has-img::after{content:'';position:absolute;left:0;right:0;bottom:0;height:60%;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,0) 100%);z-index:3;pointer-events:none}
.news-photo-has-img .news-chip{z-index:4}
/* Si la foto falla, mostramos el SVG de fallback */
.news-photo-fallback .news-photo-svg{position:relative !important;opacity:1 !important;z-index:1}
.news-photo-fallback::after{display:none}
.news-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,color-mix(in srgb,var(--surface) 70%,transparent) 82%,var(--surface));pointer-events:none}

.news-chip{position:absolute;top:14px;left:14px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:11px;text-transform:uppercase;letter-spacing:.8px;padding:6px 12px;border-radius:30px;z-index:3;display:inline-flex;align-items:center;box-shadow:0 4px 12px rgba(0,0,0,.3);backdrop-filter:blur(4px)}
.news-chip-sel{background:#22d76b;color:#04210f}
.news-chip-sed{background:#ffd72e;color:#1a1300}
.news-chip-ent{background:#3aa3ff;color:#021426}
.news-chip-fav{background:#ff3a3a;color:#fff}
.news-chip-gen{background:var(--acc);color:var(--on-acc)}

.news-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.news-card h3{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:20px;line-height:1.15;letter-spacing:-.5px;color:var(--text);margin-bottom:10px}
.news-lead{font-size:14px;color:var(--text-dim);line-height:1.5;margin-bottom:auto;font-weight:500}
.news-foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.news-when{color:var(--text-dim);font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;font-family:'Archivo',sans-serif}
.news-when svg{width:14px;height:14px;opacity:.7}
.news-more{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:13px;color:var(--acc-text);display:flex;align-items:center;gap:5px;transition:gap .2s;letter-spacing:-.2px;white-space:nowrap}
.news-card:hover .news-more{gap:9px}

/* News responsive — móvil */
@media (max-width:760px){
  .news-grid{grid-template-columns:1fr;gap:14px}
  .news-photo{height:170px}
  .news-card h3{font-size:17px;line-height:1.2;margin-bottom:8px}
  .news-lead{font-size:13.5px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .news-body{padding:14px 16px 16px}
  .news-foot{margin-top:12px;padding-top:10px;gap:8px}
  .news-when{font-size:11px}
  .news-when svg{width:12px;height:12px}
  .news-more{font-size:12px}
  .news-chip{font-size:10px;padding:4px 9px;letter-spacing:.4px}
}
@media (max-width:380px){
  .news-photo{height:150px}
  .news-card h3{font-size:16px}
}

/* ===========================================================
   PRODE
   =========================================================== */
.prode-rules{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:18px 0 24px}
.prule{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:9px 16px;border-radius:30px;font-size:13px;font-weight:600}
.prule-pts{font-family:'Archivo',sans-serif;font-weight:700;padding:2px 8px;border-radius:30px;font-size:12px}
.prule-3 .prule-pts{background:var(--acc);color:var(--on-acc)}
.prule-1 .prule-pts{background:color-mix(in srgb,var(--acc-2) 30%,var(--surface-2));color:var(--acc2-text);border:1px solid color-mix(in srgb,var(--acc-2) 50%,transparent)}
.prule-0 .prule-pts{background:var(--surface-2);color:var(--text-dim)}

/* Identidad */
.prode-identity{margin:0 auto 22px;max-width:560px}
.pi-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px}
.pi-card h4{font-style:italic;font-weight:900;font-size:18px;margin-bottom:14px;letter-spacing:-.3px}

/* CTA "Entrar" simple del prode (reemplaza la vieja pantalla welcome) */
.pi-cta-login{max-width:480px;margin:32px auto;text-align:center;padding:40px 28px;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 8%,var(--surface)) 0%,var(--surface) 70%);border:1.5px solid color-mix(in srgb,var(--acc) 22%,var(--line));border-radius:22px;box-shadow:0 14px 40px rgba(0,0,0,.2)}
.pi-cta-icon{width:64px;height:64px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:18px;background:color-mix(in srgb,var(--acc) 16%,transparent);border:1.5px solid color-mix(in srgb,var(--acc) 35%,var(--line));color:var(--acc-text)}
.pi-cta-icon svg{width:32px;height:32px}
.pi-cta-title{font-family:'Archivo';font-style:italic;font-weight:900;font-size:clamp(22px,3.6vw,28px);letter-spacing:-.5px;color:var(--text);margin:0 0 10px;line-height:1.1}
.pi-cta-sub{color:var(--text-dim);font-size:14.5px;line-height:1.55;margin:0 0 22px;max-width:380px;margin-inline:auto}
.pi-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--acc);color:var(--on-acc);font-family:'Archivo';font-style:italic;font-weight:900;font-size:16px;padding:13px 32px;border:none;border-radius:12px;cursor:pointer;text-transform:uppercase;letter-spacing:.4px;transition:.15s;box-shadow:0 6px 18px color-mix(in srgb,var(--acc) 35%,transparent)}
.pi-cta-btn:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 10px 24px color-mix(in srgb,var(--acc) 45%,transparent)}
.pi-label{display:block;font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}
.pi-avatars{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.pi-av{width:54px;height:54px;font-size:22px;padding:0;border:1.5px solid var(--line);background:var(--surface-2);border-radius:50%;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;justify-content:center;line-height:1;overflow:hidden}
.pi-av .fb-avatar{width:100%!important;height:100%!important}
.pi-av:hover{transform:translateY(-2px);border-color:var(--acc)}
.pi-av.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 18%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 25%,transparent)}
.pi-row{display:flex;gap:10px;align-items:center}
.pi-row input{flex:1;background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-size:15px;font-weight:600;padding:12px 14px;border-radius:10px}
.pi-row input:focus{outline:none;border-color:var(--acc)}
.pi-row .btn{padding:12px 22px;font-size:13px;border-radius:10px}
.pi-saved{display:flex;align-items:center;gap:14px}
.pi-saved .pi-avatar{width:64px;height:64px;font-size:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:50%;border:1.5px solid var(--line);line-height:1;overflow:hidden;flex:none}
.pi-saved .pi-avatar .fb-avatar{width:100%!important;height:100%!important}
.pi-saved .pi-info{flex:1}
.pi-saved .pi-name{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.3px}
.pi-saved .pi-id{font-family:'Archivo',sans-serif;font-size:10px;color:var(--text-dim)}
.pi-saved .pi-edit{padding:8px 14px;font-size:12px;border-radius:30px}

/* Tabs */
.prode-tabs{display:flex;gap:6px;background:var(--surface);border:1px solid var(--line);padding:5px;border-radius:14px;margin:0 auto 18px;max-width:340px}
.prode-tab{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-weight:700;font-size:14px;padding:11px;border-radius:10px;cursor:pointer;transition:.2s}
.prode-tab:hover{color:var(--text)}
.prode-tab.active{background:var(--acc);color:var(--on-acc)}
.prode-panel{display:none}
.prode-panel.active{display:block}

/* Stats */
.prode-stats{display:flex;gap:14px;justify-content:center;margin:0 0 22px}
.pstat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 22px;min-width:140px;text-align:center}
.pstat-label{font-family:'Archivo',sans-serif;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin-bottom:4px}
.pstat-val{font-family:'Archivo',sans-serif;font-weight:700;font-size:24px}
.pstat-val .pstat-of{color:var(--text-dim);font-size:16px}
.pstat-pts{color:var(--acc-text)}

/* Match cards */
#prodeList .day-group{margin-bottom:18px}
#prodeList .day-head{font-family:'Archivo',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin:0 0 8px 6px;font-weight:700}

/* Jornadas — bloques visuales para fecha 1/2/3 con header destacado y
   estado "bloqueado" cuando aún no se desbloqueó. */
.jornada-block{margin-bottom:32px;padding-top:8px}
.jornada-title{display:flex;align-items:center;flex-wrap:wrap;gap:10px;font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;color:var(--text);padding:8px 4px 12px;margin:0 0 12px;border-bottom:2px solid color-mix(in srgb,var(--acc) 40%,var(--line))}
.jornada-title .jt-ball{width:32px;height:32px;object-fit:contain;flex:none}
.jornada-title small{font-family:'Archivo',sans-serif;font-style:normal;font-weight:600;font-size:13px;color:var(--text-dim);letter-spacing:0;line-height:1.3}
.jornada-block.jornada-locked{opacity:.55;position:relative}
.jornada-block.jornada-locked .jornada-title{border-bottom-color:var(--line);color:var(--text-dim)}
.jornada-block.jornada-locked::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent 0,transparent 12px,color-mix(in srgb,var(--text) 4%,transparent) 12px,color-mix(in srgb,var(--text) 4%,transparent) 24px);pointer-events:none;border-radius:14px}
.pm{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:8px;transition:.2s}
.pm:hover{border-color:color-mix(in srgb,var(--acc) 40%,var(--line))}
.pm.locked{opacity:.7;background:var(--surface-2)}
.pm-meta{font-family:'Archivo',sans-serif;font-size:10px;color:var(--text-dim);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.pm-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center}
.pm-team{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px}
.pm-team.pm-home{justify-content:flex-end;text-align:right}
.pm-team.pm-away{justify-content:flex-start;text-align:left}
.pm-name{flex:0 1 auto}
.pm-scores{display:flex;align-items:center;gap:8px}
.pm-input{width:48px;height:44px;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:700;font-size:20px;text-align:center;border-radius:10px;-moz-appearance:textfield;transition:.15s}
.pm-input::-webkit-outer-spin-button,.pm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pm-input:focus{outline:none;border-color:var(--acc);background:color-mix(in srgb,var(--acc) 8%,var(--surface-2))}
.pm-input:disabled{cursor:not-allowed;background:transparent;color:var(--text-dim);border-style:dashed}
.pm-dash{font-family:'Archivo',sans-serif;color:var(--text-dim);font-weight:700}
.pm-status-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:12px;font-family:'Archivo',sans-serif}
.pm-result{color:var(--text-dim);font-weight:700}
.pm-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:30px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
/* Tonos suaves — sacamos el neón fluo. Verde más apagado, no chillón. */
.pm-status.locked{background:color-mix(in srgb,var(--text-dim) 15%,transparent);color:var(--text-dim);border:1px solid color-mix(in srgb,var(--text-dim) 22%,transparent)}
.pm-status.saved{background:color-mix(in srgb,#22c55e 14%,transparent);color:#86efac;border:1px solid color-mix(in srgb,#22c55e 28%,transparent)}
.pm-status.pending{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--line)}
.pm-status.pts3{background:color-mix(in srgb,#22c55e 24%,#0a1410);color:#dcfce7;border:1px solid color-mix(in srgb,#22c55e 40%,transparent)}
.pm-status.pts1{background:color-mix(in srgb,#f59e0b 18%,transparent);color:#fcd34d;border:1px solid color-mix(in srgb,#f59e0b 35%,transparent)}
.pm-status.pts0{background:color-mix(in srgb,#ef4444 16%,transparent);color:#fca5a5;border:1px solid color-mix(in srgb,#ef4444 32%,transparent)}

.prode-actions{display:flex;gap:12px;justify-content:center;margin:24px 0 8px;flex-wrap:wrap}
.prode-actions .btn{padding:14px 28px}

/* === PRODE: layout 2 columnas con panel sticky lateral === */
.prode-play-layout{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}
.prode-play-main{min-width:0}
.prode-side{position:sticky;top:90px;background:var(--surface);border:1.5px solid var(--line);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 6px 22px rgba(0,0,0,.28)}
.prode-side-title{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);margin:0}
.prode-side-rules{display:flex;flex-direction:column;gap:8px}
.prode-side-rules .prule{padding:8px 12px;font-size:12.5px;justify-content:flex-start}
.prode-side-rules .prule-pts{font-size:11.5px;padding:2px 7px}
.prode-side-divider{height:1px;background:var(--line);margin:2px 0}
.prode-side-counter{font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:13.5px;text-align:center;padding:8px 12px;border-radius:10px;background:var(--surface-2);color:var(--text-dim);transition:.2s}
.prode-side-counter.has-changes{background:color-mix(in srgb,var(--acc) 18%,var(--surface-2));color:var(--text);border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line))}
.prode-side-counter.all-saved{color:#7ee69b}
.prode-side-save{width:100%;padding:13px 18px;font-size:14px}
.prode-side-save.pulse{animation:prode-save-pulse 1.6s infinite}
.prode-side-clear{width:100%;padding:10px 14px;font-size:12.5px;opacity:.85}
@keyframes prode-save-pulse{
  0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--acc) 50%,transparent)}
  50%{box-shadow:0 0 0 6px color-mix(in srgb,var(--acc) 0%,transparent)}
}

/* Mobile: el panel pasa a sticky bottom bar (compacto) */
@media (max-width:960px){
  .prode-play-layout{grid-template-columns:1fr;gap:0}
  .prode-side{position:fixed;left:12px;right:12px;bottom:12px;top:auto;flex-direction:row;flex-wrap:wrap;align-items:center;padding:10px 12px;gap:10px;z-index:50;backdrop-filter:blur(8px);background:color-mix(in srgb,var(--surface) 92%,transparent)}
  .prode-side-title{display:none}
  .prode-side-rules{flex-direction:row;gap:6px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none}
  .prode-side-rules::-webkit-scrollbar{display:none}
  .prode-side-rules .prule{flex:0 0 auto;padding:5px 9px;font-size:11px;gap:5px}
  .prode-side-divider{display:none}
  .prode-side-counter{flex:0 0 100%;order:99;padding:4px 10px;font-size:11.5px}
  .prode-side-save{flex:1 1 auto;padding:10px 14px;font-size:13px;width:auto;min-width:140px}
  .prode-side-clear{flex:0 0 auto;padding:8px 12px;font-size:11.5px;width:auto}
  /* padding-bottom al main para que el último partido no quede tapado */
  .prode-play-main{padding-bottom:140px}
}
@media (max-width:480px){
  .prode-side{left:8px;right:8px;bottom:8px;padding:8px 10px}
  .prode-side-rules .prule span:not(.prule-pts){display:none}
  .prode-side-rules .prule{padding:4px 7px}
}

/* Ranking */
.prode-rank-note{margin-bottom:14px;text-align:center}
.prode-rank-empty{text-align:center}
.rank-table{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.rk-head,.rk-row{display:grid;grid-template-columns:40px 50px 1fr 120px 80px;align-items:center;gap:18px;padding:12px 18px}
.rk-head{background:var(--surface-2);font-family:'Archivo',sans-serif;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);font-weight:700;white-space:nowrap}
.rk-head>span{overflow:hidden;text-overflow:ellipsis}
.rk-row{border-top:1px solid var(--line);font-weight:600}
.rk-row.me{background:color-mix(in srgb,var(--acc) 8%,transparent)}
.rk-pos{font-family:'Archivo',sans-serif;font-weight:700;color:var(--text-dim)}

/* === RANKING REDISEÑADO: podio + leyenda + filas con breakdown =============
   v2: cards autocontenidas (sin pseudo-elementos que se salen), layout flex
   para que con 2 usuarios queden bien centrados, sin base-podium visual rota. */
.rk-podium{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:12px;margin-bottom:22px}
.rk-podium-n3{justify-content:space-between;align-items:flex-end}
.rk-podium-card{flex:1 1 0;min-width:0;max-width:280px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:18px 14px 16px;background:var(--surface);border:1px solid var(--line);border-radius:16px;position:relative;transition:transform .25s}
.rk-podium-n3 .rk-podium-1{transform:translateY(-12px);min-width:200px;max-width:260px;padding:22px 14px 20px;background:linear-gradient(180deg,color-mix(in srgb,#ffd700 14%,var(--surface)) 0%,var(--surface) 65%);border-color:color-mix(in srgb,#ffd700 45%,var(--line));box-shadow:0 18px 38px -18px color-mix(in srgb,#ffd700 35%,transparent)}
.rk-podium-n3 .rk-podium-2{transform:translateY(-4px);background:linear-gradient(180deg,color-mix(in srgb,#c0c0c0 10%,var(--surface)) 0%,var(--surface) 65%);border-color:color-mix(in srgb,#c0c0c0 32%,var(--line))}
.rk-podium-n3 .rk-podium-3{background:linear-gradient(180deg,color-mix(in srgb,#cd7f32 10%,var(--surface)) 0%,var(--surface) 65%);border-color:color-mix(in srgb,#cd7f32 32%,var(--line))}
.rk-podium-n2 .rk-podium-1{background:linear-gradient(180deg,color-mix(in srgb,#ffd700 14%,var(--surface)) 0%,var(--surface) 65%);border-color:color-mix(in srgb,#ffd700 45%,var(--line));box-shadow:0 18px 38px -18px color-mix(in srgb,#ffd700 35%,transparent)}
.rk-podium-n2 .rk-podium-2{background:linear-gradient(180deg,color-mix(in srgb,#c0c0c0 10%,var(--surface)) 0%,var(--surface) 65%);border-color:color-mix(in srgb,#c0c0c0 32%,var(--line))}
.rk-podium-card.me{outline:2px solid var(--acc);outline-offset:-2px}
.rk-podium-medal{font-size:30px;line-height:1;filter:drop-shadow(0 4px 10px rgba(0,0,0,.4));margin-bottom:2px}
.rk-podium-av{display:flex;align-items:center;justify-content:center;border-radius:50%;padding:3px;background:var(--surface-2);flex:none}
.rk-podium-1 .rk-podium-av{box-shadow:0 0 0 3px #ffd700, 0 10px 26px color-mix(in srgb,#ffd700 38%,transparent)}
.rk-podium-2 .rk-podium-av{box-shadow:0 0 0 3px #c0c0c0, 0 8px 20px color-mix(in srgb,#c0c0c0 28%,transparent)}
.rk-podium-3 .rk-podium-av{box-shadow:0 0 0 3px #cd7f32, 0 8px 20px color-mix(in srgb,#cd7f32 28%,transparent)}
.rk-podium-av .fb-avatar{width:64px!important;height:64px!important}
.rk-podium-1 .rk-podium-av .fb-avatar{width:80px!important;height:80px!important}
.rk-podium-name{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:14.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:inline-flex;align-items:center;gap:6px}
.rk-podium-1 .rk-podium-name{font-size:16px}
.rk-podium-pts{font-family:'Archivo',sans-serif;display:inline-flex;align-items:baseline;gap:5px;margin-top:2px}
.rk-podium-pts b{font-style:italic;font-weight:900;font-size:28px;color:var(--acc-text);letter-spacing:-1px;line-height:1}
.rk-podium-1 .rk-podium-pts b{font-size:34px;color:#ffd700}
.rk-podium-pts small{font-size:11px;color:var(--text-dim);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.rk-podium-rate{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);font-weight:700;letter-spacing:.3px;padding:4px 10px;background:color-mix(in srgb,var(--bg) 50%,transparent);border:1px solid var(--line);border-radius:30px;margin-top:6px}
.rk-podium-rate-empty{opacity:.55;font-style:italic}
.rk-podium-card.me .rk-podium-name{color:var(--acc-text)}
@media (max-width:600px){
  .rk-podium{gap:8px}
  .rk-podium-card{padding:14px 10px 12px;max-width:none}
  .rk-podium-n3 .rk-podium-1{transform:translateY(-6px);padding:16px 10px 14px;min-width:0}
  .rk-podium-n3 .rk-podium-2{transform:none}
  .rk-podium-av .fb-avatar{width:54px!important;height:54px!important}
  .rk-podium-1 .rk-podium-av .fb-avatar{width:62px!important;height:62px!important}
  .rk-podium-name{font-size:13px}
  .rk-podium-1 .rk-podium-name{font-size:14px}
  .rk-podium-pts b{font-size:24px}
  .rk-podium-1 .rk-podium-pts b{font-size:28px}
  .rk-podium-medal{font-size:24px}
  .rk-podium-rate{font-size:10px;padding:3px 8px}
}

/* Leyenda de puntaje compacta */
.rk-legend{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;padding:10px 14px;margin-bottom:14px;background:color-mix(in srgb,var(--surface-2) 60%,transparent);border:1px dashed var(--line);border-radius:10px;font-family:'Archivo',sans-serif;font-size:11.5px;color:var(--text-dim);font-weight:600}
.rk-leg-item{display:inline-flex;align-items:center;gap:6px}
.rk-leg-chip{display:inline-flex;align-items:center;justify-content:center;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:11px;padding:2px 8px;border-radius:6px;letter-spacing:.3px;font-style:normal}
.rk-leg-chip.pts3{background:#22c55e;color:#052e16}
.rk-leg-chip.pts1{background:#fcd34d;color:#1a1300}
.rk-leg-chip.pts0{background:rgba(255,255,255,.08);color:var(--text-dim)}

/* Lista de ranking (4to en adelante) */
.rk-list{display:flex;flex-direction:column;gap:8px}
.rk-row-2{display:grid;grid-template-columns:32px 44px minmax(0,1fr) auto auto;gap:14px;align-items:center;padding:12px 16px;background:var(--surface);border:1px solid var(--line);border-radius:13px;transition:.15s}
.rk-row-2:hover{border-color:color-mix(in srgb,var(--acc) 30%,var(--line))}
.rk-row-2.me{background:color-mix(in srgb,var(--acc) 8%,var(--surface));border-color:color-mix(in srgb,var(--acc) 45%,var(--line))}
.rk-row-2 .rk-pos{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:20px;color:var(--text-dim);letter-spacing:-.5px;text-align:center}
.rk-row-2.me .rk-pos{color:var(--acc-text)}
.rk-row-2 .rk-av{width:44px;height:44px;border-radius:50%;overflow:hidden}
.rk-row-2 .rk-av .fb-avatar{width:44px!important;height:44px!important}
.rk-info{min-width:0;display:flex;flex-direction:column;gap:4px}
.rk-row-2 .rk-name{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:15px;color:var(--text);display:flex;align-items:center;gap:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rk-you-tag{display:inline-block;font-family:'Archivo',sans-serif;font-style:normal;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;background:var(--acc);color:var(--on-acc);padding:2px 7px;border-radius:30px}
.rk-progress{height:5px;background:color-mix(in srgb,var(--line) 50%,transparent);border-radius:30px;overflow:hidden}
.rk-progress-bar{height:100%;background:linear-gradient(90deg,var(--acc-2),var(--acc));border-radius:30px;transition:width .35s}
.rk-progress-label{font-family:'Archivo',sans-serif;font-size:10.5px;color:var(--text-dim);font-weight:600;letter-spacing:.2px}
.rk-bd{display:flex;gap:5px;flex:none}
.rk-bd-chip{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:3px 7px;border-radius:7px;font-family:'Archivo',sans-serif;font-weight:900;font-size:12px;font-style:italic;letter-spacing:-.2px;cursor:help}
.rk-bd-chip.pts3{background:#22c55e;color:#052e16}
.rk-bd-chip.pts1{background:#fcd34d;color:#1a1300}
.rk-bd-chip.pts0{background:rgba(255,255,255,.08);color:var(--text-dim)}
.rk-pts-big{font-family:'Archivo',sans-serif;display:flex;flex-direction:column;align-items:flex-end;line-height:1;flex:none;min-width:54px}
.rk-pts-big b{font-style:italic;font-weight:900;font-size:24px;color:var(--text);letter-spacing:-.8px}
.rk-row-2.me .rk-pts-big b{color:var(--acc-text)}
.rk-pts-big small{font-size:10px;color:var(--text-dim);font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-top:2px}

@media (max-width:600px){
  .rk-podium{grid-template-columns:1fr 1.15fr 1fr;gap:8px;padding:14px 10px 8px}
  .rk-podium-av .fb-avatar{width:52px!important;height:52px!important}
  .rk-podium-name{font-size:12.5px}
  .rk-podium-pts b{font-size:22px}
  .rk-row-2{grid-template-columns:24px 36px minmax(0,1fr) auto;gap:9px;padding:10px 12px}
  .rk-row-2 .rk-av .fb-avatar{width:36px!important;height:36px!important}
  .rk-row-2 .rk-name{font-size:13.5px}
  .rk-bd{display:none}
  .rk-pts-big b{font-size:20px}
  .rk-legend{gap:8px;font-size:10.5px;padding:8px 10px}
}
.rk-av{font-size:24px;text-align:center;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;overflow:hidden;background:var(--surface-2)}
.rk-av .fb-avatar{width:100%!important;height:100%!important}
.rk-name{font-style:italic;font-weight:800;font-size:16px}
.rk-done,.rk-pts{font-family:'Archivo',sans-serif;font-weight:700;text-align:right}
.rk-pts{color:var(--acc-text);font-size:18px}

/* Toast */
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:30px;background:var(--bg-2);border:1px solid var(--line);color:var(--text);padding:12px 22px;border-radius:30px;font-family:'Archivo',sans-serif;font-size:13px;font-weight:700;box-shadow:0 10px 40px rgba(0,0,0,.3);z-index:200;animation:toastIn .25s ease-out}
.toast.ok{border-color:color-mix(in srgb,var(--acc) 50%,transparent);color:var(--acc-text)}
.toast.warn{border-color:color-mix(in srgb,var(--acc-3) 50%,transparent);color:var(--acc-3)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}

/* Banner modo local */
.local-banner{background:color-mix(in srgb,var(--acc-3) 12%,transparent);border:1px solid color-mix(in srgb,var(--acc-3) 30%,transparent);color:var(--acc-3);font-size:13px;font-weight:600;padding:12px 16px;border-radius:12px;margin:0 0 18px;text-align:center}
.pi-help{color:var(--text-dim);font-size:13px;margin-bottom:8px;line-height:1.5}
.pi-feedback{margin-top:10px;font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;min-height:16px}

/* ===== Welcome card del prode (auth no logueado) ===== */
.pi-welcome{text-align:center;padding:32px 28px 28px;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 6%,var(--surface)) 0%,var(--surface) 60%);border:1.5px solid color-mix(in srgb,var(--acc) 22%,var(--line));border-radius:22px;box-shadow:0 18px 60px rgba(0,0,0,.25),inset 0 1px 0 color-mix(in srgb,var(--text) 6%,transparent);position:relative;overflow:hidden}
.pi-welcome::before{
  /* Halo decorativo arriba que tiñe ligero con el acento del tema */
  content:"";position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:380px;height:200px;border-radius:50%;
  background:radial-gradient(closest-side,color-mix(in srgb,var(--acc) 35%,transparent),transparent 70%);
  pointer-events:none;
}
.pi-welcome-head{position:relative;z-index:1;margin-bottom:22px}
.pi-welcome-logo{display:flex;justify-content:center;margin-bottom:14px}
.pi-welcome-logo img{height:64px;width:auto;filter:drop-shadow(0 6px 18px color-mix(in srgb,var(--acc) 45%,transparent))}
.pi-welcome-title{font-style:italic;font-weight:900;font-size:28px;line-height:1.05;letter-spacing:-.8px;color:var(--text);margin:0 0 8px}
.pi-welcome-sub{font-size:15px;color:var(--text-dim);line-height:1.45;margin:0;max-width:380px;margin-left:auto;margin-right:auto;font-weight:500}

/* ===== Privacidad ===== */
.auth-privacy{margin-top:22px;padding:18px 20px;background:color-mix(in srgb,var(--acc) 7%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 28%,var(--line));border-radius:14px;text-align:left}
.auth-privacy h5{font-style:italic;font-weight:900;font-size:15px;letter-spacing:-.2px;margin:0 0 12px;color:var(--acc-text);display:flex;align-items:center;gap:9px}
.auth-privacy h5 .ap-lock{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;background:color-mix(in srgb,var(--acc) 22%,transparent);border-radius:50%;flex:none}
.auth-privacy h5 .ap-lock svg{width:13px;height:13px;color:var(--acc-text)}
.auth-privacy ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}
.auth-privacy li{font-size:13.5px;color:var(--text);line-height:1.4;font-weight:500;display:flex;align-items:flex-start;gap:10px}
.auth-privacy li .ap-check{flex:none;width:18px;height:18px;color:var(--acc-text);margin-top:2px}
.auth-privacy li span{flex:1}

/* Auth: divider + toggle entre Google y Email */
.auth-divider{display:flex;align-items:center;gap:10px;margin:18px 0 14px;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:1.5px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--line)}
.auth-method-toggle{width:100%;padding:11px;font-size:13px;border-radius:10px}

/* Botón gigante de Google (CTA principal) — versión premium */
.auth-google-big{position:relative;display:flex;align-items:center;justify-content:center;gap:14px;width:100%;background:#fff;color:#1a1a1a;border:1.5px solid rgba(0,0,0,.08);border-radius:14px;padding:18px 22px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:17px;letter-spacing:.3px;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;box-shadow:0 10px 32px rgba(0,0,0,.22),inset 0 -2px 0 rgba(0,0,0,.05);overflow:hidden}
.auth-google-big::after{
  /* Brillo sutil que cruza al hover */
  content:"";position:absolute;top:0;bottom:0;left:-100%;width:50%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  transform:skewX(-20deg);transition:left .55s ease;pointer-events:none;
}
.auth-google-big:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(0,0,0,.32),inset 0 -2px 0 rgba(0,0,0,.05);background:#fafafa}
.auth-google-big:hover::after{left:140%}
.auth-google-big:active{transform:translateY(0);box-shadow:0 6px 18px rgba(0,0,0,.22)}
.auth-google-icon{display:inline-flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;width:30px;height:30px;flex-shrink:0;position:relative;z-index:1}
.auth-google-label{flex:1;text-align:left;position:relative;z-index:1}
.auth-google-help{display:flex;justify-content:center;align-items:center;gap:7px;margin:14px 0 22px;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);padding:8px 16px;background:color-mix(in srgb,var(--acc) 7%,transparent);border:1px solid color-mix(in srgb,var(--acc) 18%,var(--line));border-radius:30px;width:fit-content;margin-inline:auto}
.auth-google-help::before{content:"⚡";font-size:13px;line-height:1;color:var(--acc-text)}

/* Acordeón email: link discreto que expande la sección */
.auth-email-toggle{width:100%;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:700;font-size:13.5px;padding:13px 16px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:border-color .2s,background .2s,color .2s}
.auth-email-toggle:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line));background:color-mix(in srgb,var(--acc) 6%,var(--surface-2));color:var(--acc-text)}
.auth-email-toggle svg{transition:transform .25s;color:var(--text-dim)}
.auth-email-toggle:hover svg{color:var(--acc-text)}
.auth-email-toggle.open{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 10%,transparent);color:var(--acc-text);margin-bottom:14px}
.auth-email-toggle.open svg{transform:rotate(180deg);color:var(--acc-text)}

/* Tabs (deprecadas pero mantengo estilos por si vuelven) */
.auth-tabs{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin:8px 0 14px}
.auth-tabs .auth-tab{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:13px;padding:10px 8px;border-radius:9px;cursor:pointer;letter-spacing:.3px;transition:all .2s}
.auth-tabs .auth-tab:hover{color:var(--text)}
.auth-tabs .auth-tab.active{background:var(--acc);color:var(--on-acc);box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 30%,transparent)}

/* Form unificado (apto para baja visión / no-tech) */
.auth-email-form{display:flex;flex-direction:column;gap:14px;text-align:left;animation:authSlide .25s ease-out}
@keyframes authSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.auth-email-form[hidden]{display:none}
.auth-field{display:flex;flex-direction:column;gap:7px}
.auth-label{font-family:'Archivo',sans-serif;font-weight:700;font-size:14px;color:var(--text);padding-left:2px}
.auth-email-form input{background:var(--surface-2);border:2px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-size:17px;font-weight:500;padding:15px 16px;border-radius:12px;width:100%;transition:all .2s}
.auth-email-form input:focus{outline:none;border-color:var(--acc);background:color-mix(in srgb,var(--acc) 5%,var(--surface-2));box-shadow:0 0 0 4px color-mix(in srgb,var(--acc) 18%,transparent)}
.auth-email-form input::placeholder{color:var(--text-dim);opacity:.55}
.auth-email-form .btn{width:100%;padding:16px;font-size:16px;border-radius:12px;margin-top:6px}
.auth-email-form .btn:disabled{opacity:.6;cursor:wait}
.auth-toggle-link{background:none;border:none;color:var(--acc-text);font-family:'Archivo',sans-serif;font-weight:600;font-size:12px;padding:6px 0;cursor:pointer;text-align:center;text-decoration:underline;text-underline-offset:3px}
.auth-toggle-link:hover{opacity:.8}
.auth-email-form .pi-feedback{font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;min-height:16px;text-align:center}
.auth-email-form .pi-feedback.ok{color:var(--acc-text)}
.auth-email-form .pi-feedback.err{color:var(--acc-3)}
.pi-feedback.ok{color:var(--acc-text)}
.pi-feedback.err{color:var(--acc-3)}

/* Ranking controls */
.rank-controls{margin-bottom:14px}
.rank-filter{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:8px 14px;border-radius:30px}
.rank-filter .rk-label{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.rank-filter select{background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;padding:6px 10px;border-radius:8px;cursor:pointer}

/* ===== Dropdowns nativos: respetan el modo claro/oscuro del tema =====
   color-scheme le dice al SO/browser que use sus widgets nativos en
   modo dark o light. Sin esto, en Windows los options quedan blancos
   sobre blanco. */
html[data-mode="dark"] select{color-scheme:dark}
html[data-mode="light"] select{color-scheme:light}
/* Fallback explícito para browsers que no respetan color-scheme */
select option{background:var(--bg-2);color:var(--text);font-family:'Archivo',sans-serif}
select optgroup{background:var(--bg-2);color:var(--text-dim)}

/* Grupos */
.g-intro{background:color-mix(in srgb,var(--acc) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--acc) 25%,var(--line));border-radius:14px;padding:14px 18px;margin-bottom:18px;font-size:14px;line-height:1.5;color:var(--text)}
.g-intro p{margin:0}

.g-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
.g-action{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:20px 18px 18px;transition:.2s;position:relative}
.g-action:hover{border-color:color-mix(in srgb,var(--acc) 40%,var(--line));transform:translateY(-2px)}
.g-action-icon{font-size:32px;line-height:1;margin-bottom:10px}
.g-action h5{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.3px;margin-bottom:4px}
.g-action-sub{font-size:12px;color:var(--text-dim);line-height:1.4;margin-bottom:14px;min-height:34px}
.g-action input{flex:1;min-width:0;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-size:14px;font-weight:700;padding:11px 14px;border-radius:10px}
.g-action input:focus{outline:none;border-color:var(--acc)}
.g-action-create input::placeholder{color:var(--text-dim)}
.g-action-join input{letter-spacing:3px;text-align:center}
.g-action .btn{padding:11px 16px;font-size:13px;border-radius:10px;white-space:nowrap}

.g-mine-title{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.3px;margin:8px 0 14px;display:flex;align-items:center;gap:10px}
.g-mine-count{display:inline-flex;align-items:center;justify-content:center;background:var(--acc);color:var(--on-acc);font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;padding:2px 9px;border-radius:30px;min-width:26px}

.groups-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;align-items:start}
.g-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:.2s}
.g-card:hover{border-color:color-mix(in srgb,var(--acc) 35%,var(--line))}
/* Cuando un grupo esta abierto: ocupa TODO el ancho de la grilla y aplica
   layout 2 col interior para que el panel se vea apaisado y protagonico. */
.g-card:has(.g-panel:not([hidden])){grid-column:1 / -1;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 6%,var(--surface)) 0,var(--surface) 220px);border-color:color-mix(in srgb,var(--acc) 35%,var(--line));box-shadow:0 8px 26px rgba(0,0,0,.25);padding:20px 22px}
.g-card:has(.g-panel:not([hidden])) .g-card-head .g-name{font-size:22px}
.g-card:has(.g-panel:not([hidden])) .g-actions-row{margin-top:4px}
.g-card:has(.g-panel:not([hidden])) .g-panel{margin-top:18px;padding-top:18px}
.g-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.g-name{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.3px;flex:1;line-height:1.1}
.g-mem{font-family:'Archivo',sans-serif;font-weight:700;color:var(--text-dim);font-size:12px;flex:none;background:var(--surface-2);padding:4px 9px;border-radius:30px}

.g-code-wrap{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px dashed var(--line);border-radius:10px;padding:8px 10px}
.g-code-pill{font-family:'Archivo',sans-serif;font-weight:700;color:var(--acc-text);font-size:17px;letter-spacing:3px;flex:1;text-align:center}
.g-icon-btn{background:transparent;border:1px solid var(--line);color:var(--text);width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:15px;display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.g-icon-btn:hover{border-color:var(--acc);color:var(--acc-text);transform:scale(1.05)}

.g-view-rank{justify-content:center;padding:10px;font-size:13px;border-radius:10px}

/* Mobile */
@media(max-width:560px){
  .prode-rules{flex-direction:column;align-items:stretch}
  .prule{justify-content:center}
  .pi-row{flex-direction:column;align-items:stretch}
  .pi-row .btn{width:100%}
  /* Mobile: mantener layout horizontal país | score | país (no stack vertical).
     Países más compactos a cada lado del input para que se entienda mejor. */
  .pm-row{grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
  .pm-team{gap:5px;font-size:12px;font-weight:600;min-width:0}
  .pm-team.pm-home{justify-content:flex-end;text-align:right}
  .pm-team.pm-away{justify-content:flex-start;text-align:left}
  .pm-team .pm-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11.5px;line-height:1.15}
  .pm-team .fb-flag,.pm-team img.fb-flag{flex:none}
  .pm-scores{justify-content:center;gap:5px}
  .pm-scores .pm-input{width:32px;height:32px;font-size:15px}
  .pm-scores .pm-dash{font-size:14px;opacity:.6}
  .pm-status-row{flex-direction:column;gap:6px}
  .pstat{min-width:0;flex:1;padding:12px 10px}
  .rk-head,.rk-row{grid-template-columns:30px 40px 1fr 80px 56px;gap:10px;padding:10px 12px;font-size:13px}
  .rk-head{font-size:9.5px;letter-spacing:.3px}
  .rk-av{font-size:20px}.rk-name{font-size:14px}.rk-pts{font-size:15px}
  .g-actions{grid-template-columns:1fr}
  .groups-list{grid-template-columns:1fr}
  .g-action .pi-row{flex-direction:column}
  .g-action .pi-row .btn{width:100%}
}

/* ============================================================
   fbConfirm — modal de confirmación in-app (reemplaza alert/confirm).
   ============================================================ */
.fb-modal-lay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .18s}
.fb-modal-lay.open{opacity:1}
.fb-modal{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;max-width:440px;width:100%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.45);transform:translateY(8px);transition:transform .22s cubic-bezier(.2,.8,.3,1)}
.fb-modal-lay.open .fb-modal{transform:translateY(0)}
.fb-modal-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.fb-modal-ico{width:42px;height:42px;border-radius:50%;background:color-mix(in srgb,var(--acc) 18%,var(--surface-2));display:flex;align-items:center;justify-content:center;font-size:22px;flex:none}
.fb-modal-ico.danger{background:color-mix(in srgb,#ef4444 22%,var(--surface-2))}
.fb-modal-title{font-style:italic;font-weight:900;font-size:20px;letter-spacing:-.4px;color:var(--text);line-height:1.15}
.fb-modal-msg{color:var(--text-dim);font-size:15px;line-height:1.55;margin:0 0 22px}
.fb-modal-acts{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.fb-modal-acts .btn{padding:11px 22px;font-size:14px;border-radius:30px}
.btn-danger{background:#ef4444;color:#fff;border:none;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;cursor:pointer;transition:.15s}
.btn-danger:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 6px 18px rgba(239,68,68,.32)}
@media (max-width:520px){
  .fb-modal{padding:20px;border-radius:16px}
  .fb-modal-title{font-size:18px}
  .fb-modal-msg{font-size:14px}
  .fb-modal-acts{flex-direction:column-reverse}
  .fb-modal-acts .btn{width:100%}
}

/* ============================================================
   ESTADÍSTICAS — estadisticas.html
   Diseño tipográfico: tablas, números grandes, foco en datos
   (sin iconos coloridos, más legible).
   ============================================================ */
.stats-mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:680px;margin:0 auto 14px;padding:0 4px}
.stats-team-pick,.stats-match-pick{max-width:680px;margin:0 auto 14px;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:10px 14px;border-radius:14px}
.stats-pick-label{font-family:'Archivo',sans-serif;font-weight:700;font-size:13px;color:var(--text);white-space:nowrap}
.stats-team-pick select,.stats-match-pick select{flex:1;background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:13.5px;padding:9px 12px;border-radius:10px;cursor:pointer;min-width:0}
.stats-team-pick select:focus,.stats-match-pick select:focus{outline:none;border-color:var(--acc)}

/* Banner (torneo no empezó) */
.stats-banner{display:flex;align-items:center;gap:12px;background:color-mix(in srgb,var(--acc) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--acc) 28%,var(--line));border-radius:14px;padding:13px 18px;margin-bottom:22px;font-size:13.5px;color:var(--text);font-weight:500;line-height:1.4}
.stats-banner .sb-ico{font-size:22px;flex:none}

/* Grupo de estadísticas (Goles / Disciplina / Construcción) */
.stats-group{margin-bottom:34px}
.sg-title{display:flex;align-items:center;gap:10px;font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.6px;color:var(--text);margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid color-mix(in srgb,var(--acc) 35%,var(--line))}
.sg-title .sg-ico{font-size:24px;flex:none}
.stats-group-warn .sg-title{border-bottom-color:color-mix(in srgb,#fbbf24 40%,var(--line))}
.stats-group-acc2 .sg-title{border-bottom-color:color-mix(in srgb,var(--acc-2) 40%,var(--line))}

/* Grupo de stats — header limpio sin ícono grande */
.stats-group{margin-bottom:34px}
.stats-group .sg-title{display:block;font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.6px;color:var(--text);margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid color-mix(in srgb,var(--acc) 35%,var(--line))}

/* Grilla de tarjetas dentro del grupo */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.stat-card:hover{border-color:color-mix(in srgb,var(--acc) 40%,var(--line));box-shadow:0 10px 28px rgba(0,0,0,.22)}
.stat-card-h{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:14px 16px 10px;border-bottom:1px solid var(--line)}
.stat-card-h .sc-title{font-style:italic;font-weight:900;font-size:16px;letter-spacing:-.3px;color:var(--text);line-height:1.15;margin:0}
.stat-card-h .sc-meta{font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);white-space:nowrap}

/* Tabla — la fuente de los números más grande, padding cómodo */
.stat-table{width:100%;border-collapse:collapse;table-layout:fixed}
.stat-table thead th{font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);text-align:left;padding:8px 14px;background:color-mix(in srgb,var(--text) 3%,transparent);border-bottom:1px solid var(--line)}
.stat-table thead th.th-val{text-align:right}
.stat-table thead th:first-child{width:30px}
.stat-table thead th:last-child{width:60px}
.stat-table thead th:nth-child(3){width:30%}
.stat-table tbody td{padding:10px 14px;border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent);font-family:'Archivo',sans-serif;font-size:14px;color:var(--text);vertical-align:middle}
.stat-table tbody tr:last-child td{border-bottom:none}
.stat-table tbody tr:hover{background:color-mix(in srgb,var(--acc) 5%,transparent)}
.stat-table tbody td.sr-pos{font-family:'Archivo',sans-serif;font-weight:700;font-size:12px;color:var(--text-dim);text-align:left}
.stat-table tbody tr:first-child td.sr-pos{color:var(--acc-text)}
.stat-table tbody td.sr-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-table tbody td.sr-team{display:flex;align-items:center;gap:8px;font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;font-weight:600}
.stat-table tbody td.sr-team .sr-flag-img{width:18px;height:auto;border-radius:3px;flex:none}
.stat-table tbody td.sr-team span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-table tbody td.sr-val{font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;color:var(--text);text-align:right;font-variant-numeric:tabular-nums}
.stat-table tbody tr:first-child td.sr-val{color:var(--acc-text)}
.stat-table tbody tr.sr-empty{opacity:.4}
.stat-table tbody tr.sr-empty td.sr-val{font-style:normal;font-weight:600;font-size:16px;color:var(--text-dim)}

/* Por SELECCIÓN — hero + totales + detalle */
.team-summary{display:flex;flex-direction:column;gap:22px}
.team-hero{display:flex;align-items:center;gap:18px;padding:22px 24px;background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 14%,var(--surface)),var(--surface));border:1px solid color-mix(in srgb,var(--acc) 28%,var(--line));border-radius:18px}
.team-hero .team-flag{width:64px;height:auto;border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,.3)}
.team-hero .team-name{font-style:italic;font-weight:900;font-size:32px;letter-spacing:-.8px;color:var(--text);margin:0;line-height:1}

.team-totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.team-total{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 16px;text-align:center}
.team-total .tt-val{font-style:italic;font-weight:900;font-size:42px;letter-spacing:-1.5px;color:var(--acc-text);line-height:1;font-variant-numeric:tabular-nums;margin-bottom:6px}
.team-total .tt-label{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}

.team-group{}
.team-group .tg-title{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.4px;color:var(--text);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.team-cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.team-cat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.team-cat .tc-label{display:block;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}
.team-cat .tc-rows{display:flex;flex-direction:column;gap:4px}
.team-cat .tc-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13.5px}
.team-cat .tc-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-cat .tc-val{font-style:italic;font-weight:900;font-size:18px;color:var(--acc-text);font-variant-numeric:tabular-nums}
.team-cat .tc-empty{font-size:12.5px;color:var(--text-dim);font-style:italic}

/* Stats inline (dentro de modal de partido — calendario / grupos) */
.match-stats-inline{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:8px}
.ms-mini-head{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;padding:10px 16px;background:color-mix(in srgb,var(--acc) 6%,transparent);border-bottom:1px solid var(--line);font-weight:700;font-size:13px}
.ms-mini-head .ms-l-team{text-align:right}
.ms-mini-head .ms-a-team{text-align:left}
.ms-mini-head .ms-vs-mid-small{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;padding:0 6px}
.match-stats-toggle{margin-top:10px;background:color-mix(in srgb,var(--text) 4%,transparent);border:1px solid var(--line);border-radius:10px;padding:0}
.match-stats-toggle>summary{cursor:pointer;padding:9px 14px;font-family:'Archivo',sans-serif;font-weight:700;font-size:12.5px;color:var(--text);list-style:none;display:flex;align-items:center;gap:8px}
.match-stats-toggle>summary::before{content:"▸";display:inline-block;transition:transform .2s;color:var(--text-dim)}
.match-stats-toggle[open]>summary::before{transform:rotate(90deg)}
.match-stats-toggle>summary::-webkit-details-marker{display:none}
.match-stats-toggle .match-stats-inline{margin:0 14px 14px}

.stats-empty{padding:40px 22px;background:var(--surface);border:1.5px dashed var(--line);border-radius:14px;text-align:center;font-size:14px;color:var(--text-dim);font-style:italic}

/* Comparativa por partido (modo match) */
.match-stats{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.ms-head{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;padding:18px 22px;background:color-mix(in srgb,var(--acc) 6%,var(--surface));border-bottom:1px solid var(--line)}
.ms-team{display:flex;align-items:center;gap:10px}
.ms-l{justify-content:flex-end;text-align:right}
.ms-a{justify-content:flex-start;text-align:left}
.ms-name{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.5px;color:var(--text)}
.ms-vs{text-align:center;display:flex;flex-direction:column;gap:3px;min-width:140px}
.ms-vs-when{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}
.ms-vs-mid{font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;color:var(--acc-text)}
.ms-vs-where{font-size:11px;color:var(--text-dim);font-weight:600}
.ms-rows{padding:6px 0}
.ms-row{display:grid;grid-template-columns:42px 1fr 42px;gap:14px;align-items:center;padding:10px 22px;border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.ms-row:last-child{border-bottom:none}
.ms-l-val,.ms-a-val{font-family:'Archivo',sans-serif;font-weight:800;font-size:17px;color:var(--text)}
.ms-l-val{text-align:right}
.ms-a-val{text-align:left}
.ms-row-mid{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:140px}
.ms-row-lbl{font-family:'Archivo',sans-serif;font-size:12px;font-weight:500;letter-spacing:.1px;color:var(--text-dim);text-transform:none}
.ms-row-bar{display:flex;width:100%;max-width:240px;height:5px;border-radius:3px;background:var(--surface-2);overflow:hidden}
.ms-row-bar .msbb{display:block;height:100%;transition:width .4s cubic-bezier(.2,.8,.2,1)}
.ms-row-bar .msbb-l{background:linear-gradient(90deg,#15803d,#22c55e);border-radius:3px 0 0 3px}
.ms-row-bar .msbb-r{background:linear-gradient(90deg,#fcd34d,#eab308);border-radius:0 3px 3px 0}

/* === Vote widget "¿Quién ganará?" === */
.ms-vote{padding:16px 18px 14px;border-top:1px solid var(--line);background:color-mix(in srgb,var(--surface) 50%,var(--surface-2))}
.ms-vote-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px;flex-wrap:wrap}
.ms-vote-q{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:15px;color:var(--text);margin:0;letter-spacing:-.2px}
.ms-vote-hint{font-family:'Archivo',sans-serif;font-size:11.5px;color:var(--text-dim);font-weight:500}
.ms-vote-btns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}
.ms-vote-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--surface);border:1.5px solid var(--line);color:var(--text);padding:12px 8px;border-radius:11px;font-family:'Archivo',sans-serif;font-weight:800;font-size:14px;cursor:pointer;transition:.15s}
.ms-vote-btn:hover{border-color:color-mix(in srgb,var(--acc) 55%,var(--line));background:color-mix(in srgb,var(--acc) 8%,var(--surface));transform:translateY(-1px)}
.ms-vote-btn.voted{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 18%,var(--surface));box-shadow:0 0 0 2px color-mix(in srgb,var(--acc) 25%,transparent)}
.ms-vote-btn.dim{opacity:.5}
.ms-vote-flag{width:22px;height:15px;border-radius:2px;object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.ms-vote-code{font-weight:800;letter-spacing:.5px}
.ms-vote-x{font-family:'Archivo',sans-serif;font-weight:900;font-style:italic;font-size:18px;color:var(--text-dim)}
.ms-vote-btn.voted .ms-vote-x{color:var(--acc-text)}
.ms-vote-results-head{display:flex;justify-content:space-between;align-items:center;margin:6px 0 8px;font-family:'Archivo',sans-serif;font-size:11.5px;color:var(--text-dim);font-weight:500}
.ms-vote-results-head .vrh-total b{color:var(--text);font-weight:700}
.ms-vote-bars{display:flex;height:14px;border-radius:8px;overflow:hidden;background:var(--surface);border:1px solid var(--line)}
.ms-vote-bar{display:flex;align-items:center;justify-content:center;transition:flex-basis .35s cubic-bezier(.2,.8,.2,1);min-width:0;overflow:hidden;flex-basis:0%}
/* Colores semaforo: verde=victoria local, amarillo=empate, rojo=victoria visitante */
.ms-vote-bar-h{background:#22c55e}
.ms-vote-bar-d{background:#fcd34d}
.ms-vote-bar-a{background:#ef4444}
.ms-vote-legend{display:flex;justify-content:space-between;margin-top:8px;font-family:'Archivo',sans-serif;font-size:11.5px;color:var(--text-dim);font-weight:500}
.ms-vote-legend b{color:var(--text);font-weight:700}
.ms-vote-foot{margin-top:8px;text-align:center}
.ms-vote-disclaimer{font-family:'Archivo',sans-serif;font-size:10.5px;color:var(--text-dim);opacity:.7;font-weight:500}
@media (max-width:480px){
  .ms-vote{padding:14px 14px 12px}
  .ms-vote-q{font-size:14px}
  .ms-vote-btn{padding:10px 6px;font-size:13px}
  .ms-vote-code{font-size:12.5px}
  .ms-vote-flag{width:20px;height:14px}
  .ms-vote-bars{height:12px}
}
.ms-foot{padding:12px 22px;background:var(--surface-2);font-size:12.5px;color:var(--text-dim);text-align:center;font-style:italic;border-top:1px solid var(--line)}

@media (max-width:560px){
  .stats-mode-tabs{grid-template-columns:1fr}
  .stats-match-pick{flex-direction:column;align-items:stretch}
  .stats-pick-label{white-space:normal}
  .stats-grid{grid-template-columns:1fr}
  .sg-title{font-size:18px}
  .stat-row{grid-template-columns:22px 24px 1fr auto;padding:8px 12px;gap:8px}
  .stat-card-h{padding:12px 14px 10px}
  .sr-name strong{font-size:12.5px}
  .sr-val{font-size:16px}
  .ms-head{grid-template-columns:1fr;gap:8px;text-align:center;padding:16px}
  .ms-team{justify-content:center;text-align:center}
  .ms-row{grid-template-columns:1fr;text-align:center;gap:6px;padding:11px 16px}
  .ms-l-val,.ms-a-val{text-align:center}
}

/* ============================================================
   MODAL DE REGISTRO GLOBAL (openRegistrationModal)
   ============================================================ */
.reg-modal-lay .fb-modal{max-width:580px;padding:0;overflow:hidden;max-height:92vh;display:flex;flex-direction:column}
.reg-modal{display:flex;flex-direction:column;max-height:92vh}
.reg-modal-lay .reg-body{overflow-y:auto;max-height:calc(92vh - 200px)}
.reg-close{position:absolute;top:10px;right:14px;background:transparent;border:none;color:var(--text);font-size:26px;line-height:1;cursor:pointer;z-index:5;opacity:.7;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.reg-close:hover{opacity:1;background:rgba(255,255,255,.08)}

/* Avatar block: preview + selector */
.reg-avatar-prev{flex:0 0 auto;border:2px solid color-mix(in srgb,var(--acc) 30%,var(--line));border-radius:50%;padding:3px;background:color-mix(in srgb,var(--acc) 8%,var(--surface-2));box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 20%,transparent);position:relative}
.reg-avatar-prev .fb-avatar{width:72px!important;height:72px!important}
.reg-prev-flag{position:absolute;bottom:-2px;right:-2px;width:28px;height:28px;border-radius:50%;background:#0a1f10;border:2px solid var(--surface);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.4)}
.reg-prev-flag img{width:100%;height:100%;object-fit:cover;display:block}

/* Toast "Cuenta creada con éxito" post-signup */
.auth-success-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);background:linear-gradient(135deg,#0e3a1f,#1a5a30);border:1.5px solid color-mix(in srgb,var(--acc) 50%,#2a7a4a);color:#fff;padding:18px 28px;border-radius:16px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:17px;display:flex;align-items:center;gap:12px;box-shadow:0 18px 50px rgba(0,0,0,.55),0 0 0 4px color-mix(in srgb,var(--acc) 18%,transparent);z-index:10000;opacity:0;transition:opacity .25s,transform .25s cubic-bezier(.34,1.56,.64,1);pointer-events:none}
.auth-success-toast.open{opacity:1;transform:translate(-50%,-50%) scale(1)}
.auth-success-toast svg{color:#7ee69b;flex:0 0 auto}

/* Bandera "apoya a" al lado del nombre en navbar — con tooltip CSS instantaneo */
.pp-flag-wrap{position:relative;display:inline-flex;align-items:center;margin-left:6px;vertical-align:middle}
.pp-flag{display:inline-block;width:16px;height:11px;border-radius:2px;object-fit:cover;box-shadow:0 1px 3px rgba(0,0,0,.3);cursor:default;transition:transform .15s}
.pp-flag-wrap:hover .pp-flag{transform:scale(1.18)}
.pp-flag-wrap::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(2px);background:#0a1f12;color:#fff;border:1px solid color-mix(in srgb,var(--acc) 50%,#2a4a30);padding:5px 10px;border-radius:7px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:11.5px;white-space:nowrap;letter-spacing:.2px;box-shadow:0 6px 18px rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:200}
.pp-flag-wrap::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(2px);border:5px solid transparent;border-top-color:#0a1f12;opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:200}
.pp-flag-wrap:hover::after,.pp-flag-wrap:hover::before{opacity:1;transform:translateX(-50%) translateY(0)}
.mob-prof-name .pp-flag{width:18px;height:13px}
.reg-svg-row{display:flex;flex-wrap:wrap;gap:6px}
.reg-svg-btn{width:44px;height:44px;border:1.5px solid var(--line);background:transparent;border-radius:50%;cursor:pointer;padding:2px;transition:.15s;display:inline-flex;align-items:center;justify-content:center;overflow:hidden}
.reg-svg-btn:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line));transform:translateY(-1px)}
.reg-svg-btn.active{border-color:var(--acc);box-shadow:0 0 0 2px color-mix(in srgb,var(--acc) 28%,transparent)}
.reg-svg-btn .fb-avatar{width:100%!important;height:100%!important}
.reg-upload-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);padding:7px 12px;border-radius:8px;cursor:pointer;font-size:12.5px;font-weight:600;transition:.15s}
.reg-upload-btn:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line));background:color-mix(in srgb,var(--acc) 8%,var(--surface-2))}
.reg-head{padding:28px 28px 18px;text-align:center;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 12%,var(--surface)) 0%,var(--surface) 100%);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.reg-head::before{content:"";position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:300px;height:160px;border-radius:50%;background:radial-gradient(closest-side,color-mix(in srgb,var(--acc) 40%,transparent),transparent 70%);pointer-events:none}
.reg-logo{position:relative;z-index:1;height:54px;width:auto;display:block;margin:0 auto 12px;filter:drop-shadow(0 6px 18px color-mix(in srgb,var(--acc) 45%,transparent))}
.reg-title{position:relative;z-index:1;font-style:italic;font-weight:900;font-size:24px;line-height:1.1;letter-spacing:-.6px;color:var(--text);margin:0 0 6px}
.reg-sub{position:relative;z-index:1;font-size:14px;color:var(--text-dim);line-height:1.45;margin:0;max-width:380px;margin-inline:auto;font-weight:500}
.reg-body{padding:18px 24px 22px;display:flex;flex-direction:column;gap:10px}
.reg-privacy-warn{display:flex;align-items:flex-start;gap:9px;margin:0 24px;padding:10px 14px;border-radius:10px;background:color-mix(in srgb,#fbbf24 12%,var(--surface-2));border:1px solid color-mix(in srgb,#fbbf24 38%,var(--line));color:#fde68a;font-family:'Archivo',sans-serif;font-size:12.5px;line-height:1.4;font-weight:500}
.reg-privacy-warn svg{width:16px;height:16px;flex:none;color:#fbbf24;margin-top:1px}
@media (max-width:560px){
  .reg-privacy-warn{margin:0 16px;font-size:12px;padding:9px 12px}
}
.reg-label{display:block;font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-top:4px}
.reg-avatars{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.reg-av{width:48px;height:48px;border:1.5px solid var(--line);background:var(--surface-2);border-radius:50%;cursor:pointer;padding:0;transition:.15s;display:inline-flex;align-items:center;justify-content:center;overflow:hidden}
.reg-av:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line))}
.reg-av.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 22%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 22%,transparent)}
.reg-av .fb-avatar{width:100%!important;height:100%!important}
.reg-row{display:flex;gap:10px;align-items:stretch}
.reg-row input{flex:1;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:15px;padding:12px 14px;border-radius:10px;transition:border-color .15s,box-shadow .15s;min-width:0}
.reg-row input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 20%,transparent)}
.reg-row .btn{padding:12px 18px;font-size:14px;border-radius:10px;white-space:nowrap;flex:none}
.reg-fb{font-family:'Archivo',sans-serif;font-size:11.5px;font-weight:700;min-height:14px;letter-spacing:.3px}
.reg-fb.ok{color:var(--acc-text)}
.reg-fb.err{color:#ef4444}
@media (max-width:560px){
  .reg-modal-lay .fb-modal{max-width:100%;width:100%;max-height:100vh;height:100dvh;border-radius:0;border:0;display:flex;flex-direction:column}
  .reg-modal{max-height:100dvh}
  .reg-modal-lay .reg-body{max-height:none;flex:1;padding:14px 16px 24px}
  .reg-head{padding:20px 18px 14px}
  .reg-logo{height:44px}
  .reg-title{font-size:21px}
  .reg-sub{font-size:13px}
  .reg-row{flex-direction:column}
  .reg-row .btn{width:100%}
  .reg-av{width:42px;height:42px}
  /* Avatar block stack vertical en mobile: preview arriba, controles abajo */
  .reg-avatar-block{flex-direction:column;align-items:center;text-align:center}
  .reg-avatar-prev .fb-avatar{width:88px!important;height:88px!important}
  .reg-svg-row{justify-content:center;gap:8px}
  .reg-svg-btn{width:46px;height:46px}
  .reg-prev-flag{width:32px;height:32px}
  /* Flag picker en mobile: cards mas chiquitos */
  .myprof-flags{grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:5px;max-height:230px}
  .myprof-flag img{width:30px;height:21px}
  .myprof-flag span{font-size:9.5px}
  /* SQL migration text wrap-friendly */
  .reg-fb{word-break:break-word;line-height:1.4}
  /* Toast más chico, full width */
  .auth-success-toast{padding:14px 22px;font-size:15px;max-width:90vw;text-align:center}
  .auth-success-toast svg{width:18px;height:18px}
}
@media (max-width:380px){
  .reg-svg-btn{width:42px;height:42px}
  .myprof-flag span{font-size:9px}
}

/* Auth tabs: Iniciar sesión vs Crear cuenta (separación visual fuerte) */
.auth-mode-tabs{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin:4px 0 12px}
.auth-mode-tabs .amt{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:13px;padding:10px 8px;border-radius:9px;cursor:pointer;letter-spacing:.3px;transition:all .2s}
.auth-mode-tabs .amt:hover{color:var(--text)}
.auth-mode-tabs .amt.active{background:var(--acc);color:var(--on-acc);box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 30%,transparent)}
.auth-mode-banner{font-size:12.5px;line-height:1.4;padding:10px 12px;border-radius:10px;margin-bottom:8px;text-align:left}
.auth-mode-banner.is-signup{background:color-mix(in srgb,var(--acc) 10%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 25%,var(--line));color:var(--text)}
.auth-mode-banner.is-signin{background:color-mix(in srgb,var(--acc-2) 10%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc-2) 25%,var(--line));color:var(--text)}
.auth-mode-banner strong{font-style:italic;font-weight:900}
.auth-mode-banner span{color:var(--text-dim);font-weight:500}

/* Muro de hinchas: estado "logueado pero sin perfil" — CTA al modal global */
.tk-identity-pending{background:color-mix(in srgb,var(--acc) 10%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 30%,var(--line));justify-content:space-between;flex-wrap:wrap;gap:10px;display:flex;align-items:center;padding:12px 14px;border-radius:12px}
.tk-identity-pending .tk-id-msg{color:var(--text);font-weight:700;font-size:13.5px}
.tk-identity-pending .tk-id-btn{background:var(--acc);border:none;color:var(--on-acc);font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:13px;padding:9px 18px;border-radius:30px;cursor:pointer;transition:.15s;white-space:nowrap;box-shadow:0 4px 14px color-mix(in srgb,var(--acc) 32%,transparent)}
.tk-identity-pending .tk-id-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}

/* ============================================================
   CALENDARIO — fix mobile (Fase 4)
   En mobile la card del partido tenía 4 columnas y el chip "Grupo A"
   se cortaba o quedaba debajo. La reflexionamos a 2 filas: equipos arriba
   con tiempo, y la chip + flecha en la fila de abajo.
   ============================================================ */
@media (max-width:560px){
  .cal-match{display:grid;grid-template-columns:56px 1fr auto;gap:10px;padding:11px 12px;align-items:center}
  .cal-time{width:auto;font-size:17px;text-align:left}
  .cal-time .cm-status{font-size:8.5px}
  .cal-teams{font-size:14px;min-width:0}
  .cal-team .ct-name{font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cal-team .ct-score{font-size:16px}
  .cal-gchip{font-size:9px;padding:3px 6px}
  .cal-arrow{display:none}            /* la flecha consume espacio, sacamos */
  .day-head-big{gap:10px;padding:8px 0 10px;margin:0 0 10px}
  .day-head-num{min-width:62px;padding:6px 12px}
  .day-head-num .day-num{font-size:30px}
  .day-head-meta .day-name{font-size:17px}
  .day-head-meta .day-count{font-size:10px}
  .cal-filters{gap:5px;margin-bottom:16px}
  .cal-filters button{font-size:11px;padding:7px 12px}
}

/* ============================================================
   RESULTADOS — resultados.html
   ============================================================ */
.page-bg-results .page-decor{opacity:.4}

.results-empty{text-align:center;padding:60px 24px;background:var(--surface);border:1.5px dashed var(--line);border-radius:20px;max-width:520px;margin:0 auto}
.results-empty .re-ico{font-size:48px;margin-bottom:16px}
.results-empty .re-title{font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.5px;margin:0 0 8px;color:var(--text)}
.results-empty .re-sub{font-size:14px;color:var(--text-dim);line-height:1.5;margin:0 0 22px;max-width:380px;margin-inline:auto}
.results-empty .btn{padding:11px 22px;font-size:14px}

.results-day{margin-bottom:30px}
.results-day .rd-title{font-style:italic;font-weight:900;font-size:20px;letter-spacing:-.5px;color:var(--text);margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid color-mix(in srgb,var(--acc) 35%,var(--line))}
.rd-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}

.result-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 18px;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}
.result-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--acc) 40%,var(--line));box-shadow:0 10px 28px rgba(0,0,0,.25)}
.rc-meta{display:flex;justify-content:space-between;align-items:baseline;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}
.rc-meta .rc-stage{background:var(--surface-2);padding:3px 8px;border-radius:6px}
.rc-teams{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center}
.rc-team{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px;color:var(--text);min-width:0}
.rc-team:first-child{justify-content:flex-end;text-align:right}
.rc-team:last-child{justify-content:flex-start;text-align:left}
.rc-team .rc-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rc-team.draw{opacity:.9}
.rc-team:not(.winner):not(.draw){opacity:.65}
.rc-score{display:flex;align-items:baseline;gap:8px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:32px;letter-spacing:-1px;color:var(--text);font-variant-numeric:tabular-nums}
.rc-score .rcs-sep{font-size:22px;color:var(--text-dim)}
.rc-score .win{color:var(--acc-text)}
.rc-foot{display:flex;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px solid color-mix(in srgb,var(--line) 70%,transparent);font-size:11.5px;color:var(--text-dim)}
.rc-foot .rc-ft{font-family:'Archivo',sans-serif;font-weight:700;letter-spacing:1px;text-transform:uppercase}
@media (max-width:560px){
  .rd-list{grid-template-columns:1fr}
  .rc-score{font-size:26px}
  .rc-team{font-size:14px}
}

/* Estadios modal — partidos de knockout TBD */
.sm-match-ko{background:color-mix(in srgb,var(--acc) 7%,var(--surface));border-color:color-mix(in srgb,var(--acc) 30%,var(--line))}
.sm-mt-tbd{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);background:var(--surface-2);padding:3px 8px;border-radius:6px;border:1px dashed var(--line)}
.sm-match-ko-tag{background:var(--acc)!important;color:var(--on-acc)!important}
.sm-tbd-note{margin-top:12px;padding:10px 12px;background:var(--surface-2);border:1px dashed var(--line);border-radius:10px;font-size:12px;color:var(--text-dim);line-height:1.4;font-style:italic;text-align:center}

/* ============================================================
   STATS REDISEÑO V2 — cards con podio (Fase 7)
   Top 1 destacado con bandera grande de fondo, 2-5 en lista compacta abajo.
   ============================================================ */
.stat-card-v2{padding:0;display:flex;flex-direction:column}
.stat-card-v2 .stat-card-h{padding:13px 16px 11px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--text) 3%,transparent)}
.stat-card-v2 .sc-top{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:18px 16px;background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 14%,var(--surface)),var(--surface));border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.stat-card-v2 .sc-top::before{
  content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(closest-side,color-mix(in srgb,var(--acc) 26%,transparent),transparent 70%);
  pointer-events:none;
}
.stat-card-v2 .sc-top-flag{position:relative;z-index:1;width:64px;height:48px;flex:none;border-radius:8px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.35);background:var(--surface-2)}
.stat-card-v2 .sc-top-flag img{width:100%;height:100%;object-fit:cover;display:block}
.stat-card-v2 .sc-top-info{position:relative;z-index:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.stat-card-v2 .sc-top-pos{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--acc-text)}
.stat-card-v2 .sc-top-name{font-style:italic;font-weight:900;font-size:18px;letter-spacing:-.4px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.1}
.stat-card-v2 .sc-top-team{font-size:12px;color:var(--text-dim);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}
.stat-card-v2 .sc-top-val{position:relative;z-index:1;font-style:italic;font-weight:900;font-size:38px;letter-spacing:-1.5px;color:var(--acc-text);font-variant-numeric:tabular-nums;line-height:1;text-shadow:0 2px 12px color-mix(in srgb,var(--acc) 40%,transparent)}
.stat-card-v2 .sc-top-empty{opacity:.4;background:var(--surface)}
.stat-card-v2 .sc-top-empty::before{display:none}
.stat-card-v2 .sc-top-empty .sc-top-val{color:var(--text-dim);font-size:30px;text-shadow:none}

.stat-card-v2 .sc-rest{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.stat-card-v2 .sc-rest-row{display:grid;grid-template-columns:22px 26px 1fr auto auto;gap:10px;align-items:center;padding:9px 16px;border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent);font-size:13.5px}
.stat-card-v2 .sc-rest-row:last-child{border-bottom:none}
.stat-card-v2 .sc-rest-row:hover{background:color-mix(in srgb,var(--acc) 5%,transparent)}
.stat-card-v2 .sc-r-pos{font-family:'Archivo',sans-serif;font-weight:700;font-size:11.5px;color:var(--text-dim);text-align:center}
.stat-card-v2 .sc-r-flag{width:22px;height:auto;border-radius:3px;display:block;flex:none}
.stat-card-v2 .sc-r-flag-ph{width:22px;height:14px;display:block;background:var(--surface-2);border-radius:3px}
.stat-card-v2 .sc-r-name{font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-card-v2 .sc-r-team{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;text-align:right;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-card-v2 .sc-r-val{font-style:italic;font-weight:900;font-size:17px;color:var(--text);font-variant-numeric:tabular-nums;text-align:right;min-width:30px}
.stat-card-v2 .sc-rest-empty{opacity:.35}
.stat-card-v2 .sc-rest-empty .sc-r-val{font-style:normal;font-size:14px;color:var(--text-dim)}

@media (max-width:560px){
  .stat-card-v2 .sc-top{grid-template-columns:auto 1fr;padding:14px}
  .stat-card-v2 .sc-top-flag{width:54px;height:40px}
  .stat-card-v2 .sc-top-name{font-size:16px}
  .stat-card-v2 .sc-top-val{grid-column:1/-1;font-size:32px;margin-top:6px;text-align:center}
  .stat-card-v2 .sc-rest-row{grid-template-columns:20px 22px 1fr auto;gap:8px;padding:8px 12px;font-size:12.5px}
  .stat-card-v2 .sc-r-team{display:none}    /* en mobile sacamos el país del listado */
}

/* Banner de agradecimiento post-pago — se muestra cuando MP redirige
   de vuelta a /?donacion=ok */
.mp-thanks{margin-top:12px;padding:12px 16px;background:color-mix(in srgb,var(--acc) 14%,var(--surface));border:1px solid color-mix(in srgb,var(--acc) 35%,var(--line));border-radius:12px;font-size:13.5px;color:var(--text);line-height:1.5;text-align:center}
.mp-thanks.mp-thanks-success{background:linear-gradient(135deg,color-mix(in srgb,var(--acc) 22%,var(--surface)),color-mix(in srgb,var(--acc-2) 14%,var(--surface)));border-color:var(--acc);animation:thanksGlow 1.2s ease-out}
.mp-thanks strong{font-style:italic;font-weight:900;letter-spacing:-.3px}
@keyframes thanksGlow{
  0%{transform:scale(.95);opacity:0}
  50%{transform:scale(1.04)}
  100%{transform:scale(1);opacity:1}
}

/* ============================================================
   SELECTOR DE IDIOMA — globo + dropdown con 6 idiomas
   Reemplaza la pildora horizontal de ES/EN/PT.
   ============================================================ */
.lang-wrap{position:relative;display:inline-flex}
.lang-btn{display:inline-flex;align-items:center;gap:6px;padding:0 12px;width:auto !important;border-radius:30px !important}
.lang-btn .lang-current-label{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.8px;color:var(--text)}
.lang-pop{position:absolute;top:calc(100% + 6px);right:0;z-index:160;min-width:190px;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:0 18px 50px rgba(0,0,0,.45);display:flex;flex-direction:column;gap:1px;animation:pmPop .18s ease-out}
.lang-pop[hidden]{display:none}
.lang-item{display:flex;align-items:center;gap:10px;background:none;border:none;color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;padding:8px 10px;border-radius:9px;cursor:pointer;text-align:left;transition:.12s}
.lang-item:hover{background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--acc-text)}
.lang-item.active{background:var(--acc);color:var(--on-acc)}
.lang-item .li-code{font-family:'Archivo',sans-serif;font-weight:700;font-size:10.5px;letter-spacing:1.5px;min-width:34px}
.lang-item .li-name{flex:1;font-size:12.5px}

/* Hide el switcher viejo (legacy) si todavía aparece en algún navbar viejo */
.pill .lang{display:none !important}

@media (max-width:920px){
  .lang-btn{padding:0 10px}
  .lang-btn .lang-current-label{font-size:10px}
}

/* ============================================================
   MI PERFIL — modal de edición (nombre + bandera)
   ============================================================ */
.myprof-modal-lay .fb-modal{max-width:540px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:90vh}
.myprof-modal{display:flex;flex-direction:column;min-height:0}
.myprof-close{position:absolute;top:14px;right:14px;z-index:10;background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(8px);border:none;width:36px;height:36px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}
.myprof-close:hover{background:rgba(0,0,0,.75)}
.myprof-head{padding:24px 24px 18px;text-align:center;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 12%,var(--surface)) 0%,var(--surface) 100%);border-bottom:1px solid var(--line);position:relative;flex:none}
.myprof-avatar-preview{display:flex;justify-content:center;margin-bottom:10px}
.myprof-avatar-preview .fb-avatar{box-shadow:0 6px 22px rgba(0,0,0,.4)}
.myprof-title{font-style:italic;font-weight:900;font-size:22px;color:var(--text);margin:0 0 4px;letter-spacing:-.4px}
.myprof-email{font-family:'Archivo',sans-serif;font-size:11px;color:var(--text-dim);margin:0;letter-spacing:.5px}
.myprof-body{padding:18px 22px 22px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:18px}
.myprof-section{display:flex;flex-direction:column;gap:8px}
.myprof-label{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:15px;color:var(--text);margin:0}
.myprof-hint{font-size:11.5px;color:var(--text-dim);margin:2px 0 0;line-height:1.45}
.myprof-row{display:flex;gap:8px;align-items:stretch}
.myprof-row input{flex:1;background:var(--surface-2);border:1.5px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:600;font-size:14px;padding:10px 12px;border-radius:10px;min-width:0}
.myprof-row input:focus{outline:none;border-color:var(--acc)}
.myprof-row .btn{padding:10px 16px;font-size:13px;border-radius:10px;white-space:nowrap}
.myprof-search{width:100%;background:var(--surface-2);border:1px solid var(--line);color:var(--text);font-family:'Archivo',sans-serif;font-weight:500;font-size:13px;padding:9px 12px;border-radius:9px}
.myprof-search:focus{outline:none;border-color:var(--acc)}
.myprof-flags{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;max-height:280px;overflow-y:auto;padding:4px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px}
.myprof-flag{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--surface);border:1.5px solid var(--line);border-radius:9px;padding:8px 4px;cursor:pointer;transition:.15s}
.myprof-flag:hover{border-color:color-mix(in srgb,var(--acc) 50%,var(--line));transform:translateY(-1px)}
.myprof-flag.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 14%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--acc) 25%,transparent)}
.myprof-flag img{width:34px;height:24px;border-radius:3px;object-fit:cover;display:block;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.myprof-flag span{font-size:10.5px;font-weight:600;color:var(--text);text-align:center;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.pi-feedback.myprof-name-fb,.pi-feedback.myprof-flag-fb{font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;min-height:13px;letter-spacing:.3px}
.pi-feedback.myprof-name-fb.ok,.pi-feedback.myprof-flag-fb.ok{color:var(--acc-text)}
.pi-feedback.myprof-name-fb.err,.pi-feedback.myprof-flag-fb.err{color:#ef4444}

@media (max-width:560px){
  .myprof-head{padding:20px 18px 14px}
  .myprof-body{padding:14px 16px 18px;gap:14px}
  .myprof-flags{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));max-height:220px}
  .myprof-flag img{width:30px;height:22px}
  .myprof-flag span{font-size:10px}
}

/* ============================================================
   PÁGINA Mi Perfil (mi-perfil.html) — versión página completa
   reutilizando los estilos del modal. Layout dos columnas en
   desktop, apilado en mobile.
   ============================================================ */
.mp-page{padding:48px 20px 80px;min-height:60vh}
.mp-wrap{max-width:1080px;margin:0 auto}
.mp-back{display:inline-flex;align-items:center;gap:6px;font-family:'Archivo',sans-serif;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);text-decoration:none;margin-bottom:18px}
.mp-back:hover{color:var(--acc-text)}
.mp-back svg{width:14px;height:14px}

.mp-grid{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}
@media (max-width:880px){.mp-grid{grid-template-columns:1fr}}

/* Tarjeta avatar (col izquierda) */
.mp-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px 22px;text-align:center;position:relative;overflow:hidden}
.mp-card::before{content:'';position:absolute;inset:0 0 auto 0;height:90px;background:linear-gradient(180deg,color-mix(in srgb,var(--acc) 22%,transparent) 0%,transparent 100%);pointer-events:none}
.mp-card>*{position:relative}
.mp-av-big{display:flex;justify-content:center;margin-bottom:16px;position:relative;width:120px;margin-inline:auto}
.mp-av-big .fb-avatar{box-shadow:0 10px 30px rgba(0,0,0,.4);width:120px !important;height:120px !important}
.mp-av-big .fb-avatar img,.mp-av-big .fb-avatar svg{width:120px !important;height:120px !important}
/* cursor:help dibuja un "?" sobre la bandera mientras espera al tooltip nativo
   (delay ~1s). Cambiamos a default + tooltip instantaneo via ::after (data-tip)
   para no mostrar el "?" del cursor. */
.mp-av-flag{position:absolute;bottom:0;right:0;width:42px;height:42px;border-radius:50%;background:#0a1f10;border:3px solid var(--surface);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.5);cursor:default}
.mp-av-flag[data-tip]{overflow:visible}
.mp-av-flag[data-tip]::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(2px);background:#0a1f12;color:#fff;border:1px solid color-mix(in srgb,var(--acc) 50%,#2a4a30);padding:6px 11px;border-radius:8px;font-family:'Archivo',sans-serif;font-style:italic;font-weight:800;font-size:12px;white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:50}
.mp-av-flag[data-tip]:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.mp-av-flag img{width:100%;height:100%;object-fit:cover;display:block}
.mp-medalla{display:inline-block;margin-top:12px;padding:6px 14px;background:color-mix(in srgb,var(--acc) 18%,var(--surface-2));border:1.5px solid color-mix(in srgb,var(--acc) 40%,var(--line));border-radius:999px;font-family:'Archivo';font-weight:800;font-size:13px;color:var(--text)}
.mp-username{font-family:'Archivo';font-style:italic;font-weight:900;font-size:22px;letter-spacing:-.4px;color:var(--text);margin:0 0 4px}
.mp-email{font-family:'Archivo',sans-serif;font-size:11.5px;color:var(--text-dim);margin:0 0 18px;word-break:break-all}
.mp-stats{display:flex;justify-content:center;gap:18px;padding-top:16px;margin-top:6px;border-top:1px solid var(--line)}
.mp-stat{display:flex;flex-direction:column;align-items:center;gap:2px}
.mp-stat-n{font-family:'Archivo';font-style:italic;font-weight:900;font-size:22px;color:var(--acc-text);line-height:1}
.mp-stat-l{font-family:'Archivo',sans-serif;font-size:9.5px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.2px}

/* Secciones (col derecha) */
.mp-sections{display:flex;flex-direction:column;gap:18px}
.mp-section{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 22px}
.mp-section-head{display:flex;align-items:center;gap:10px;margin:0 0 14px}
.mp-section-head svg{width:20px;height:20px;color:var(--acc-text);flex:none}
.mp-section-head h2{font-family:'Archivo';font-style:italic;font-weight:900;font-size:18px;margin:0;color:var(--text);letter-spacing:-.3px}
.mp-section-desc{font-size:13px;color:var(--text-dim);margin:0 0 14px;line-height:1.5}
.mp-signout{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1.5px solid color-mix(in srgb,#ef4444 60%,var(--line));color:#ef4444;font-weight:800;font-size:13px;padding:10px 16px;border-radius:10px;cursor:pointer;transition:.15s}
.mp-signout:hover{background:color-mix(in srgb,#ef4444 14%,transparent);border-color:#ef4444}
.mp-signout svg{width:16px;height:16px}

.mp-loading{text-align:center;padding:80px 20px;color:var(--text-dim);font-family:'Archivo',sans-serif;font-size:13px}
.mp-not-logged{max-width:480px;margin:60px auto;text-align:center;padding:36px 24px;background:var(--surface);border:1px solid var(--line);border-radius:18px}
.mp-not-logged h2{font-family:'Archivo';font-style:italic;font-weight:900;font-size:28px;margin:0 0 10px}
.mp-not-logged p{color:var(--text-dim);font-size:14px;margin:0 0 18px}
.mp-not-logged a{display:inline-block;padding:11px 22px;background:var(--acc);color:var(--acc-text);text-decoration:none;font-weight:900;font-family:'Archivo';font-style:italic;text-transform:uppercase;border-radius:10px}

/* === Zona peligrosa: borrar cuenta === */
.mp-section-danger{border-color:color-mix(in srgb,#ef4444 40%,var(--line)) !important;background:color-mix(in srgb,#ef4444 4%,var(--surface))}
.mp-section-danger .mp-section-head svg{color:#ef4444}
.mp-delete-btn{width:100%;background:transparent;border:1.5px solid #ef4444;color:#ef4444;font-family:'Archivo';font-style:italic;font-weight:900;font-size:14px;padding:12px 18px;border-radius:11px;cursor:pointer;transition:.15s;letter-spacing:.2px}
.mp-delete-btn:hover{background:#ef4444;color:#fff;box-shadow:0 6px 16px color-mix(in srgb,#ef4444 30%,transparent)}

@media (max-width:880px){
  .mp-page{padding:24px 14px 60px}
  .mp-section{padding:18px 16px}
  .mp-card{padding:20px 16px}
  .mp-av-big{width:100px}
  .mp-av-big .fb-avatar,.mp-av-big .fb-avatar img,.mp-av-big .fb-avatar svg{width:100px !important;height:100px !important}
  .mp-av-flag{width:36px;height:36px;border-width:2.5px}
}
@media (max-width:560px){
  .mp-page{padding:18px 12px 80px}
  .mp-section{padding:16px 14px;border-radius:14px}
  .mp-section-head h2{font-size:16px}
  .mp-section-desc{font-size:12.5px;margin-bottom:10px}
  .mp-card{padding:18px 14px;border-radius:14px}
  .mp-username{font-size:22px}
  .mp-email{font-size:12.5px;word-break:break-all}
  .mp-av-big{width:96px}
  .mp-av-big .fb-avatar,.mp-av-big .fb-avatar img,.mp-av-big .fb-avatar svg{width:96px !important;height:96px !important}
  .mp-av-flag{width:32px;height:32px}
  .myprof-row{flex-direction:column;gap:8px}
  .myprof-row input,.myprof-row .btn{width:100%}
  .myprof-flags{grid-template-columns:repeat(auto-fill,minmax(86px,1fr));max-height:240px;gap:5px}
  .myprof-flag{padding:6px 3px}
  .myprof-flag img{width:28px;height:20px}
  .myprof-flag span{font-size:9.5px}
  .reg-svg-row{justify-content:center}
  .reg-svg-btn{width:42px;height:42px}
  .mp-back{font-size:13px;margin-bottom:14px}
  .mp-signout{width:100%;justify-content:center}
}

/* Tabs Bandera / Personaje + grilla de personajes */
.mp-av-tabs{display:flex;gap:6px;padding:5px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;margin-bottom:12px}
.mp-av-tab{flex:1;padding:9px 12px;background:transparent;border:none;color:var(--text-dim);font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;border-radius:8px;cursor:pointer;transition:.15s}
.mp-av-tab:hover{color:var(--text)}
.mp-av-tab.active{background:var(--acc);color:var(--on-acc);box-shadow:0 4px 12px color-mix(in srgb,var(--acc) 25%,transparent)}
.mp-persons{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:10px;padding:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;max-height:340px;overflow-y:auto}
.mp-person{position:relative;background:var(--surface);border:2px solid var(--line);border-radius:12px;padding:6px;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;aspect-ratio:1}
.mp-person:hover{border-color:color-mix(in srgb,var(--acc) 55%,var(--line));transform:translateY(-2px)}
.mp-person.active{border-color:var(--acc);background:color-mix(in srgb,var(--acc) 12%,var(--surface));box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 25%,transparent)}
.mp-person .fb-avatar{width:100% !important;height:auto !important;aspect-ratio:1}
.mp-person .fb-avatar svg,.mp-person .fb-avatar img{width:100% !important;height:100% !important;border-radius:9px}

/* Ocultar el email "@usuario" largo en el profile pill, mostrar solo @nombre. */
.profile-pill .pp-name{max-width:none}

/* Mensaje del autor (Nacho) dentro del ticket "Bancá Fulbazo" */
.tk-author{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;margin-top:14px;background:color-mix(in srgb,var(--acc) 8%,var(--surface-2));border:1px solid color-mix(in srgb,var(--acc) 25%,var(--line));border-radius:14px;text-align:left}
.tk-author-avatar{width:48px;height:48px;flex:none;border-radius:50%;overflow:hidden;background:#0a2540}
.tk-author-avatar svg{width:100%;height:100%;display:block}
.tk-author-text{margin:0;font-size:13.5px;line-height:1.5;color:var(--text);font-weight:500}
.tk-author-text b{font-style:italic;font-weight:900;color:var(--acc-text)}
@media (max-width:560px){
  .tk-author{padding:12px 14px;gap:10px}
  .tk-author-avatar{width:42px;height:42px}
  .tk-author-text{font-size:12.5px}
}

/* ============================================================
   Modal de login con email (openEmailAuthModal) — versión APAISADA.
   Layout 2 columnas: hero visual (banderas + avatares) + form.
   Sin Google: solo email/password. Apilado vertical en mobile.
   ============================================================ */
.auth-modal-lay .fb-modal{max-width:480px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:92vh}
.auth-modal{display:flex;flex-direction:column;min-height:0}
.auth-modal-close{position:absolute;top:14px;right:14px;z-index:10;background:rgba(0,0,0,.55);color:#fff;backdrop-filter:blur(8px);border:none;width:36px;height:36px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}
.auth-modal-close:hover{background:rgba(0,0,0,.78)}
.auth-modal .reg-body{overflow-y:auto;flex:1}

/* === MODAL APAISADO (auth-modal-wide) === */
.auth-modal-lay .auth-modal-wide{max-width:920px;width:100%;padding:0;overflow:hidden;display:grid;grid-template-columns:1.05fr 1fr;max-height:92vh;background:#0a1f12;border:1px solid color-mix(in srgb,#d4af37 22%,rgba(255,255,255,.08));border-radius:22px;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.6)}

/* Columna izquierda: HERO verde sólido con detalles dorados sutiles. */
.aml-hero{position:relative;padding:34px 36px;
  background:
    radial-gradient(ellipse 60% 50% at 85% 0%,rgba(212,175,55,.14),transparent 60%),
    radial-gradient(ellipse 70% 60% at 10% 100%,rgba(0,0,0,.35),transparent 70%),
    linear-gradient(160deg,#0d2a18 0%,#0a2014 45%,#06170e 100%);
  overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;color:#fff;min-height:500px}

/* Capa decorativa: trama de hexágonos sutil + halo dorado */
.aml-hero-bg{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 75% 25%,rgba(212,175,55,.10),transparent 35%),
    repeating-linear-gradient(45deg,transparent 0,transparent 24px,rgba(212,175,55,.03) 24px,rgba(212,175,55,.03) 25px);
}
.aml-hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 110%,rgba(0,0,0,.5),transparent 70%);pointer-events:none}

/* Grid de avatares — posicionados arriba a la derecha (no chocan con brand izq) */
.aml-hero-grid{position:absolute;top:34px;right:24px;width:48%;max-width:250px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;pointer-events:none;opacity:.55;z-index:1}
.aml-av{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.06);box-shadow:0 4px 14px rgba(0,0,0,.4);border:1.5px solid rgba(212,175,55,.25);animation:amlFloat 7s ease-in-out infinite;animation-delay:var(--d,0ms);overflow:hidden}
.aml-av .fb-avatar,.aml-av img,.aml-av svg{width:44px !important;height:44px !important;border-radius:50%}
@keyframes amlFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* Texto principal - va abajo, separado del brand (que ahora es absolute top-left) */
.aml-hero-text{position:relative;z-index:2;max-width:90%;margin-top:auto}
/* Brand vertical centrado (estilo fulbazo-logo.png: logo arriba, "Fulbazo" debajo)
   Sin fondo ni pildora — usa el fondo verde gradient del hero del modal.
   Posicionado ARRIBA-IZQUIERDA del hero column (separado del aml-hero-text que
   tiene el titulo/bullets abajo). */
.aml-hero-brand{position:absolute;top:24px;left:36px;display:flex;flex-direction:column;align-items:center;gap:6px;z-index:3;pointer-events:none}
.aml-hero-brand img{height:84px;width:auto;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45)) drop-shadow(0 0 12px rgba(212,175,55,.18))}
.aml-hero-brand span{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:24px;letter-spacing:-.5px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.aml-hero-title{font-family:'Archivo';font-style:italic;font-weight:900;font-size:clamp(26px,3.4vw,34px);letter-spacing:-.8px;line-height:1.05;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5);margin:0 0 12px}
.aml-hero-title b,.aml-hero-title em{font-style:italic;color:#e8c870}
.aml-hero-sub{color:rgba(255,255,255,.78);font-size:13.5px;line-height:1.5;margin:0 0 22px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.aml-hero-bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.aml-hero-bullets li{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:rgba(255,255,255,.95);line-height:1.35}
.aml-hero-bullets .aml-b-ic{flex:none;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d4af37 0%,#a8862c 100%);color:#0a1f12;border-radius:50%;box-shadow:0 2px 6px rgba(212,175,55,.35)}
.aml-hero-bullets .aml-b-ic svg{width:10px;height:10px;stroke-width:3.5}

/* Línea dorada sutil que separa hero/form */
.aml-hero::after{content:'';position:absolute;top:0;bottom:0;right:0;width:1px;background:linear-gradient(180deg,transparent 0%,rgba(212,175,55,.4) 50%,transparent 100%);z-index:5}

/* Columna derecha: FORM (email + password) */
.aml-form{background:#0d2418;padding:36px 36px 32px;overflow-y:auto;display:flex;align-items:center;color:#fff;position:relative}
.aml-form-inner{width:100%;max-width:380px;margin:0 auto}

/* Tabs con slider animado (estilo demo) */
.aml-tabs{position:relative;display:flex;background:rgba(255,255,255,.05);border:1px solid rgba(212,175,55,.18);border-radius:12px;padding:4px;margin-bottom:24px;overflow:hidden}
.aml-tabs-slider{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:linear-gradient(135deg,#d4af37 0%,#b48a2a 100%);border-radius:9px;transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 10px rgba(212,175,55,.3);z-index:1}
.aml-tabs .amt{flex:1;background:transparent;border:none;color:rgba(255,255,255,.55);font-family:'Archivo';font-weight:800;font-size:13.5px;padding:10px 14px;border-radius:8px;cursor:pointer;transition:color .2s;position:relative;z-index:2;font-style:italic}
.aml-tabs .amt:hover{color:rgba(255,255,255,.85)}
.aml-tabs .amt.active{color:#0a1f12}

.aml-h{font-family:'Archivo';font-style:italic;font-weight:900;font-size:24px;letter-spacing:-.5px;color:#fff;margin:0 0 4px;line-height:1.1}
.aml-s{font-size:13px;color:rgba(255,255,255,.62);margin:0 0 14px;line-height:1.4}

.aml-fields{display:flex;flex-direction:column;gap:10px}
.aml-fields .auth-field{display:flex;flex-direction:column;gap:4px;margin:0}
.aml-fields .auth-label{font-family:'Archivo';font-weight:800;font-size:11.5px;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.7)}
.aml-fields input{background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);color:#fff;font-family:'Archivo',sans-serif;font-weight:500;font-size:14px;padding:12px 14px;border-radius:10px;outline:none;transition:border-color .15s,background .15s,box-shadow .15s;width:100%}
/* Toggle ojo/cerrado para revelar contraseña */
.auth-pwd-wrap{position:relative;display:block;width:100%}
.auth-pwd-wrap input{padding-right:46px}
.auth-pwd-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;background:transparent;border:none;color:rgba(255,255,255,.55);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;padding:0;transition:color .15s,background .15s}
.auth-pwd-toggle::before{content:"";width:20px;height:20px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94'/><path d='M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19'/><path d='M14.12 14.12a3 3 0 1 1-4.24-4.24'/><line x1='1' y1='1' x2='23' y2='23'/></svg>");background-size:contain;background-repeat:no-repeat;opacity:.7}
.auth-pwd-toggle.shown::before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/><circle cx='12' cy='12' r='3'/></svg>")}
.auth-pwd-toggle:hover{color:#fff;background:rgba(255,255,255,.06)}
.auth-pwd-toggle:hover::before{opacity:1}
.aml-fields input:focus{border-color:rgba(212,175,55,.6);background:rgba(255,255,255,.06);box-shadow:0 0 0 3px rgba(212,175,55,.15)}
.aml-fields input::placeholder{color:rgba(255,255,255,.3)}

.aml-fields .pi-feedback{min-height:18px;font-size:12.5px;font-weight:600;margin:2px 0 0;line-height:1.4}
.aml-fields .pi-feedback.err{color:#ff9d97}
.aml-fields .pi-feedback.ok{color:#7fdf9d}

.aml-submit{margin-top:8px;width:100%;background:linear-gradient(135deg,#d4af37 0%,#b48a2a 100%);color:#0a1f12;font-family:'Archivo';font-style:italic;font-weight:900;font-size:15px;padding:13px 20px;border:none;border-radius:11px;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:.18s;box-shadow:0 6px 18px rgba(212,175,55,.3)}
.aml-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px rgba(212,175,55,.4);filter:brightness(1.05)}
.aml-submit:disabled{opacity:.6;cursor:wait;transform:none}

/* === Overlay "Creando cuenta…" — encima del modal de auth con blur + spinner === */
.auth-loading-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,31,18,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:50;opacity:0;transition:opacity .25s;border-radius:inherit}
.auth-loading-ov.open{opacity:1}
.alo-card{text-align:center;color:#fff;max-width:300px;padding:24px 20px}
.alo-title{font-family:'Archivo',sans-serif;font-style:italic;font-weight:900;font-size:18px;margin:14px 0 6px;letter-spacing:.3px;color:#fff}
.alo-sub{font-family:'Archivo',sans-serif;font-size:13px;color:rgba(255,255,255,.7);margin:0;line-height:1.45;font-weight:500}
/* Spinner — 4 puntos dorados pulsantes en círculo */
.alo-spin{position:relative;width:54px;height:54px;margin:0 auto}
.alo-spin div{position:absolute;top:50%;left:50%;width:10px;height:10px;border-radius:50%;background:#d4af37;margin:-5px 0 0 -5px;animation:aloSpin 1.2s linear infinite;box-shadow:0 0 12px rgba(212,175,55,.6)}
.alo-spin div:nth-child(1){animation-delay:0s;transform:translate(0,-22px)}
.alo-spin div:nth-child(2){animation-delay:.3s;transform:translate(22px,0)}
.alo-spin div:nth-child(3){animation-delay:.6s;transform:translate(0,22px)}
.alo-spin div:nth-child(4){animation-delay:.9s;transform:translate(-22px,0)}
@keyframes aloSpin{0%,40%{opacity:.3;transform:scale(.6) translate(var(--tx,0),var(--ty,0))}20%{opacity:1;transform:scale(1) translate(var(--tx,0),var(--ty,0))}}
/* Posición de cada punto (CSS vars para que cada uno mantenga su orbita) */
.alo-spin div:nth-child(1){--tx:0;--ty:-22px}
.alo-spin div:nth-child(2){--tx:22px;--ty:0}
.alo-spin div:nth-child(3){--tx:0;--ty:22px}
.alo-spin div:nth-child(4){--tx:-22px;--ty:0}

/* Footer trust badge */
.aml-foot-trust{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:18px;color:rgba(255,255,255,.4);font-size:11.5px;font-weight:600}
.aml-trust-ic{width:13px;height:13px;color:rgba(212,175,55,.7)}
.aml-trust-ic svg{width:13px;height:13px}

html[data-mode="light"] .aml-form{background:#0d2418;color:#fff}

/* TABLET: 1 columna pero hero mas compacto */
@media(max-width:960px){
  .auth-modal-lay .auth-modal-wide{grid-template-columns:1fr;max-height:96vh;overflow-y:auto;max-width:520px}
  .aml-hero{min-height:auto;padding:30px 28px 26px;padding-top:100px}
  .aml-hero-grid{top:18px;right:18px;width:42%;max-width:170px;gap:7px;opacity:.45}
  .aml-av{width:38px;height:38px}
  .aml-av .fb-avatar,.aml-av img,.aml-av svg{width:34px !important;height:34px !important}
  .aml-hero::after{display:none}
  .aml-hero-brand{top:18px;left:28px;gap:4px}
  .aml-hero-brand img{height:60px}
  .aml-hero-brand span{font-size:20px}
  .aml-hero-title{font-size:24px;margin-bottom:10px}
  .aml-hero-sub{font-size:13px;margin-bottom:14px}
  .aml-hero-bullets{gap:9px}
  .aml-hero-bullets li{font-size:12.5px}
  .aml-form{padding:28px 26px 26px}
  .aml-tabs{margin-bottom:18px}
  .aml-tabs .amt{font-size:13px;padding:9px 12px}
  .aml-h{font-size:22px}
  .aml-s{font-size:12.5px;margin-bottom:14px}
  .aml-fields{gap:11px}
  .aml-fields input{padding:11px 13px;font-size:14px}
  .aml-submit{padding:12px 18px;font-size:14px}
}

/* MOBILE: aun mas compacto, full viewport */
@media(max-width:560px){
  .auth-modal-lay .fb-modal-lay{padding:0}
  /* grid-template-rows:auto 1fr -> hero queda compacto (solo contenido),
     form ocupa el resto del viewport. Antes height:100dvh estiraba ambas
     celdas y aparecia un espacio vacio entre hero y form. */
  .auth-modal-lay .auth-modal-wide{max-width:100%;width:100%;height:100dvh;min-height:100vh;max-height:none;border-radius:0;border:0;grid-template-rows:auto 1fr}
  .auth-modal-close{top:10px;right:10px;width:34px;height:34px;font-size:20px}
  /* Hero sin margin-top:auto (queda compacto al top).
     padding-top:108 deja espacio para brand absolute (top:14 + img 52 +
     span 18 ≈ 86px) sin que el titulo se superponga. */
  .aml-hero{padding:108px 20px 20px;justify-content:flex-start}
  .aml-hero-text{margin-top:0}
  .aml-hero-grid{top:14px;right:14px;width:38%;gap:5px}
  .aml-av{width:32px;height:32px}
  .aml-av .fb-avatar,.aml-av img,.aml-av svg{width:28px !important;height:28px !important}
  .aml-hero-brand{top:14px;left:20px}
  .aml-hero-brand img{height:52px}
  .aml-hero-brand span{font-size:18px}
  .aml-hero-title{font-size:20px;margin-bottom:8px}
  .aml-hero-sub{font-size:12px;margin-bottom:10px}
  .aml-hero-bullets li{font-size:12px}
  .aml-form{padding:22px 18px 20px}
  .aml-h{font-size:20px}
  .aml-fields{gap:9px}
  .aml-fields input{padding:11px 12px}
  .aml-submit{padding:13px 18px;font-size:14px}
  /* Bullets ocultos en mobile chico para ganar espacio (info redundante) */
  .aml-hero-bullets{display:none}
}

/* Landscape mobile: hero a la izquierda, form a la derecha pero compacto */
@media(max-width:900px) and (orientation:landscape) and (max-height:520px){
  .auth-modal-lay .auth-modal-wide{grid-template-columns:1fr 1.2fr;max-height:100vh;height:100dvh;max-width:100%;border-radius:0}
  .aml-hero{min-height:auto;padding:62px 22px 18px;justify-content:flex-end}
  .aml-hero-grid{display:none}
  .aml-hero-brand{top:10px;left:18px}
  .aml-hero-brand img{height:42px}
  .aml-hero-brand span{font-size:16px}
  .aml-hero-title{font-size:18px;margin-bottom:6px}
  .aml-hero-sub{font-size:11.5px;margin-bottom:8px}
  .aml-hero-bullets{gap:6px}
  .aml-hero-bullets li{font-size:11px}
  .aml-form{padding:18px 22px}
  .aml-tabs{margin-bottom:12px}
  .aml-h{font-size:18px}
  .aml-s{margin-bottom:10px;font-size:12px}
  .aml-fields{gap:7px}
  .aml-fields input{padding:9px 11px;font-size:13px}
  .aml-submit{padding:10px 16px;font-size:13px}
}

/* tk-id-link ahora es un <button>, mantengo el estilo del link anterior */
button.tk-id-link{background:transparent;border:none;cursor:pointer;font-family:inherit}

/* ============================================================
   NAVBAR nuevo recto — overrides desktop
   ============================================================ */
/* Profile pill desktop: bandera + @nombre + chevron */
.profile-pill .pp-av{width:28px;height:28px}
.profile-pill .pp-name{font-size:13.5px;font-weight:800;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-pill{padding:5px 12px 5px 5px;background:color-mix(in srgb,var(--acc) 14%,var(--surface-2));border:1.5px solid color-mix(in srgb,var(--acc) 35%,var(--line))}
.profile-pill:hover{background:color-mix(in srgb,var(--acc) 22%,var(--surface-2));border-color:var(--acc)}

/* === MOBILE NAVBAR (≤920px): brand + tools visibles, links colapsan === */
@media (max-width:920px){
  .navbar{padding:0 8px 0 6px;height:64px;gap:10px}
  .nav-brand{margin-right:auto;margin-left:0;gap:10px;padding-left:2px}
  .nav-brand img{height:44px}
  .nav-brand .bn{font-size:20px}
  /* Links se colapsan, se abren con burger. Fixed para que sea independiente
     del padre (siempre arrancan desde abajo del navbar fijo de 64px). */
  .nav-links{position:fixed;top:64px;left:0;right:0;display:none;flex-direction:column;background:color-mix(in srgb,var(--bg) 96%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);box-shadow:0 12px 30px rgba(0,0,0,.45);padding:8px;z-index:99;height:auto;max-height:calc(100vh - 64px);overflow-y:auto;align-items:stretch}
  .nav-links.open{display:flex}
  .nav-link{height:auto;padding:13px 18px;border-bottom:none;border-radius:9px;font-size:15px}
  .nav-link.active{background:color-mix(in srgb,var(--acc) 14%,transparent);border-bottom:none}
  /* Submenú "Partidos" en mobile: se abre inline al tap.
     - Ocultamos la línea punteada decorativa (::after) que en PC se ve linda
       pero en mobile aparece como "..." al lado del texto y confunde al user.
     - Mostramos el chevron SVG bien grande y prolijo a la derecha. */
  .has-dd{flex-direction:column;align-items:stretch;width:100%;height:auto}
  .has-dd .nav-link{width:100%;justify-content:space-between}
  .has-dd > .nav-link::after{display:none !important}
  .has-dd > .nav-link .chev{width:18px;height:18px;flex:none;opacity:.85}
  .has-dd.open > .nav-link .chev{transform:rotate(180deg);opacity:1;color:var(--acc-text)}
  .dd-menu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:none;box-shadow:none;padding:0 0 6px 18px;border-radius:0}
  .has-dd:not(.open) .dd-menu{display:none}
  /* Tools: theme + lang + @user + burger — separados con gap mas amplio */
  .nav-tools{margin-left:0;gap:9px}
  .profile-pill{padding:5px 12px 5px 5px;gap:7px}
  .profile-pill .pp-av{width:26px;height:26px;display:flex}
  .profile-pill .pp-name{font-size:12.5px;max-width:100px}
  .profile-pill .pp-chev{width:11px;height:11px}
  .nav-burger{display:inline-flex !important;width:40px;height:40px;align-items:center;justify-content:center;background:none;border:none;color:var(--text);cursor:pointer;padding:0;border-radius:10px}
  .nav-burger:hover{background:color-mix(in srgb,var(--text) 10%,transparent)}
}
@media (max-width:560px){
  .navbar{padding:0 8px 0 6px;height:60px;gap:8px}
  .nav-brand{padding-left:2px}
  .nav-brand img{height:38px}
  .nav-brand .bn{font-size:18px}
  .nav-tools{gap:7px}
  .profile-pill .pp-name{max-width:70px;font-size:12px}
  .profile-pill{padding:4px 10px 4px 4px;gap:6px}
  .profile-pill .pp-av{width:24px;height:24px}
  #themeBtn{width:34px !important;height:34px !important}
  .lang-wrap .lang-btn{padding:0 8px;width:auto !important;height:34px}
  .lang-wrap .lang-btn .lang-current-label{font-size:10px}
}
@media (max-width:380px){
  .nav-brand .bn{display:none}
}
/* Burger oculto en desktop (lo mostramos solo en mobile arriba) */
.nav-burger{display:none}

/* === THEME PICKER mejorado === */
.theme-pop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}
.theme-pop-head h4{margin:0;flex:1}
.theme-search-toggle{background:color-mix(in srgb,var(--text) 8%,transparent);border:1px solid var(--line);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex:none;transition:.15s;color:var(--text)}
.theme-search-toggle:hover{background:color-mix(in srgb,var(--acc) 18%,transparent);border-color:var(--acc)}
.search-wrap[hidden]{display:none !important}

/* === Modal Mi Perfil — z-index sobre todo === */
.myprof-modal-lay{z-index:300 !important}

/* === Email login button (muroEmailLogin / muroLogin) tamaño === */
.tk-identity-anon{flex-direction:column;align-items:stretch;gap:10px;padding:14px}
.tk-identity-anon .tk-id-msg{text-align:center;font-size:13px}
.tk-identity-anon .tk-id-btn{padding:12px 18px;font-size:14px;font-weight:800;width:100%;height:auto;border-radius:11px;background:var(--acc);color:var(--on-acc);border:none}
.tk-identity-anon .tk-id-btn:hover{filter:brightness(1.08)}
.tk-identity-anon .tk-id-link{font-size:13px;text-align:center;color:var(--text-dim);background:none;border:1px dashed var(--line);padding:10px;border-radius:10px;cursor:pointer;font-family:inherit;font-weight:600}
.tk-identity-anon .tk-id-link:hover{border-color:var(--acc);color:var(--acc-text)}

/* === Predicción mobile: simulador visible === */
@media (max-width:760px){
  .page-compact .sim-groups{display:grid;grid-template-columns:1fr;gap:14px}
  .page-compact .sim-group{width:100%;min-width:0}
  .page-compact .sim-group-head{flex-wrap:wrap}
  .page-compact .sim-table-wrap{overflow:hidden}
  .page-compact .sim-table{font-size:11px}
  .page-compact .sim-table th,.page-compact .sim-table td{padding:4px 5px}
  .page-compact .sim-matches{display:flex;flex-direction:column;gap:6px}
  .page-compact .sim-match{flex-direction:column;gap:6px;padding:9px 10px}
  .page-compact .sm-team{font-size:12px}
  .page-compact .sm-score input{width:36px;font-size:14px}
  .page-compact .sim-rank-row{padding:8px 10px;gap:8px}
  .page-compact .srr-name{font-size:13px}
  .page-compact .sim-bracket-info{font-size:13px;padding:14px}
  .page-compact .bracket{transform-origin:left top}
  .page-compact .bracket-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:10px}
}

/* === Estadios cards: scroll natural + visibilidad asegurada ===
   Bug histórico: las cards no se ven en mobile y se veía todo verde —
   causado por (1) el page-decor fixed con mix-blend-mode:screen tintando
   todo, y (2) reveal observer que no firea bien en algunos webviews. */
@media (max-width:760px){
  .stadiums-grid{display:grid !important;grid-template-columns:1fr !important;gap:14px;padding-bottom:40px;isolation:isolate;position:relative;z-index:5}
  .stad{width:100% !important;display:flex !important;flex-direction:column !important;visibility:visible !important;opacity:1 !important;transform:none !important;background:var(--surface) !important;position:relative;z-index:3;isolation:isolate}
  .stad .info{padding:14px 14px 12px;background:var(--surface);position:relative;z-index:2}
  .stad .photo{position:relative;z-index:1}
  .stadiums-wrap{overflow:visible !important;position:relative;z-index:3}
  body{overflow-x:hidden}
  /* NUCLEAR FIX: ocultar el page-decor decorativo en estadios mobile —
     su mix-blend-mode:screen pintaba TODO verde y tapaba las cards. */
  body.page-bg-stad .page-decor{display:none !important}
}
/* Asegurar que las cards de estadios SIEMPRE estén visibles globalmente.
   Ya no usamos .reveal en el render (HTML inline), pero por las dudas
   forzamos opacidad y visibilidad full a CUALQUIER .stad. */
.stad,.stadiums-grid .stad,.stadiums-grid .stad.reveal,.stadiums-grid .stad.reveal.in{opacity:1 !important;transform:none !important;visibility:visible !important}
.stadiums-grid .stad{min-height:280px;background:var(--surface)}
.stad-addr-mini{margin-top:8px;font-size:12px;color:var(--text-dim);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.stad-more-btn{margin-top:10px;width:100%;padding:9px 12px;background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--text);border:1.5px solid color-mix(in srgb,var(--acc) 40%,var(--line));border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.stad-more-btn:hover{background:color-mix(in srgb,var(--acc) 24%,transparent);border-color:var(--acc)}

/* Squish del navbar nuevo en pantallas muy chicas */
@media (max-width:420px){
  .nav-tools{gap:3px !important}
  .nav-tools > .profile-pill .pp-name{max-width:50px}
}

/* === Body scroll desbloqueo cuando se cierra modal Mi Perfil === */
body.no-scroll{overflow:hidden}

/* === Hamburger DENTRO de la pill, no afuera; tamaño compacto === */
@media (max-width:920px){
  .nav-burger{display:inline-flex !important;flex:0 0 auto;width:34px;height:34px;align-items:center;justify-content:center;margin-left:2px;order:60}
}
@media (max-width:560px){
  .nav-burger{width:32px;height:32px}
  .nav-burger svg{width:18px;height:18px}
}

