/* ============================================================
   Millonario 360 — estilos globales
   ============================================================ */
:root,[data-theme="dark"]{
  /* --- Paleta roja (fija) --- */
  --red:#e2231a; --red-deep:#9b0f0a; --red-glow:#ff3b30;
  --green:#1db954; --amber:#f0a020;
  --font-display:'Bebas Neue',sans-serif;
  --font-mono:'Sometype Mono',monospace;
  --font-body:'Plus Jakarta Sans',sans-serif;
  --font-accent:'Barlow Condensed',sans-serif;

  /* --- Tema OSCURO --- */
  --bg:#0a0606;
  --bg-2:#140b0b;
  --bg-card:rgba(20,11,11,.75);
  --bg-nav:rgba(8,4,4,.88);
  --bg-input:rgba(10,6,6,.7);
  --bg-modal:linear-gradient(160deg,#1a0e0e,#0a0606);
  --bg-side:rgba(12,6,6,.96);
  --bg-auth:radial-gradient(ellipse at 30% 20%,rgba(155,15,10,.28),transparent 52%),radial-gradient(ellipse at 72% 80%,rgba(226,35,26,.16),transparent 52%),#0a0606;
  --bg-footer:var(--bg-footer);
  --text:#f5f0ec;
  --text-2:#e8dbd8;
  --text-muted:#a98c8c;
  --text-sub:#cbb;
  --border:rgba(226,35,26,.22);
  --border-hover:rgba(226,35,26,.55);
  --shadow:rgba(0,0,0,.55);
  --shadow-card:0 20px 60px rgba(0,0,0,.5);
  --shadow-glow:0 8px 30px rgba(226,35,26,.4);
  --overlay-hero:radial-gradient(ellipse at center,rgba(155,15,10,.32) 0%,rgba(10,6,6,.8) 60%,#0a0606 100%),linear-gradient(180deg,rgba(10,6,6,.5) 0%,transparent 35%,transparent 60%,#0a0606 100%);
  --grain:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --grain-opacity:.05;
  --stroke-hero:rgba(245,240,236,.85);
  --scrollbar:#0a0606;
  --scrollbar-thumb:#9b0f0a;
  --nav-link:#d8c8c8;
  --select-option:#1a0e0e;
  --crest-bg:linear-gradient(145deg,#1a1010,#0a0606);
  --team-tile-bg:linear-gradient(150deg,#1a1010,#0a0606);
  --cd-box-bg:rgba(10,6,6,.7);
  --qty-btn-bg:rgba(10,6,6,.7);
  --modal-overlay:rgba(4,2,2,.88);
  --theme-btn-icon:'🌙';
  --logo-src:url('/img/logo-dark.png');
  --transition-theme:.32s cubic-bezier(.4,0,.2,1);
  /* Footer & sección video — adaptables por tema */
  --ft-text:rgba(255,255,255,.85);
  --ft-dim:rgba(255,255,255,.28);
  --ft-link:rgba(255,255,255,.32);
  --ft-link-hover:#fff;
  --ft-copy:rgba(255,255,255,.18);
  --ft-author-label:rgba(255,255,255,.3);
  --ft-author:rgba(255,255,255,.65);
  --ft-icon-bg:rgba(255,255,255,.04);
  --ft-icon-border:rgba(255,255,255,.08);
  --ft-icon-color:rgba(255,255,255,.38);
  --ft-divider:rgba(255,255,255,.05);
  --vid-stat-n:rgba(255,255,255,.85);
  --vid-stat-l:rgba(255,255,255,.3);
}

[data-theme="light"]{
  /* --- Tema CLARO suave premium --- */
  --bg:#faf7f5;
  --bg-2:#f0ebe6;
  --bg-card:rgba(255,255,255,.88);
  --bg-nav:rgba(250,247,245,.94);
  --bg-input:rgba(255,255,255,.95);
  --bg-modal:linear-gradient(160deg,#fff8f5,#faf7f5);
  --bg-side:rgba(255,253,251,.98);
  --bg-auth:radial-gradient(ellipse at 30% 20%,rgba(226,35,26,.07),transparent 52%),radial-gradient(ellipse at 72% 80%,rgba(155,15,10,.05),transparent 52%),#faf7f5;
  --bg-footer:#f0ebe6;
  --text:#1c0a0a;
  --text-2:#2e1010;
  --text-muted:#7a5555;
  --text-sub:#8a6060;
  --border:rgba(226,35,26,.18);
  --border-hover:rgba(226,35,26,.5);
  --shadow:rgba(100,20,20,.1);
  --shadow-card:0 4px 24px rgba(100,20,20,.1);
  --shadow-glow:0 8px 30px rgba(226,35,26,.25);
  --overlay-hero:radial-gradient(ellipse at center,rgba(226,35,26,.12) 0%,rgba(250,247,245,.7) 55%,#faf7f5 100%),linear-gradient(180deg,rgba(250,247,245,.35) 0%,transparent 30%,transparent 65%,#faf7f5 100%);
  --grain:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --grain-opacity:.03;
  --stroke-hero:rgba(28,10,10,.7);
  --scrollbar:#f0ebe6;
  --scrollbar-thumb:#c0706060;
  --nav-link:#5a3030;
  --select-option:#fff8f5;
  --crest-bg:linear-gradient(145deg,#f8efef,#f0e5e5);
  --team-tile-bg:linear-gradient(150deg,#f5eeee,#ede0e0);
  --cd-box-bg:rgba(255,255,255,.85);
  --qty-btn-bg:rgba(255,255,255,.9);
  --modal-overlay:rgba(60,10,10,.35);
  --theme-btn-icon:'☀️';
  --logo-src:url('/img/logo-white.jpg');
  --transition-theme:.32s cubic-bezier(.4,0,.2,1);
  /* Footer & sección video — adaptables por tema */
  --ft-text:rgba(20,5,5,.85);
  --ft-dim:rgba(20,5,5,.55);
  --ft-link:rgba(20,5,5,.5);
  --ft-link-hover:rgba(20,5,5,.95);
  --ft-copy:rgba(20,5,5,.4);
  --ft-author-label:rgba(20,5,5,.5);
  --ft-author:rgba(20,5,5,.75);
  --ft-icon-bg:rgba(20,5,5,.04);
  --ft-icon-border:rgba(20,5,5,.12);
  --ft-icon-color:rgba(20,5,5,.45);
  --ft-divider:rgba(20,5,5,.07);
  --vid-stat-n:rgba(20,5,5,.85);
  --vid-stat-l:rgba(20,5,5,.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit}
::selection{background:var(--red);color:#fff}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:#0a0606}
::-webkit-scrollbar-thumb{background:var(--red-deep);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--red)}

/* grain overlay */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ══════════════════════════════════════
   NAV — logo + burger únicamente
══════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;
  transition:.4s cubic-bezier(.16,1,.3,1);
}
nav.scrolled{background:var(--bg-nav);backdrop-filter:blur(14px);border-bottom:1px solid rgba(226,35,26,.12);padding:12px 5vw}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;position:relative;z-index:215}
.brand .crest{width:42px;height:42px;border-radius:10px;background:var(--crest-bg);border:1px solid var(--border);display:grid;place-items:center;box-shadow:0 0 22px rgba(226,35,26,.28)}
.brand .crest img{width:28px;height:28px;object-fit:contain;border-radius:4px}
.brand b{font-family:var(--font-display);font-size:20px;letter-spacing:1.5px}

/* Burger — z-index 215 para que siempre sea clickeable (encima del menú también) */
.burger{
  display:flex;flex-direction:column;gap:6px;
  cursor:pointer;background:none;border:0;
  padding:8px;z-index:215;position:relative;
}
.burger span{display:block;width:28px;height:2px;background:#fff;border-radius:2px;transition:.35s cubic-bezier(.16,1,.3,1)}
[data-theme="light"] .burger span{background:#1c0a0a}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ── Clima en navbar ── */
.nav-weather{
  display:flex;align-items:center;gap:6px;
  padding:5px 13px;
  border-radius:20px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(226,35,26,.18);
  backdrop-filter:blur(10px);
  cursor:default;
  transition:background .3s,border-color .3s;
  position:relative;z-index:201;
}
.nav-weather:hover{background:rgba(226,35,26,.1);border-color:rgba(226,35,26,.38)}
.nw-icon{font-size:14px;line-height:1}
.nw-temp{
  font-family:var(--font-display);
  font-size:13px;font-weight:700;
  color:#fff;letter-spacing:.5px;
}
.nw-city{
  font-family:var(--font-mono);
  font-size:9px;letter-spacing:2px;
  color:rgba(255,255,255,.35);
  display:none;
}
nav.scrolled .nw-city{display:block}
@media(max-width:480px){.nav-weather{padding:4px 10px}.nw-city{display:none!important}}

/* ── Menú fullscreen ── */
.nav-links{
  position:fixed!important;inset:0;z-index:200;
  display:none!important;
  flex-direction:column;align-items:center;justify-content:center;gap:0;
  background:rgba(6,3,3,.72);
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  opacity:0;
  transition:opacity .35s cubic-bezier(.16,1,.3,1);
}
.nav-links.open{display:flex!important;opacity:1}

.nav-links a{
  color:rgba(245,240,236,.75);text-decoration:none;
  font-family:var(--font-display);font-size:clamp(28px,5vw,52px);
  letter-spacing:3px;text-transform:uppercase;
  padding:10px 0;line-height:1;
  transition:.2s;
  transform:translateY(0);
}
.nav-links a:hover{color:#fff;letter-spacing:5px}
.nav-cta{
  margin-top:18px;
  background:var(--red)!important;color:#fff!important;
  padding:14px 40px!important;border-radius:10px;
  font-size:clamp(16px,2.5vw,22px)!important;
  letter-spacing:2px!important;
}
.nav-cta:hover{box-shadow:0 12px 40px rgba(226,35,26,.5);letter-spacing:3px!important}

/* Divider decorativo */
.nav-links::before{
  content:"";display:block;
  width:40px;height:2px;background:var(--red);
  margin-bottom:28px;border-radius:2px;
}

/* Botón tema + cerrar — fila inferior del panel */
.nav-panel-footer{
  position:absolute;bottom:40px;
  display:flex;align-items:center;gap:20px;
}
.theme-toggle{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:#fff;border-radius:10px;padding:10px 16px;cursor:pointer;
  font-size:18px;transition:.2s;
}
.theme-toggle:hover{background:rgba(226,35,26,.2);border-color:rgba(226,35,26,.5)}
.nav-close{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:#fff;border-radius:10px;padding:10px 18px;cursor:pointer;
  font-size:18px;line-height:1;transition:.2s;
}
.nav-close:hover{background:rgba(226,35,26,.2);border-color:rgba(226,35,26,.5)}

/* ══════════════════════════════════════════════════
   NAV MENU — Glass Premium v3
══════════════════════════════════════════════════ */
#navMenu{
  position:fixed;inset:0;z-index:210;
  display:flex;
  clip-path:polygon(0 0,100% 0,100% 0,0 0);
  visibility:hidden;
  pointer-events:none;
  transition:clip-path .85s cubic-bezier(.16,1,.3,1),visibility 0s .85s;
}
#navMenu.is-open{
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  visibility:visible;
  pointer-events:auto;
  transition:clip-path .85s cubic-bezier(.16,1,.3,1),visibility 0s 0s;
}

/* Grain de película */
#navMenu::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:99;
  opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Grid split ── */
.nm-inner{
  display:grid;
  grid-template-columns:58fr 42fr;
  width:100%;height:100%;
  position:relative;z-index:1;
}

/* ═══════════════════════════
   PANEL IZQUIERDO
═══════════════════════════ */
.nm-left{
  display:flex;flex-direction:column;
  /* pt ≥ 72px para quedar por debajo de la barra de nav fija (~64px) */
  padding:clamp(72px,10vh,96px) clamp(32px,5.5vw,80px) clamp(22px,3vh,36px);
  background:rgba(5,1,1,.96);
  backdrop-filter:blur(48px) saturate(160%);
  border-right:1px solid rgba(226,35,26,.1);
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}

/* ── Topbar ── */
.nm-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:clamp(20px,3vh,34px);
  border-bottom:1px solid rgba(255,255,255,.045);
  margin-bottom:clamp(20px,3.5vh,38px);
  flex-shrink:0;
}
.nm-brand-mark{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
}
.nm-brand-mark img{
  width:28px;height:28px;object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(226,35,26,.5));
}
.nm-brand-mark span{
  font-family:var(--font-display);
  font-size:14px;letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,.35);
}
.nm-actions{display:flex;align-items:center;gap:8px}

/* botones de acción (tema / login / cerrar) */
.nm-action-btn{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
  color:rgba(255,255,255,.65);
  border-radius:10px;padding:8px 13px;
  cursor:pointer;font-size:13px;line-height:1;
  transition:background .22s,border-color .22s,color .22s;
  white-space:nowrap;
}
.nm-action-btn svg{flex-shrink:0;opacity:.7;transition:opacity .2s}
.nm-action-btn:hover{
  background:rgba(226,35,26,.14);
  border-color:rgba(226,35,26,.35);
  color:#fff;
}
.nm-action-btn:hover svg{opacity:1}
.nm-theme-label{
  font-family:var(--font-mono);
  font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
}
.nm-pwa-btn{padding:8px 10px}
.nm-login-btn{
  font-family:var(--font-display);
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  background:rgba(226,35,26,.12);
  border:1px solid rgba(226,35,26,.28);
  color:rgba(255,255,255,.7);
  border-radius:10px;padding:8px 16px;
  text-decoration:none;display:inline-flex;align-items:center;
  transition:background .22s,border-color .22s,color .22s;
  white-space:nowrap;
}
.nm-login-btn:hover{
  background:rgba(226,35,26,.24);
  border-color:rgba(226,35,26,.55);
  color:#fff;
}
.nm-close-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;
  background:rgba(226,35,26,.12);
  border:1.5px solid rgba(226,35,26,.35);
  color:rgba(255,255,255,.85);
  border-radius:12px;cursor:pointer;
  transition:background .22s,color .22s,border-color .22s,transform .18s;
  flex-shrink:0;
}
.nm-close-btn:hover{
  background:rgba(226,35,26,.28);
  border-color:rgba(226,35,26,.65);
  color:#fff;
  transform:rotate(90deg);
}

/* ── Bloque acciones (tema · instalar · ingresar) ── */
.nm-user-row{
  display:flex;align-items:center;gap:8px;
  padding:clamp(14px,2.5vh,22px) 0 0;
  margin-top:auto;
  flex-wrap:wrap;
}
.nm-user-btn{
  display:inline-flex;align-items:center;gap:8px;
  flex:1;min-width:0;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);
  border-radius:12px;padding:11px 14px;
  cursor:pointer;font-size:13px;line-height:1;
  text-decoration:none;
  font-family:var(--font-body);
  transition:background .22s,border-color .22s,color .22s;
  white-space:nowrap;
  justify-content:center;
}
.nm-user-btn svg{flex-shrink:0;opacity:.8}
.nm-user-btn:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.2);
  color:#fff;
}
.nm-user-btn--accent{
  background:rgba(226,35,26,.14);
  border-color:rgba(226,35,26,.35);
  color:rgba(255,255,255,.85);
  font-weight:600;
}
.nm-user-btn--accent:hover{
  background:rgba(226,35,26,.26);
  border-color:rgba(226,35,26,.6);
  color:#fff;
}
[data-theme="light"] .nm-user-btn{
  background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.1);color:rgba(20,8,8,.7);
}
[data-theme="light"] .nm-user-btn:hover{background:rgba(0,0,0,.09);color:#1c0a0a}
[data-theme="light"] .nm-user-btn--accent{
  background:rgba(226,35,26,.08);border-color:rgba(226,35,26,.25);color:rgba(180,20,10,.9);
}

/* ── Nav items ── */
.nm-nav{display:flex;flex-direction:column;flex:1;gap:0}

.nm-item{
  display:grid;
  grid-template-columns:38px 1fr 28px;
  align-items:center;gap:18px;
  text-decoration:none;
  padding:clamp(11px,1.6vh,18px) 12px;
  border-radius:14px;
  position:relative;
  transition:background .3s;
  margin:0 -12px;
}
.nm-item:hover{background:rgba(226,35,26,.06)}

/* borde izquierdo rojo animado */
.nm-item::before{
  content:'';
  position:absolute;left:0;top:50%;
  width:2px;height:0;
  background:linear-gradient(to bottom,transparent,var(--red),transparent);
  border-radius:2px;
  transform:translateY(-50%);
  transition:height .4s cubic-bezier(.16,1,.3,1);
}
.nm-item:hover::before{height:70%}

/* Separador entre items */
.nm-item + .nm-item{
  border-top:1px solid rgba(255,255,255,.038);
}

/* ── Icon box ── */
.nm-icon{
  width:38px;height:38px;
  display:grid;place-items:center;
  border-radius:11px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  color:rgba(226,35,26,.45);
  transition:background .3s,border-color .3s,color .3s,
             box-shadow .3s;
  flex-shrink:0;
}
.nm-item:hover .nm-icon{
  background:rgba(226,35,26,.12);
  border-color:rgba(226,35,26,.3);
  color:#e2231a;
  box-shadow:0 0 18px rgba(226,35,26,.2);
}

/* ── Cuerpo: num + label + desc ── */
.nm-body{display:flex;flex-direction:column;gap:1px;overflow:hidden}

.nm-num{
  font-family:var(--font-mono);
  font-size:9px;letter-spacing:2px;
  color:rgba(226,35,26,.32);
  line-height:1;
  transition:color .3s;
}
.nm-item:hover .nm-num{color:rgba(226,35,26,.65)}

/* Clip reveal */
.nm-label-wrap{overflow:hidden;display:flex;align-items:center;gap:8px}
.nm-label{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(28px,3.8vw,58px);
  letter-spacing:1px;text-transform:uppercase;
  color:rgba(245,240,236,.82);
  line-height:1;
  transform:translateY(110%);
  transition:transform .65s cubic-bezier(.16,1,.3,1),color .3s;
  white-space:nowrap;
}
.nm-item:hover .nm-label{color:#fff}

.nm-desc{
  font-family:var(--font-mono);
  font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.18);
  line-height:1;margin-top:2px;
  opacity:0;transform:translateY(6px);
  transition:opacity .45s .55s,transform .45s .55s;
}
#navMenu.is-open .nm-desc{opacity:1;transform:translateY(0)}

/* ── Flecha derecha ── */
.nm-arrow{
  color:rgba(255,255,255,.12);
  opacity:0;transform:translateX(-6px);
  transition:opacity .3s,transform .3s,color .3s;
  flex-shrink:0;
}
.nm-item:hover .nm-arrow{opacity:1;transform:translateX(0);color:var(--red)}

/* ── Reveal escalonado (5 ítems) ── */
#navMenu.is-open .nm-item:nth-child(1) .nm-label{transform:translateY(0);transition-delay:.14s}
#navMenu.is-open .nm-item:nth-child(2) .nm-label{transform:translateY(0);transition-delay:.22s}
#navMenu.is-open .nm-item:nth-child(3) .nm-label{transform:translateY(0);transition-delay:.30s}
#navMenu.is-open .nm-item:nth-child(4) .nm-label{transform:translateY(0);transition-delay:.38s}
#navMenu.is-open .nm-item:nth-child(5) .nm-label{transform:translateY(0);transition-delay:.46s}

/* ── Live badge ── */
.nm-live-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:7px;letter-spacing:2px;
  padding:3px 8px;border-radius:99px;
  background:rgba(226,35,26,.15);
  color:#e2231a;
  border:1px solid rgba(226,35,26,.3);
  animation:livePulse 2s ease-in-out infinite;
  flex-shrink:0;
}
.nm-live-badge::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:#e2231a;
  animation:livePulse 1.5s ease-in-out infinite;
}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ── Footer ── */
.nm-footer{
  margin-top:auto;
  padding-top:clamp(14px,2.5vh,26px);
  border-top:1px solid rgba(255,255,255,.045);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.nm-tagline{
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.1);
}
.nm-footer-year{
  font-family:var(--font-display);font-size:22px;
  color:rgba(226,35,26,.12);letter-spacing:2px;
}

/* ═══════════════════════════
   PANEL DERECHO — decorativo
═══════════════════════════ */
.nm-right{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(3,0,0,.98);
  position:relative;overflow:hidden;
}

/* Glow radial rojo de fondo */
.nm-right::after{
  content:'';position:absolute;
  width:80%;aspect-ratio:1;
  background:radial-gradient(circle,rgba(226,35,26,.10) 0%,transparent 65%);
  border-radius:50%;pointer-events:none;
}

/* Texto RP de fondo */
.nm-right-bg{
  position:absolute;
  font-family:var(--font-display);
  font-size:clamp(200px,28vw,380px);
  color:rgba(226,35,26,.035);
  line-height:1;letter-spacing:-6px;
  user-select:none;pointer-events:none;
  bottom:-10%;right:-8%;
}

.nm-visual{
  display:flex;flex-direction:column;align-items:center;
  gap:20px;position:relative;z-index:1;padding:40px;
}

.nm-visual-img{
  width:clamp(90px,13vw,170px);height:auto;
  filter:drop-shadow(0 0 48px rgba(226,35,26,.5));
  opacity:0;transform:translateY(20px) scale(.92);
  transition:opacity .7s cubic-bezier(.16,1,.3,1) .28s,
             transform .7s cubic-bezier(.16,1,.3,1) .28s;
}
#navMenu.is-open .nm-visual-img{opacity:1;transform:translateY(0) scale(1)}

/* Divider */
.nm-visual-div{
  width:1px;height:32px;
  background:linear-gradient(to bottom,transparent,rgba(226,35,26,.3),transparent);
  opacity:0;transition:opacity .5s .5s;
}
#navMenu.is-open .nm-visual-div{opacity:1}

/* Título */
.nm-visual-title{
  font-family:var(--font-display);
  font-size:clamp(11px,1.2vw,16px);
  letter-spacing:6px;text-transform:uppercase;
  text-align:center;line-height:1.4;
  color:rgba(255,255,255,.07);
  user-select:none;margin:0;
}

/* Stats en glass pills */
.nm-stats-row{
  display:flex;gap:10px;margin-top:4px;
}
.nm-stat-pill{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:10px 16px;border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  opacity:0;transform:translateY(14px);
  transition:opacity .5s cubic-bezier(.16,1,.3,1),
             transform .5s cubic-bezier(.16,1,.3,1);
}
.nm-stat-pill:nth-child(1){transition-delay:.42s}
.nm-stat-pill:nth-child(2){transition-delay:.50s}
.nm-stat-pill:nth-child(3){transition-delay:.58s}
#navMenu.is-open .nm-stat-pill{opacity:1;transform:translateY(0)}
.nm-stat-pill b{
  font-family:var(--font-display);
  font-size:clamp(22px,3vw,38px);
  color:var(--red);line-height:1;
}
.nm-stat-pill small{
  font-family:var(--font-mono);
  font-size:7.5px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.28);
  white-space:nowrap;
}

/* Quick links glass */
.nm-quick-links{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;
  margin-top:8px;
  opacity:0;transition:opacity .5s .65s;
}
#navMenu.is-open .nm-quick-links{opacity:1}
.nm-quick-link{
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:1.5px;
  padding:6px 11px;border-radius:8px;text-decoration:none;
  background:rgba(255,255,255,.04);color:rgba(255,255,255,.38);
  border:1px solid rgba(255,255,255,.07);
  transition:background .2s,color .2s,border-color .2s;
  display:flex;align-items:center;gap:5px;
}
.nm-quick-link:hover{
  background:rgba(226,35,26,.14);
  color:rgba(255,255,255,.8);
  border-color:rgba(226,35,26,.28);
}

/* ── Mobile ── */
@media(max-width:767px){
  .nm-inner{grid-template-columns:1fr}
  .nm-right{display:none}
  .nm-left{padding:70px 22px 22px;border-right:none}
  .nm-label{font-size:clamp(30px,9.5vw,48px)}
  .nm-brand-mark span{display:none}
  .nm-theme-label{display:none}
}

/* ── Landscape móvil ── */
@media(max-height:580px){
  .nm-label{font-size:clamp(24px,5vh,36px)}
  .nm-item{padding:7px 12px}
  .nm-icon{width:30px;height:30px;border-radius:8px}
  .nm-topbar{padding-bottom:12px;margin-bottom:14px}
}

.nav-overlay{display:none}
.pwa-install-btn{display:none}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:grid;place-items:center;overflow:hidden;text-align:center}
.video-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.video-bg iframe{position:absolute;top:50%;left:50%;width:177.78vh;height:100vh;min-width:100vw;min-height:56.25vw;transform:translate(-50%,-50%);pointer-events:none}
.video-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.video-overlay{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at center,transparent 0%,rgba(10,6,6,.78) 60%,var(--ink) 100%),linear-gradient(180deg,rgba(10,6,6,.55) 0%,transparent 35%,transparent 60%,var(--ink) 100%)}
.video-overlay::before{content:"";position:absolute;inset:0;opacity:.16;background:repeating-linear-gradient(115deg,transparent 0 60px,var(--red-deep) 60px 64px);mix-blend-mode:screen}
#canvas3d{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-content{position:relative;z-index:3;padding:0 5vw}
.hero-crest{width:120px;height:120px;margin:0 auto 28px;border-radius:24px;background:linear-gradient(160deg,#1f1212,#0a0606);border:1px solid var(--border);display:grid;place-items:center;box-shadow:0 0 60px rgba(226,35,26,.4),inset 0 0 30px rgba(0,0,0,.6);animation:float 5s ease-in-out infinite}
.hero-crest svg{width:70px;height:70px}
.hero-crest img{width:72px;height:72px;object-fit:contain;border-radius:12px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero h1{font-family:var(--font-display);font-size:clamp(64px,15vw,200px);line-height:.82;letter-spacing:2px;text-shadow:0 0 60px rgba(226,35,26,.5);margin-bottom:10px}
.hero h1 .stroke{-webkit-text-stroke:2px rgba(245,240,236,.85);color:transparent}
.hero .tag{font-family:var(--font-mono);font-size:clamp(12px,2vw,16px);letter-spacing:6px;text-transform:uppercase;color:var(--text-muted)}
.hero .tag b{color:var(--red-glow)}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;font-family:var(--font-mono);font-size:11px;letter-spacing:3px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:8px;animation:bob 2s ease-in-out infinite;text-decoration:none}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
.scroll-hint .arrow{width:18px;height:18px;border-right:2px solid var(--red);border-bottom:2px solid var(--red);transform:rotate(45deg)}
.reveal-up{opacity:0;transform:translateY(40px);animation:revealUp .9s cubic-bezier(.16,1,.3,1) forwards}
@keyframes revealUp{to{opacity:1;transform:translateY(0)}}
.d1{animation-delay:.1s}.d2{animation-delay:.3s}.d3{animation-delay:.5s}.d4{animation-delay:.7s}

/* ---------- SECCIONES ---------- */
section{position:relative;padding:110px 5vw;max-width:1400px;margin:0 auto}
.eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--red-glow);text-align:center;margin-bottom:10px}
.sec-title{font-family:var(--font-display);font-size:clamp(40px,7vw,86px);text-align:center;letter-spacing:1px;line-height:.95;margin-bottom:8px}
.sec-sub{text-align:center;color:var(--text-muted);margin-bottom:14px;font-size:15px}
.sec-rule{width:80px;height:3px;background:var(--red);margin:0 auto 56px;border-radius:3px;box-shadow:0 0 14px var(--red)}
.fade{opacity:0;transform:translateY(34px);transition:.8s cubic-bezier(.16,1,.3,1)}
.fade.in{opacity:1;transform:none}

/* ---------- PRÓXIMO PARTIDO ---------- */
.match-card{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:54px 30px;text-align:center;position:relative;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.match-card::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(226,35,26,.12),transparent 60%);animation:spin 18s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.comp-badge{position:relative;display:inline-flex;gap:8px;align-items:center;background:rgba(226,35,26,.12);border:1px solid var(--red);color:var(--red-glow);padding:6px 16px;border-radius:999px;font-family:var(--font-mono);font-size:12px;letter-spacing:1px;margin-bottom:24px}
.vs-row{position:relative;display:flex;align-items:center;justify-content:center;gap:30px;margin:30px 0}
.team-box{display:flex;flex-direction:column;align-items:center;gap:12px}
.team-tile{width:120px;height:120px;border-radius:18px;display:grid;place-items:center;background:var(--team-tile-bg);border:1px solid var(--border);font-family:var(--font-display);font-size:42px;color:#fff;box-shadow:0 0 30px rgba(226,35,26,.2);transition:.4s}
.team-box:hover .team-tile{transform:translateY(-8px) rotateX(8deg);box-shadow:0 0 50px rgba(226,35,26,.5)}
.team-box span{font-weight:700;font-size:15px}
.vs{font-family:var(--font-display);font-size:50px;color:var(--red);text-shadow:0 0 24px var(--red)}
.countdown{position:relative;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin:34px 0 24px}
.cd-box{background:var(--bg-input);border:1px solid var(--border);border-radius:14px;padding:16px 22px;min-width:84px}
.cd-box b{display:block;font-family:var(--font-display);font-size:44px;color:var(--red-glow);line-height:1}
.cd-box small{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;color:var(--text-muted)}
.match-meta{position:relative;display:flex;justify-content:center;gap:26px;flex-wrap:wrap;color:var(--text-sub);font-size:14px;font-family:var(--font-mono)}
.match-meta i{color:var(--red);font-style:normal;margin-right:6px}

/* ---------- RESULTADOS ---------- */
/* ── Próximos Partidos — Carousel ──────────────────────────── */
.proximo-carousel{max-width:560px;margin:0 auto}
.proximo-stage{position:relative}

/* Apilamiento: position:absolute para inactivos, relative para el activo */
.proximo-track{position:relative}
.proximo-slide{
  position:absolute;top:0;left:0;right:0;
  opacity:0;
  pointer-events:none;
  transform:scale(.97) translateX(20px);
  transition:opacity .48s cubic-bezier(.16,1,.3,1),
             transform .48s cubic-bezier(.16,1,.3,1);
  border-top-width:4px;
  border-top-style:solid;
  border-top-color:transparent;
  z-index:0;
}
.proximo-slide.active{
  position:relative;
  opacity:1;
  pointer-events:auto;
  transform:scale(1) translateX(0);
  z-index:1;
}
.proximo-slide.comp-liga   {border-top-color:var(--comp-liga)}
.proximo-slide.comp-suda   {border-top-color:var(--comp-suda)}
.proximo-slide.comp-copa   {border-top-color:var(--comp-copa)}
.proximo-slide.comp-amistoso{border-top-color:var(--comp-amistoso)}
.proximo-slide.comp-reserva {border-top-color:var(--comp-reserva)}
.proximo-slide.comp-femenino{border-top-color:var(--comp-femenino)}

/* logos dentro del carousel */
.proximo-slide .team-logo-wrap{
  width:100px;height:100px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.proximo-slide .team-logo-wrap img,
.proximo-slide .team-logo-wrap .team-logo{
  width:100%;height:100%;object-fit:contain;padding:8px;
}

/* VS centrado con badge neutro */
.vs-center{display:flex;flex-direction:column;align-items:center;gap:6px}
.cond-neutral-badge{font-family:var(--font-mono);font-size:8px;letter-spacing:1.5px;color:var(--text-muted);opacity:.65}

/* LOCAL / VISIT. tags debajo del nombre del equipo */
.cond-tag{
  font-family:var(--font-mono);font-size:8px;letter-spacing:2px;
  padding:2px 8px;border-radius:20px;margin-top:2px;display:inline-block;
}
.cond-local{background:rgba(78,168,255,.12);color:rgba(78,168,255,.8);border:1px solid rgba(78,168,255,.25)}
.cond-visit{background:rgba(255,159,67,.12);color:rgba(255,159,67,.8);border:1px solid rgba(255,159,67,.25)}
.cond-neutral{background:rgba(168,176,200,.1);color:rgba(168,176,200,.65);border:1px solid rgba(168,176,200,.2)}

/* Contador X / 6 */
.slide-counter{
  font-family:var(--font-mono);font-size:9px;letter-spacing:2px;
  color:var(--text-muted);opacity:.4;margin-top:16px;text-align:center;
}

/* Flechas prev / next */
.proximo-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.65);
  font-size:22px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;
  transition:background .2s,color .2s,border-color .2s;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.proximo-arrow:hover{background:rgba(226,35,26,.18);border-color:rgba(226,35,26,.4);color:#e2231a}
.proximo-prev{left:10px}
.proximo-next{right:10px}

/* Dots */
.proximo-dots{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:22px;flex-wrap:wrap}
.proximo-dot{
  width:8px;height:8px;border-radius:50%;border:none;padding:0;cursor:pointer;
  background:rgba(255,255,255,.18);
  transition:background .3s,transform .3s,width .3s;
}
.proximo-dot.active{width:22px;border-radius:4px;transform:none}
.proximo-dot.comp-liga.active   {background:var(--comp-liga)}
.proximo-dot.comp-suda.active   {background:var(--comp-suda)}
.proximo-dot.comp-copa.active   {background:var(--comp-copa)}
.proximo-dot.comp-amistoso.active{background:var(--comp-amistoso)}
.proximo-dot.comp-reserva.active{background:var(--comp-reserva)}
.proximo-dot.comp-femenino.active{background:var(--comp-femenino)}

/* ── Próximos Partidos — grid y cards ──────────────────────── */
.proximos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}

.prox-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-top-width:3px;
  border-top-color:var(--border);
  border-radius:16px;
  padding:18px 20px 16px;
  transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .35s;
  box-shadow:0 4px 24px rgba(0,0,0,.28);
}
.prox-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,.45),0 0 0 1px rgba(226,35,26,.18)}
.prox-card.comp-liga  {border-top-color:var(--comp-liga)}
.prox-card.comp-suda  {border-top-color:var(--comp-suda)}
.prox-card.comp-copa  {border-top-color:var(--comp-copa)}
.prox-card.comp-amistoso{border-top-color:var(--comp-amistoso)}
.prox-card.comp-reserva {border-top-color:var(--comp-reserva)}
.prox-card.comp-femenino{border-top-color:var(--comp-femenino)}

/* Colores de badge por competición */
.rc-comp.comp-amistoso{color:var(--comp-amistoso);background:rgba(168,176,200,.1);border-color:rgba(168,176,200,.2)}
.rc-comp.comp-reserva {color:var(--comp-reserva); background:rgba(46,196,182,.1); border-color:rgba(46,196,182,.2)}
.rc-comp.comp-femenino{color:var(--comp-femenino);background:rgba(199,125,255,.1);border-color:rgba(199,125,255,.2)}

/* Duelo: dos escudos + VS */
.prox-duel{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;margin:14px 0 12px;
}
.prox-team{
  display:flex;flex-direction:column;align-items:center;
  gap:7px;flex:1;min-width:0;
}
.prox-crest{
  width:60px;height:60px;
  border-radius:14px;
  background:var(--team-tile-bg);
  border:1px solid var(--border);
  display:grid;place-items:center;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  flex-shrink:0;
}
.prox-crest img,.prox-crest .logo-fallback{width:44px!important;height:44px!important}
.prox-name{
  font-family:var(--font-body);font-weight:700;font-size:11px;
  text-align:center;line-height:1.25;
  color:var(--text-2);
  max-width:90px;
}
.prox-cond-badge{
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:2px;
  text-transform:uppercase;padding:2px 7px;border-radius:20px;
  background:rgba(226,35,26,.12);color:rgba(226,35,26,.75);
  border:1px solid rgba(226,35,26,.18);
}
.prox-vs-block{
  display:flex;flex-direction:column;align-items:center;
  gap:2px;flex-shrink:0;
}
.prox-vs{
  font-family:var(--font-display);font-size:28px;letter-spacing:3px;
  color:var(--border);line-height:1;
}
.prox-vs-date{
  font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
  color:var(--text-muted);
}
.prox-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.05);
  gap:8px;
}
[data-theme="light"] .prox-meta{border-top-color:rgba(0,0,0,.06)}
.prox-hora{
  font-family:var(--font-mono);font-size:10px;letter-spacing:1px;
  color:var(--text-muted);display:flex;align-items:center;gap:5px;
}
.prox-estadio{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.5px;
  color:var(--text-muted);opacity:.7;text-align:right;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px;
}
.prox-nota{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:.5px;
  color:var(--text-muted);opacity:.65;margin-top:6px;text-align:center;
  font-style:italic;
}

.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:20px}

/* ── Colores por competición ─────────────────────────────── */
:root{
  --comp-liga:#4ea8ff;
  --comp-suda:#ff9f43;
  --comp-copa:#2ecc71;
  --comp-amistoso:#a8b0c8;
  --comp-reserva:#2ec4b6;
  --comp-femenino:#c77dff;
}

/* ── Result card base ─────────────────────────────────────── */
.result-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-top-width:3px;
  border-top-color:var(--border);
  border-radius:16px;
  padding:22px 22px 20px;
  transition:transform .35s cubic-bezier(.16,1,.3,1),
             border-color .3s,box-shadow .35s;
  position:relative;overflow:visible;
  box-shadow:0 4px 24px rgba(0,0,0,.35);
}
.result-card.comp-liga     { border-top-color:var(--comp-liga); }
.result-card.comp-suda     { border-top-color:var(--comp-suda); }
.result-card.comp-copa     { border-top-color:var(--comp-copa); }
.result-card.comp-amistoso { border-top-color:var(--comp-amistoso); }
.result-card.comp-reserva  { border-top-color:var(--comp-reserva); }
.result-card.comp-femenino { border-top-color:var(--comp-femenino); }

.result-card:hover{
  transform:translateY(-8px);
  border-color:rgba(226,35,26,.5);
  box-shadow:0 24px 56px rgba(0,0,0,.5),0 0 0 1px rgba(226,35,26,.2);
}
.result-card.comp-liga:hover     { border-top-color:var(--comp-liga); }
.result-card.comp-suda:hover     { border-top-color:var(--comp-suda); }
.result-card.comp-copa:hover     { border-top-color:var(--comp-copa); }
.result-card.comp-amistoso:hover { border-top-color:var(--comp-amistoso); }
.result-card.comp-reserva:hover  { border-top-color:var(--comp-reserva); }
.result-card.comp-femenino:hover { border-top-color:var(--comp-femenino); }

/* ── match-card grande: borde superior por competencia ── */
.match-card{ border-top-width:3px; }
.match-card.comp-liga     { border-top-color:var(--comp-liga); }
.match-card.comp-suda     { border-top-color:var(--comp-suda); }
.match-card.comp-copa     { border-top-color:var(--comp-copa); }
.match-card.comp-amistoso { border-top-color:var(--comp-amistoso); }
.match-card.comp-reserva  { border-top-color:var(--comp-reserva); }
.match-card.comp-femenino { border-top-color:var(--comp-femenino); }

/* ── Próximos partidos: grid de cards pequeñas con escudos ── */
.prox-upcoming-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;
  margin-top:24px;
}
.prox-up-duel{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:14px 18px 10px;
}
.prox-up-team{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;flex:1;text-align:center;
}
.prox-up-logo{
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  background:var(--team-tile-bg);
  border-radius:12px;
  border:1px solid var(--border);
  overflow:hidden;flex-shrink:0;
  transition:.3s;
}
.prox-up-logo img,.prox-up-logo .team-logo{
  width:34px!important;height:34px!important;
  object-fit:contain;
}
.prox-up-logo .fallback-abbr{
  font-family:var(--font-display);font-size:14px;color:var(--text);
}
.prox-up-logo .crest-svg{width:34px;height:34px}
.prox-up-logo .crest-svg svg{width:100%;height:100%}
.prox-up-card:hover .prox-up-logo{
  box-shadow:0 0 12px rgba(226,35,26,.2);
  border-color:rgba(226,35,26,.25);
}
.prox-up-tname{
  font-size:10px;font-weight:700;
  color:var(--text);line-height:1.2;
  font-family:var(--font-body);max-width:90px;
}
.prox-up-vs{
  font-family:var(--font-display);font-size:22px;
  color:var(--red);flex-shrink:0;letter-spacing:2px;
}
.prox-up-foot{
  display:flex;justify-content:space-between;align-items:center;
  gap:8px;padding:8px 18px 14px;
  font-family:var(--font-mono);font-size:9px;
  color:var(--text-muted);letter-spacing:.5px;
  border-top:1px solid var(--border);
}
.prox-up-card .rc-top{ margin-bottom:0; }
.prox-up-card .rc-top>span:last-child{
  font-family:var(--font-mono);font-size:10px;
  color:var(--text-muted);letter-spacing:.5px;
}

/* ── Pompa de jabón — goleador ───────────────────────────── */
/* ══════════════════════════════════════════════════════════════
   SCORER GLASS — badge circular en borde superior de tarjeta
══════════════════════════════════════════════════════════════ */
.scorer-glass{
  position:absolute;
  top:-16px; left:50%;
  /* centrado + oculto arriba por defecto */
  transform:translateX(-50%) translateY(-5px) scale(.9);
  transform-origin:center bottom;

  display:inline-flex;
  align-items:center;
  gap:0;
  overflow:hidden;           /* CRÍTICO: impide que las imágenes desborden */
  max-height:34px;           /* altura fija del badge */
  flex-shrink:0;

  /* Liquid Glass pill */
  background:rgba(8,3,3,.78);
  backdrop-filter:blur(22px) saturate(190%) brightness(1.05);
  -webkit-backdrop-filter:blur(22px) saturate(190%) brightness(1.05);
  border:1px solid rgba(255,255,255,.13);
  border-top:1px solid rgba(255,255,255,.22);
  border-radius:34px;
  padding:3px 10px 3px 3px;
  box-shadow:0 6px 24px rgba(0,0,0,.55),0 0 0 1px rgba(226,35,26,.09),
             inset 0 1px 0 rgba(255,255,255,.07);
  white-space:nowrap;

  opacity:0;pointer-events:none;z-index:30;
  transition:opacity .26s ease, transform .32s cubic-bezier(.16,1,.3,1);
}
.result-card:hover .scorer-glass{
  opacity:1;
  transform:translateX(-50%) translateY(0) scale(1);
  pointer-events:auto;
}

/* Avatar circular — tamaño fijo reforzado */
.sg-av{
  display:block;
  width:28px!important; height:28px!important;
  min-width:28px; max-width:28px;
  min-height:28px; max-height:28px;
  border-radius:50%;
  object-fit:cover; object-position:top center;
  border:1.5px solid rgba(255,255,255,.18);
  box-shadow:-2px 0 6px rgba(0,0,0,.45);
  margin-left:-7px;
  flex-shrink:0;
  background:rgba(14,5,5,.9);
  transition:transform .2s cubic-bezier(.16,1,.3,1);
  z-index:calc(10 - var(--i,0));
  position:relative;
}
.sg-av:first-child{ margin-left:0; }
.sg-av:hover{ transform:scale(1.15) translateY(-2px); z-index:20; }

/* Círculo de iniciales — mismo tamaño fijo */
.sg-ini{
  display:flex; align-items:center; justify-content:center;
  width:28px!important; height:28px!important;
  min-width:28px; max-width:28px;
  min-height:28px; max-height:28px;
  border-radius:50%;
  background:radial-gradient(circle at 38% 32%, rgba(226,35,26,.2), rgba(10,4,4,.92));
  border:1.5px solid rgba(226,35,26,.3);
  box-shadow:-2px 0 6px rgba(0,0,0,.45);
  margin-left:-7px;
  flex-shrink:0;
  font-family:var(--font-mono);font-size:8px;font-weight:700;
  letter-spacing:.5px;color:rgba(226,35,26,.75);
  z-index:calc(10 - var(--i,0));
  position:relative;
  transition:transform .2s cubic-bezier(.16,1,.3,1);
}
.sg-ini:first-child{ margin-left:0; }
.sg-ini:hover{ transform:scale(1.15) translateY(-2px); z-index:20; }

/* Etiqueta: ⚽ + apellido */
.sg-info{
  display:flex; align-items:center; gap:4px;
  margin-left:7px; flex-shrink:0;
  overflow:hidden;
}
.sg-text{
  font-family:var(--font-mono);
  font-size:7.5px;letter-spacing:1.2px;text-transform:uppercase;
  color:rgba(255,255,255,.6); white-space:nowrap;
}
.sg-text strong{ color:rgba(255,255,255,.86); font-weight:700; }

/* Entrada escalonada por avatar */
.result-card:hover .sg-av,
.result-card:hover .sg-ini{
  animation:sgPop .3s cubic-bezier(.16,1,.3,1) both;
  animation-delay:calc(var(--i,0) * 55ms);
}
@keyframes sgPop{
  from{ opacity:0; transform:scale(.55) translateY(3px); }
  to  { opacity:1; transform:scale(1) translateY(0); }
}

/* Light theme */
[data-theme="light"] .scorer-glass{
  background:rgba(255,249,248,.88);
  border-color:rgba(0,0,0,.09); border-top-color:rgba(255,255,255,.9);
  box-shadow:0 6px 24px rgba(0,0,0,.14),0 0 0 1px rgba(226,35,26,.07),
             inset 0 1px 0 rgba(255,255,255,.85);
}
[data-theme="light"] .sg-av{ border-color:rgba(0,0,0,.1); background:#f0e4e4; }
[data-theme="light"] .sg-ini{ background:rgba(226,35,26,.07); border-color:rgba(226,35,26,.2); color:rgba(226,35,26,.65); }
[data-theme="light"] .sg-text{ color:rgba(40,15,15,.5); }
[data-theme="light"] .sg-text strong{ color:#1a0505; }

/* ── Card header ─────────────────────────────────────────── */
.rc-top{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:16px;
}
.rc-comp{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.8px;
  text-transform:uppercase;font-weight:700;
  padding:3px 8px;border-radius:20px;
  background:rgba(255,255,255,.06);
  color:var(--text-muted);
  border:1px solid rgba(255,255,255,.08);
}
.rc-comp.comp-liga{ color:var(--comp-liga);background:rgba(78,168,255,.1);border-color:rgba(78,168,255,.2); }
.rc-comp.comp-suda{ color:var(--comp-suda);background:rgba(255,159,67,.1);border-color:rgba(255,159,67,.2); }
.rc-comp.comp-copa{ color:var(--comp-copa);background:rgba(46,204,113,.1);border-color:rgba(46,204,113,.2); }
.rc-date{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.5px;
  color:var(--text-muted);opacity:.7;
}

/* ── Card body ───────────────────────────────────────────── */
.rc-body{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}
.rc-team{font-weight:800;font-size:17px;line-height:1.15}
.rc-team small{
  display:block;color:var(--text-muted);font-weight:400;font-size:13px;margin-top:4px;
  opacity:.85;
}

/* ── Score ───────────────────────────────────────────────── */
.score{
  font-family:var(--font-display);font-size:44px;line-height:1;
  display:flex;align-items:center;gap:8px;
  letter-spacing:-1px;flex-shrink:0;
}
.score.win { color:var(--green);text-shadow:0 0 20px rgba(29,185,84,.35); }
.score.loss{ color:var(--red-glow);text-shadow:0 0 20px rgba(255,59,48,.25); }
.score.draw{ color:var(--amber);text-shadow:0 0 20px rgba(240,160,32,.25); }

/* ── Result pills ────────────────────────────────────────── */
.pill{
  width:28px;height:28px;border-radius:7px;
  display:grid;place-items:center;font-size:14px;font-weight:700;
}
.pill.win { background:rgba(29,185,84,.18);color:var(--green); }
.pill.loss{ background:rgba(226,35,26,.18);color:var(--red-glow); }
.pill.draw{ background:rgba(240,160,32,.18);color:var(--amber); }

/* ── Live indicator ──────────────────────────────────────── */
.api-state{text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--text-muted);padding:28px;letter-spacing:.5px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 14px}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:var(--green);
  display:inline-block;margin-right:6px;
  animation:pulse 1.4s infinite;
  box-shadow:0 0 6px var(--green);
}
@keyframes pulse{
  0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(29,185,84,.5),0 0 6px var(--green)}
  50%{opacity:.6;box-shadow:0 0 0 8px rgba(29,185,84,0),0 0 10px var(--green)}
}

/* ---------- TICKETS ---------- */
.ticket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.ticket{background:linear-gradient(165deg,rgba(30,14,14,.8),rgba(10,6,6,.92));border:1px solid var(--border);border-radius:20px;padding:28px;position:relative;transition:.4s}
.ticket.featured{border-color:var(--red);box-shadow:0 0 40px rgba(226,35,26,.25)}
.ticket:hover{transform:translateY(-8px)}
.ticket .badge{position:absolute;top:18px;right:18px;background:var(--red);color:#fff;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:1px}
.ticket h3{font-family:var(--font-display);font-size:26px;letter-spacing:.5px;margin-bottom:4px}
.ticket .t-sub{color:var(--text-muted);font-size:13px;margin-bottom:20px;font-family:var(--font-mono)}
.ticket .t-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-sub);margin-bottom:10px}
.ticket .t-row i{color:var(--red);font-style:normal}
.t-price{font-family:var(--font-display);font-size:38px;margin:18px 0 4px}
.t-price small{font-family:var(--font-mono);font-size:14px;color:var(--text-muted)}
.avail-bar{height:7px;border-radius:6px;background:rgba(255,255,255,.08);overflow:hidden;margin:8px 0 18px}
.avail-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--red),var(--red-glow))}

/* ---------- BOTONES / FORM ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--red);color:#fff;border:0;padding:13px;border-radius:10px;font-weight:700;letter-spacing:.5px;cursor:pointer;font-family:var(--font-body);font-size:15px;transition:.3s;text-decoration:none}
.btn:hover{box-shadow:0 10px 30px rgba(226,35,26,.45);transform:translateY(-2px)}
.btn.ghost{background:transparent;border:1px solid var(--border);color:#fff}
.btn.ghost:hover{border-color:var(--red);box-shadow:none}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-family:var(--font-mono);letter-spacing:1px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:var(--font-body);font-size:15px;transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(226,35,26,.15)}
.field .err{color:var(--red-glow);font-size:12px;margin-top:5px;display:none;font-family:var(--font-mono)}
.field.invalid input,.field.invalid select{border-color:var(--red-glow)}
.field.invalid .err{display:block}

/* ---------- MODAL ---------- */
.modal-bg{position:fixed;inset:0;z-index:1000;background:var(--modal-overlay);backdrop-filter:blur(8px);display:none;place-items:center;padding:20px}
.modal-bg.open{display:grid;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg-modal);border:1px solid var(--border);border-radius:22px;width:100%;max-width:500px;padding:34px;position:relative;max-height:92vh;overflow-y:auto;animation:popUp .4s cubic-bezier(.16,1,.3,1)}
@keyframes popUp{from{transform:scale(.92) translateY(20px);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-family:var(--font-display);font-size:28px;margin-bottom:4px}
.modal .m-sub{color:var(--text-muted);font-size:13px;margin-bottom:22px;font-family:var(--font-mono)}
.close-x{position:absolute;top:18px;right:18px;background:none;border:0;color:var(--text-muted);font-size:26px;cursor:pointer;line-height:1;transition:.2s}
.close-x:hover{color:var(--red);transform:rotate(90deg)}
.qty-row{display:flex;align-items:center;gap:14px}
.qty-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--bg-input);color:#fff;font-size:20px;cursor:pointer;transition:.2s}
.qty-btn:hover{border-color:var(--red);color:var(--red-glow)}
.pax-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;padding:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:12px}
.pax-row input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--text);font-family:var(--font-body)}
.summary{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:16px;margin:18px 0;font-family:var(--font-mono);font-size:14px}
.summary .s-row{display:flex;justify-content:space-between;margin-bottom:8px;color:var(--text-sub)}
.summary .s-total{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:10px;margin-top:10px;font-size:18px;color:#fff}
.summary .s-total b{font-family:var(--font-display);color:var(--red-glow)}
.note{font-size:11px;color:var(--text-muted);text-align:center;margin-top:14px;font-family:var(--font-mono);line-height:1.6}
.success-check{width:70px;height:70px;border-radius:50%;background:rgba(29,185,84,.15);border:2px solid var(--green);display:grid;place-items:center;margin:0 auto 18px}
.success-check svg{width:34px;height:34px;stroke:var(--green)}

/* ---------- CONTACTO ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:34px;backdrop-filter:blur(14px)}
.contact-info h4{font-family:var(--font-display);font-size:24px;margin-bottom:18px}
.info-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.info-icon{width:44px;height:44px;border-radius:12px;background:rgba(226,35,26,.12);border:1px solid var(--border);display:grid;place-items:center;flex-shrink:0}
.info-icon svg{width:20px;height:20px;stroke:var(--red-glow);fill:none}
.info-item b{display:block;font-size:14px;margin-bottom:2px}
.info-item span{color:var(--text-muted);font-size:13px;font-family:var(--font-mono)}
.trend-box{margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}
.trend-box h5{font-family:var(--font-mono);font-size:12px;letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;margin-bottom:14px}
.trend-tags{display:flex;flex-wrap:wrap;gap:8px}
.trend-tag{font-size:12px;font-family:var(--font-mono);padding:6px 12px;border-radius:999px;background:rgba(226,35,26,.08);border:1px solid var(--border);color:#dcc;transition:.25s}
.trend-tag:hover{background:var(--red);color:#fff;cursor:default}
.trend-tag b{color:var(--red-glow)}

/* ---------- FOOTER ---------- */
footer{text-align:center;padding:60px 5vw 50px;border-top:1px solid var(--line);background:var(--bg-footer)}
.footer-crest{width:70px;height:70px;margin:0 auto 16px;border-radius:16px;background:var(--team-tile-bg);border:1px solid var(--border);display:grid;place-items:center}
.footer-crest svg{width:40px;height:40px}
footer .f-name{font-family:var(--font-display);font-size:30px;letter-spacing:3px;margin-bottom:6px}
footer .f-meta{color:var(--text-muted);font-size:13px;margin-bottom:18px}
footer .f-heart{color:var(--red)}
footer .f-legal{font-size:11px;color:#5a4040;margin-top:18px;font-family:var(--font-mono)}

/* ---------- TOAST ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);z-index:2000;background:var(--green);color:#031;padding:14px 26px;border-radius:12px;font-weight:700;box-shadow:0 14px 40px rgba(0,0,0,.4);transition:.5s cubic-bezier(.16,1,.3,1);max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--red-glow);color:#fff}

/* ============================================================
   AUTH (login / registro / recuperar)
   ============================================================ */
.auth-page{min-height:100vh;display:grid;place-items:center;padding:90px 20px 40px;position:relative;overflow:hidden}
.auth-bg{position:fixed;inset:0;z-index:-1;background:var(--bg-auth)}
.auth-bg::before{content:"";position:absolute;inset:0;opacity:.1;background:repeating-linear-gradient(115deg,transparent 0 70px,var(--red-deep) 70px 74px)}
.auth-card{background:linear-gradient(160deg,rgba(30,14,14,.96),rgba(8,4,4,.98));border:1px solid rgba(226,35,26,.35);border-radius:22px;padding:36px 30px;width:100%;max-width:420px;backdrop-filter:blur(24px) saturate(160%);box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 0 1px rgba(226,35,26,.1) inset;animation:popUp .45s cubic-bezier(.16,1,.3,1)}
.auth-card .a-crest{width:64px;height:64px;margin:0 auto 18px;border-radius:16px;background:linear-gradient(150deg,#1f1212,#0a0606);border:1px solid var(--border);display:grid;place-items:center;box-shadow:0 0 30px rgba(226,35,26,.3)}
.auth-card .a-crest svg{width:38px;height:38px}
.auth-card h1{font-family:var(--font-display);font-size:34px;text-align:center;letter-spacing:1px}
.auth-card .a-sub{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:28px}
.auth-foot{text-align:center;margin-top:20px;font-size:13px;color:var(--text-muted)}
.auth-foot a{color:var(--red-glow);text-decoration:none;font-weight:600}
.auth-foot a:hover{text-decoration:underline}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dash{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.side{background:#0c0707;border-right:1px solid var(--line);padding:26px 18px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.side .s-brand{display:flex;align-items:center;gap:10px;margin-bottom:34px;text-decoration:none;color:#fff}
.side .s-brand .crest{width:38px;height:38px;border-radius:9px;background:var(--crest-bg);border:1px solid var(--border);display:grid;place-items:center}
.side .s-brand .crest svg{width:22px;height:22px}
.side .s-brand b{font-family:var(--font-display);font-size:17px;letter-spacing:1px}
.side nav{position:static;flex-direction:column;padding:0;display:flex;gap:4px;align-items:stretch;background:none}
.side-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:11px;color:var(--text-sub);text-decoration:none;font-size:14px;font-weight:600;transition:.2s;cursor:pointer;border:1px solid transparent}
.side-link svg{width:19px;height:19px;stroke:currentColor;fill:none;flex-shrink:0}
.side-link:hover{background:rgba(226,35,26,.08);color:#fff}
.side-link.active{background:rgba(226,35,26,.14);border-color:var(--border);color:#fff}
.side-foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.main{padding:34px 4vw;overflow-y:auto}
.dash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;flex-wrap:wrap;gap:16px}
.dash-head h1{font-family:var(--font-display);font-size:clamp(30px,5vw,48px);letter-spacing:1px}
.dash-head .greet{color:var(--text-muted);font-size:14px;font-family:var(--font-mono)}
.avatar{width:54px;height:54px;border-radius:14px;background:linear-gradient(150deg,var(--red),var(--red-deep));display:grid;place-items:center;font-family:var(--font-display);font-size:22px;color:#fff;box-shadow:0 0 26px rgba(226,35,26,.4)}
.avatar.lg{width:96px;height:96px;font-size:40px;border-radius:22px}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:30px}
.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:24px;position:relative;overflow:hidden;transition:.3s}
.stat:hover{transform:translateY(-4px);border-color:var(--red)}
.stat .s-ico{width:42px;height:42px;border-radius:11px;background:rgba(226,35,26,.12);display:grid;place-items:center;margin-bottom:14px}
.stat .s-ico svg{width:22px;height:22px;stroke:var(--red-glow);fill:none}
.stat .s-val{font-family:var(--font-display);font-size:40px;line-height:1;color:#fff}
.stat .s-lbl{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);letter-spacing:1px;margin-top:6px;text-transform:uppercase}

.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:26px;margin-bottom:24px}
.panel h2{font-family:var(--font-display);font-size:24px;letter-spacing:.5px;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.panel h2 .badge-soft{font-family:var(--font-mono);font-size:11px;background:rgba(226,35,26,.12);border:1px solid var(--border);color:var(--red-glow);padding:3px 10px;border-radius:999px;letter-spacing:1px}

.member-card{background:linear-gradient(135deg,var(--red-deep),#3a0a07 60%,#0a0606);border:1px solid var(--border);border-radius:18px;padding:26px;position:relative;overflow:hidden}
.member-card::after{content:"";position:absolute;top:-40%;right:-10%;width:60%;height:180%;background:radial-gradient(circle,rgba(255,59,48,.25),transparent 60%)}
.member-card .mc-lvl{font-family:var(--font-mono);font-size:12px;letter-spacing:2px;color:#ffd;text-transform:uppercase}
.member-card .mc-name{font-family:var(--font-display);font-size:30px;margin:6px 0 18px;position:relative}
.member-card .mc-meta{display:flex;gap:24px;flex-wrap:wrap;position:relative}
.member-card .mc-meta div small{display:block;font-family:var(--font-mono);font-size:10px;color:#fcc;letter-spacing:1px;text-transform:uppercase}
.member-card .mc-meta div b{font-size:16px}

.tk-item{display:flex;align-items:center;gap:16px;padding:16px;border:1px solid var(--border);border-radius:14px;margin-bottom:12px;transition:.25s;flex-wrap:wrap}
.tk-item:hover{border-color:var(--red);background:rgba(226,35,26,.05)}
.tk-ico{width:46px;height:46px;border-radius:12px;background:rgba(226,35,26,.12);display:grid;place-items:center;font-size:22px;flex-shrink:0}
.tk-info{flex:1;min-width:160px}
.tk-info b{font-size:16px}
.tk-info span{display:block;color:var(--text-muted);font-size:12px;font-family:var(--font-mono);margin-top:3px}
.tk-right{text-align:right}
.tk-right .tk-code{font-family:var(--font-mono);font-size:12px;color:var(--red-glow)}
.tk-right .tk-days{font-family:var(--font-display);font-size:26px;line-height:1}
.tk-right small{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}
.estado{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-family:var(--font-mono);letter-spacing:.5px}
.estado.confirmado{background:rgba(29,185,84,.15);color:var(--green)}
.estado.pendiente{background:rgba(240,160,32,.15);color:var(--amber)}
.empty{text-align:center;padding:30px;color:var(--text-muted);font-family:var(--font-mono);font-size:14px}

.dash-section{display:none}
.dash-section.active{display:block;animation:fadeIn .4s}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .dash{grid-template-columns:1fr}
  .side{position:fixed;left:-280px;width:260px;z-index:200;transition:.35s cubic-bezier(.16,1,.3,1);box-shadow:0 0 60px rgba(0,0,0,.6)}
  .side.open{left:0}
  .dash-burger{display:flex!important}
  .main{padding:80px 6vw 40px}
}
@media(max-width:860px){
  .contact-wrap{grid-template-columns:1fr}
  section{padding:80px 6vw}
  .vs-row{gap:14px}.team-tile{width:90px;height:90px;font-size:32px}
}
/* Overlay oscuro detrás del menú móvil */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:98;backdrop-filter:blur(2px)}
.nav-overlay.open{display:block}
@media(max-width:560px){
  .row2{grid-template-columns:1fr}
  .pax-row{grid-template-columns:1fr}
  .cd-box{min-width:68px;padding:12px 14px}.cd-box b{font-size:34px}
  .auth-card{padding:30px 22px}
}
.dash-burger{display:none;position:fixed;top:18px;left:18px;z-index:210;width:46px;height:46px;border-radius:12px;background:rgba(8,4,4,.9);border:1px solid var(--border);flex-direction:column;gap:5px;align-items:center;justify-content:center;cursor:pointer}
.dash-burger span{width:22px;height:2px;background:#fff}

/* ============================================================
   PWA: badge EN VIVO + botones flotantes
   ============================================================ */
.live-badge{display:inline-flex;align-items:center;gap:8px;background:#c40000;color:#fff;padding:7px 14px;border-radius:999px;font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:1px;text-decoration:none;box-shadow:0 0 22px rgba(196,0,0,.55);animation:liveGlow 1.6s ease-in-out infinite;position:relative;z-index:101}
.live-badge .live-pulse{width:9px;height:9px;border-radius:50%;background:#fff;animation:pulse 1.2s infinite}
@keyframes liveGlow{0%,100%{box-shadow:0 0 22px rgba(196,0,0,.55)}50%{box-shadow:0 0 34px rgba(255,40,40,.85)}}

.install-fab,.noti-fab{position:fixed;z-index:1500;border:0;cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:14px;border-radius:999px;padding:13px 20px;box-shadow:0 12px 34px rgba(0,0,0,.45);transition:.3s;display:inline-flex;align-items:center;gap:8px}
.install-fab{left:20px;bottom:20px;background:var(--red);color:#fff}
.install-fab:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(226,35,26,.5)}
.noti-fab{right:20px;bottom:20px;background:rgba(20,11,11,.92);color:#fff;border:1px solid var(--border);backdrop-filter:blur(10px)}
.noti-fab:hover{transform:translateY(-3px);border-color:var(--red)}
@media(max-width:560px){
  .install-fab,.noti-fab{font-size:13px;padding:11px 16px}
  .live-badge .live-text{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}


/* ============================================================
   THEME SYSTEM — transición cinematográfica entre temas
   ============================================================ */

/* Transición suave global SOLO para props de color/fondo */
html{
  transition:
    background-color var(--transition-theme),
    color var(--transition-theme);
}
body,
.result-card,.ticket,.match-card,.contact-card,.modal,
.side,.stat-card,.info-card,.cd-box,.auth-card,
nav,.field input,.field select,.field textarea,
.pax-row input,.qty-btn,.modal-bg,.dash,.tk-item,
.footer-crest,.trend-box,.comp-badge,.live-badge{
  transition:
    background var(--transition-theme),
    background-color var(--transition-theme),
    border-color var(--transition-theme),
    color var(--transition-theme),
    box-shadow var(--transition-theme);
}
/* Animaciones no deben heredar transition */
.spinner,.hero-crest svg,.match-card::before,.scroll-hint,
.live-badge .live-pulse,.install-fab,.noti-fab{
  transition:none!important;
}

/* ---- Aplicar variables semánticas ---- */
body{ background:var(--bg); color:var(--text); }
body::after{ opacity:var(--grain-opacity); }
::-webkit-scrollbar-track{ background:var(--scrollbar); }
::-webkit-scrollbar-thumb{ background:var(--scrollbar-thumb); border-radius:8px; }

/* Nav */
nav.scrolled{
  background:var(--bg-nav);
  box-shadow:0 1px 0 var(--border);
}

/* Campos de formulario */
.field input,.field select,.field textarea,.pax-row input{
  background:var(--bg-input);
  border-color:var(--border);
  color:var(--text);
}
.field select option{ background:var(--select-option); }

/* Cards / secciones */
.result-card,.ticket,.contact-card,.auth-card{
  background:var(--bg-card);
  border-color:var(--border);
  box-shadow:var(--shadow-card);
}
.match-card{
  background:var(--bg-card);
  border-color:var(--border);
  box-shadow:var(--shadow-card);
}
.modal{ background:var(--bg-modal); }
.modal-bg{ background:var(--modal-overlay); }

/* ── Tema claro: sección de contacto ── */
[data-theme="light"] .ctc-channel{
  background:rgba(255,255,255,.65);
  border-color:rgba(0,0,0,.06);
  color:#1c0a0a;
}
[data-theme="light"] .ctc-wa{
  box-shadow:0 0 0 1px rgba(37,211,102,.25),0 0 16px rgba(37,211,102,.08),0 4px 18px rgba(100,20,20,.07);
}
[data-theme="light"] .ctc-wa:hover{
  box-shadow:0 0 0 1px rgba(37,211,102,.5),0 0 28px rgba(37,211,102,.2),0 8px 28px rgba(100,20,20,.1);
}
[data-theme="light"] .ctc-ig{
  box-shadow:0 0 0 1px rgba(193,53,132,.22),0 0 16px rgba(193,53,132,.07),0 4px 18px rgba(100,20,20,.07);
}
[data-theme="light"] .ctc-ig:hover{
  box-shadow:0 0 0 1px rgba(193,53,132,.5),0 0 28px rgba(193,53,132,.2),0 8px 28px rgba(100,20,20,.1);
}
[data-theme="light"] .ctc-email{
  box-shadow:0 0 0 1px rgba(226,35,26,.22),0 0 16px rgba(226,35,26,.08),0 4px 18px rgba(100,20,20,.07);
}
[data-theme="light"] .ctc-email:hover{
  box-shadow:0 0 0 1px rgba(226,35,26,.5),0 0 28px rgba(226,35,26,.2),0 8px 28px rgba(100,20,20,.1);
}
[data-theme="light"] .ctc-ch-icon{
  background:rgba(0,0,0,.05);
  border-color:rgba(0,0,0,.09);
}
[data-theme="light"] .ctc-ch-body small{color:#7a5555}
[data-theme="light"] .ctc-form-wrap{
  background:rgba(255,255,255,.72);
  border-color:rgba(226,35,26,.15);
  box-shadow:0 0 0 1px rgba(226,35,26,.12),0 0 30px rgba(226,35,26,.07),0 20px 60px rgba(100,20,20,.1);
}
[data-theme="light"] .ctc-field input,
[data-theme="light"] .ctc-field textarea,
[data-theme="light"] .ctc-field select{
  background:rgba(255,255,255,.88);
  color:#1c0a0a;
  border-color:rgba(226,35,26,.2);
  backdrop-filter:none;
}
[data-theme="light"] .ctc-field input::placeholder,
[data-theme="light"] .ctc-field textarea::placeholder{color:#a07070;opacity:1}
[data-theme="light"] .ctc-field input:focus,
[data-theme="light"] .ctc-field textarea:focus,
[data-theme="light"] .ctc-field select:focus{
  background:rgba(255,255,255,.98);
  box-shadow:0 0 0 3px rgba(226,35,26,.1);
}

/* Countdown box */
.cd-box{ background:var(--cd-box-bg); border-color:var(--border); }

/* Team tile */
.team-tile{ background:var(--team-tile-bg); border-color:var(--border); }
.hero-crest,.brand .crest{ background:var(--crest-bg); border-color:var(--border); }

/* Texts */
.sec-sub,.rc-top,.rc-team small,.ticket .t-sub,.ticket .t-row,
.note,.f-meta,.info-item span,.trend-box h5,.empty,
.api-state,.match-meta,.tag,.cd-box small,.f-legal{
  color:var(--text-muted);
}

/* Footer */
footer{ background:var(--bg-footer); }
.footer-crest{ background:var(--crest-bg); border-color:var(--border); }

/* Auth pages */
.auth-bg{ background:var(--bg-auth); }

/* Ghost button */
.btn.ghost{ border-color:var(--border); color:var(--text); }
.btn.ghost:hover{ border-color:var(--red); }

/* Qty btn */
.qty-btn{ background:var(--qty-btn-bg); border-color:var(--border); color:var(--text); }

/* Trend tags */
.trend-tag{ border-color:var(--border); color:var(--text-sub); }

/* Summary */
.summary{ background:var(--bg-input); border-color:var(--border); }
.summary .s-row{ color:var(--text-muted); }
.summary .s-total{ border-color:var(--border); color:var(--text); }
.summary .s-rule{ border-color:var(--border); }

/* Modal close */
.close-x{ color:var(--text-muted); }

/* Dashboard side */
.side{ background:var(--bg-side); border-right-color:var(--border); }
.tk-item{ border-color:var(--border); }
.tk-item:hover{ background:rgba(226,35,26,.05); }

/* Hero overlay */
.video-overlay{
  background:var(--overlay-hero);
}
[data-theme="light"] .video-overlay::before{ opacity:.06; }
[data-theme="light"] .hero h1{ color:var(--text); text-shadow:0 0 40px rgba(226,35,26,.25); }
[data-theme="light"] .hero h1 .stroke{ -webkit-text-stroke:2px var(--stroke-hero); }
[data-theme="light"] .hero .tag{ color:var(--text-muted); }
[data-theme="light"] .scroll-hint{ color:var(--text-muted); }

/* Info items */
.info-item b{ color:var(--text); }

/* Dashboard stats */
.stat-card,.info-card{
  background:var(--bg-card);
  border-color:var(--border);
}

/* ---- THEME TOGGLE BUTTON ---- */
.theme-toggle{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--bg-input);
  color:var(--text);
  cursor:pointer;
  font-size:17px;
  line-height:1;
  transition:
    border-color var(--transition-theme),
    background var(--transition-theme),
    box-shadow .2s,
    transform .2s;
  flex-shrink:0;
  position:relative;
  overflow:hidden;
}
.theme-toggle:hover{
  border-color:var(--red);
  box-shadow:0 0 16px rgba(226,35,26,.3);
  transform:scale(1.08);
}
.theme-toggle:active{ transform:scale(.95); }

/* ---- TEAM LOGOS en match card ---- */
.team-logo-wrap{
  width:110px;height:110px;
  border-radius:20px;
  background:var(--team-tile-bg);
  border:1.5px solid var(--border);
  display:grid;place-items:center;
  box-shadow:0 0 28px rgba(226,35,26,.18),var(--shadow-card);
  transition:.4s cubic-bezier(.16,1,.3,1);
  overflow:hidden;
  position:relative;
}
.team-logo-wrap img{
  width:80%;height:80%;
  object-fit:contain;
  transition:.4s;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.team-logo-wrap .fallback-abbr{
  font-family:var(--font-display);
  font-size:38px;
  color:var(--text);
  display:none;
}
.team-logo-wrap.no-img img{ display:none; }
.team-logo-wrap.no-img .fallback-abbr{ display:block; }
/* Escudo SVG local generado por crests.js */
.team-logo-wrap .crest-svg{
  width:80%;height:80%;
  display:grid;place-items:center;
  filter:drop-shadow(0 3px 10px rgba(0,0,0,.45));
  transition:.4s;
}
.team-logo-wrap .crest-svg svg{ width:100%;height:100%; }
.footer-crest .crest-svg svg{ width:44px;height:44px; }
.team-box:hover .team-logo-wrap{
  transform:translateY(-8px) rotateX(6deg);
  box-shadow:0 0 50px rgba(226,35,26,.45),var(--shadow-card);
  border-color:var(--border-hover);
}
.team-box span{
  font-weight:700;
  font-size:15px;
  color:var(--text);
  margin-top:12px;
  letter-spacing:.3px;
}

/* ---- TICKETS FALLBACK GRID ---- */
.ticket-fallback-note{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-muted);
  text-align:center;
  padding:8px;
  grid-column:1/-1;
  opacity:.7;
}

/* ---- TICKET CARD mejorada ---- */
.ticket{
  background:var(--bg-card);
  border:1.5px solid var(--border);
}
.ticket.featured{
  border-color:var(--red);
  box-shadow:0 0 40px rgba(226,35,26,.22),var(--shadow-card);
  position:relative;
}
.ticket.featured::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(circle at top right,rgba(226,35,26,.08),transparent 60%);
  border-radius:inherit;
  pointer-events:none;
}

/* ---- Scrollbar light ---- */
[data-theme="light"]::-webkit-scrollbar-thumb{ background:rgba(180,80,80,.5); }

/* ===== MEJORAS v5 ===== */

/* ---- Transición de tema global suave ---- */
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
  transition:
    background var(--transition-theme),
    background-color var(--transition-theme),
    border-color var(--transition-theme),
    color var(--transition-theme),
    box-shadow var(--transition-theme),
    opacity var(--transition-theme) !important;
}

/* ---- Tipografía mejorada ---- */
.sec-title {
  font-family: var(--font-display);
  font-size: clamp(46px,8vw,96px);
  letter-spacing: 3px;
  line-height: .92;
}
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(72px,16vw,210px);
  letter-spacing: 4px;
}
.hero .tag {
  font-family: var(--font-accent);
  font-size: clamp(13px,2.2vw,18px);
  letter-spacing: 8px;
  font-weight: 600;
}
.eyebrow {
  font-family: var(--font-accent);
  font-size: 13px;
  letter-spacing: 5px;
  font-weight: 700;
}
.brand b {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: 2.5px;
}
.ticket h3 {
  font-family: var(--font-display);
  font-size: 30px;
  letter-spacing: 1px;
}
.score {
  font-family: var(--font-display);
  font-size: 44px;
  letter-spacing: -1px;
}
.cd-box b {
  font-family: var(--font-display);
  font-size: 48px;
}

/* ---- Footer crest mejorado ---- */
.footer-crest {
  width: 88px;
  height: 88px;
  margin: 0 auto 20px;
  border-radius: 20px;
  background: var(--crest-bg);
  border: 1.5px solid var(--border);
  display: grid;
  place-items: center;
  box-shadow: 0 0 40px rgba(226,35,26,.35), var(--shadow-card);
  transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s;
  overflow: hidden;
}
.footer-crest:hover {
  transform: translateY(-6px) scale(1.05);
  box-shadow: 0 0 60px rgba(226,35,26,.55), var(--shadow-card);
}
.footer-crest img {
  width: 70%;
  height: 70%;
  object-fit: contain;
}
footer .f-name {
  font-family: var(--font-display);
  font-size: 34px;
  letter-spacing: 5px;
}

/* ---- Burger animado ---- */
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.burger span { transition: transform .3s, opacity .3s; }

/* ---- Próximo partido: logos de equipos ---- */
.team-logo-wrap {
  width: 120px;
  height: 120px;
  border-radius: 22px;
}
.team-logo-wrap img {
  width: 82%;
  height: 82%;
}

/* ---- Match card VS más estético ---- */
.vs {
  font-family: var(--font-display);
  font-size: 56px;
  letter-spacing: 3px;
  background: linear-gradient(135deg,var(--red),var(--red-glow));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 18px rgba(226,35,26,.6));
}

/* ---- Comp badge mejorado ---- */
.comp-badge {
  font-family: var(--font-accent);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
}

/* ---- Spinner mejorado ---- */
.spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(226,35,26,.18);
  border-top-color: var(--red);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 18px;
}

/* ══════════════════════════════════════
   STICKER CARDS — integradas al tema del sitio
══════════════════════════════════════ */
.holo-card{
  border-radius:20px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background:var(--bg-card);
  border:1px solid var(--border);
  display:flex;
  flex-direction:column;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 20px 55px rgba(0,0,0,.32);
  transition:
    transform    .45s cubic-bezier(.16,1,.3,1),
    box-shadow   .45s cubic-bezier(.16,1,.3,1),
    border-color .35s ease;
}
.holo-card:hover{
  transform:translateY(-10px) rotate(.5deg) scale(1.02);
  border-color:rgba(226,35,26,.6);
  box-shadow:
    0 0 0 1px rgba(226,35,26,.45),
    0 0 38px rgba(226,35,26,.20),
    0 32px 80px rgba(0,0,0,.5);
}

/* Imagen centrada — altura fija para que todas las imgs ocupen el mismo espacio */
.holo-img-wrap{
  flex:none;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px 18px 14px;
  position:relative;
  z-index:1;
  height:270px;
  overflow:hidden;
}
.holo-img{
  width:auto;
  height:100%;
  max-width:100%;
  max-height:240px;
  object-fit:contain;
  position:relative;
  z-index:1;
  filter:drop-shadow(0 6px 20px rgba(226,35,26,.18));
  transition:
    transform .4s cubic-bezier(.16,1,.3,1),
    filter    .4s ease,
    opacity   .38s ease;
}
.holo-card:hover .holo-img{
  transform:scale(1.07) translateY(-4px);
  filter:drop-shadow(0 14px 36px rgba(226,35,26,.32));
}

/* Reflejo sutil: diagonal River Plate (rojo/blanco), apenas perceptible */
.holo-foil{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:2;
  background:linear-gradient(
    138deg,
    transparent              0%,
    rgba(226,35,26,.055)    22%,
    rgba(255,255,255,.10)   38%,
    transparent              52%,
    rgba(226,35,26,.04)     68%,
    rgba(255,255,255,.075)  82%,
    transparent             100%
  );
  background-size:220% 220%;
  animation:stickerSheen 6s ease-in-out infinite alternate;
  border-radius:inherit;
}
[data-theme="light"] .holo-foil{
  background:linear-gradient(
    138deg,
    transparent              0%,
    rgba(226,35,26,.07)     22%,
    rgba(255,255,255,.20)   38%,
    transparent              52%,
    rgba(226,35,26,.05)     68%,
    rgba(255,255,255,.16)   82%,
    transparent             100%
  );
  background-size:220% 220%;
}
@keyframes stickerSheen{
  0%  {background-position:0%   0%}
  100%{background-position:100% 100%}
}

/* Footer */
.holo-footer{
  background:rgba(226,35,26,.07);
  border-top:1px solid rgba(226,35,26,.14);
  padding:11px 16px;
  position:relative;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
}
.holo-label{
  font-family:var(--font-display);
  font-size:10px;
  letter-spacing:3.5px;
  color:var(--text-muted);
  text-transform:uppercase;
  margin:0;
}

/* Mobile: se ocultan */
@media(max-width:600px){ .holo-card{display:none} }

/* ══════════════════════════════════════
   BANNER PUBLICITARIO HOLOGRÁFICO 790×90
══════════════════════════════════════ */
.pub-banner-wrap{
  max-width:790px;margin:0 auto 40px;padding:0 0 0 0;
}
.pub-banner{
  position:relative;
  height:90px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(100,180,255,.2);
  background:linear-gradient(135deg,rgba(4,6,14,.96) 0%,rgba(8,4,18,.96) 50%,rgba(4,8,14,.96) 100%);
  box-shadow:
    0 0 0 1px rgba(100,180,255,.08),
    0 8px 48px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.06);
  cursor:pointer;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s ease,border-color .4s ease;
}
.pub-banner:hover{
  transform:translateY(-3px) scale(1.004);
  border-color:rgba(120,200,255,.45);
  box-shadow:
    0 0 0 1px rgba(120,200,255,.25),
    0 0 60px rgba(80,150,255,.18),
    0 0 120px rgba(180,60,255,.09),
    0 18px 60px rgba(0,0,0,.6);
}

/* Capa holográfica arco-iris animada */
.pub-foil{
  position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;
  background:linear-gradient(
    115deg,
    rgba(255,100,100,.0)    0%,
    rgba(255,180,60,.08)   14%,
    rgba(200,255,100,.07)  28%,
    rgba(60,220,255,.09)   42%,
    rgba(120,80,255,.08)   56%,
    rgba(255,60,200,.07)   70%,
    rgba(255,180,60,.06)   84%,
    rgba(255,100,100,.0)  100%
  );
  background-size:300% 300%;
  animation:pubFoilShift 5s ease-in-out infinite alternate;
  mix-blend-mode:screen;
}
@keyframes pubFoilShift{
  0%  {background-position:0%   30%;opacity:.7}
  50% {background-position:100% 60%;opacity:1}
  100%{background-position:40% 100%;opacity:.75}
}

/* Línea de scan animada */
.pub-scan{
  position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden;border-radius:inherit;
}
.pub-scan::after{
  content:'';position:absolute;top:-100%;left:0;right:0;height:40%;
  background:linear-gradient(180deg,transparent 0%,rgba(100,200,255,.06) 50%,transparent 100%);
  animation:pubScanLine 3.8s linear infinite;
}
@keyframes pubScanLine{
  0%  {top:-40%}
  100%{top:140%}
}

/* Grid lines decorativas */
.pub-grid-lines{
  position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;
  background-image:
    repeating-linear-gradient(90deg,rgba(100,200,255,.025) 0,rgba(100,200,255,.025) 1px,transparent 1px,transparent 79px),
    repeating-linear-gradient(0deg, rgba(100,200,255,.025) 0,rgba(100,200,255,.025) 1px,transparent 1px,transparent 30px);
}

/* Contenido */
.pub-inner{
  position:relative;z-index:3;
  height:100%;
  display:flex;align-items:center;
  padding:0 28px;
  gap:20px;
}
.pub-left{
  flex:1;min-width:0;
}
.pub-tag{
  display:inline-block;
  font-family:var(--font-mono);font-size:8px;letter-spacing:3px;
  color:rgba(120,200,255,.55);
  text-transform:uppercase;margin-bottom:4px;
}
.pub-title{
  font-family:var(--font-display);font-size:22px;letter-spacing:2px;
  color:rgba(255,255,255,.88);
  margin:0 0 2px;line-height:1;
  text-shadow:0 0 30px rgba(100,180,255,.4),0 0 60px rgba(180,60,255,.2);
}
.pub-sub{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:1.5px;
  color:rgba(255,255,255,.22);margin:0;
}

/* Orbe central */
.pub-mid{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  width:60px;
}
.pub-orb{
  position:relative;width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
}
.pub-orb-ring{
  position:absolute;border-radius:50%;border:1px solid;
  animation:pubOrbSpin 4s linear infinite;
}
.pub-orb-ring.r1{inset:0;border-color:rgba(100,200,255,.25);animation-duration:4s}
.pub-orb-ring.r2{inset:6px;border-color:rgba(180,60,255,.2);animation-duration:2.8s;animation-direction:reverse}
.pub-orb-core{
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle,rgba(140,220,255,.9) 0%,rgba(100,160,255,.5) 50%,transparent 100%);
  box-shadow:0 0 14px rgba(100,200,255,.6),0 0 30px rgba(100,180,255,.25);
  animation:pubOrbPulse 2s ease-in-out infinite;
}
@keyframes pubOrbSpin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
@keyframes pubOrbPulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.18)}}

/* Precio */
.pub-right{
  flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px;
}
.pub-price-block{
  display:flex;flex-direction:column;align-items:flex-end;gap:0;
}
.pub-price-desde{
  font-family:var(--font-mono);font-size:8px;letter-spacing:2.5px;
  color:rgba(255,255,255,.28);
}
.pub-price-val{
  font-family:var(--font-display);font-size:20px;letter-spacing:1px;
  color:rgba(140,220,255,.92);line-height:1;
  text-shadow:0 0 20px rgba(100,200,255,.5);
}
.pub-price-unit{
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:2px;
  color:rgba(255,255,255,.22);
}
.pub-cta-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 14px;border-radius:20px;
  background:rgba(100,180,255,.1);
  border:1px solid rgba(100,180,255,.28);
  font-family:var(--font-mono);font-size:9px;letter-spacing:2.5px;
  color:rgba(140,220,255,.8);
  text-decoration:none;
  transition:background .3s,border-color .3s,color .3s;
}
.pub-cta-btn:hover{
  background:rgba(100,180,255,.2);
  border-color:rgba(140,220,255,.5);
  color:#fff;
}
.pub-cta-btn span{transition:transform .25s ease}
.pub-cta-btn:hover span{transform:translateX(3px)}

@media(max-width:600px){
  .pub-banner{height:auto;min-height:70px}
  .pub-inner{padding:12px 16px;flex-wrap:wrap;gap:12px}
  .pub-mid{display:none}
  .pub-right{flex-direction:row;align-items:center;gap:12px;width:100%}
  .pub-title{font-size:16px}
}

/* ---- Ticket grid responsive ---- */
@media (max-width: 600px) {
  .ticket-grid { grid-template-columns: 1fr; }
  .vs-row { gap: 16px; }
  .team-logo-wrap { width: 90px; height: 90px; }
}

/* ===== SPONSORS ===== */
.sponsors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px;margin-bottom:16px}

.sponsor-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:18px;
  padding:26px 16px 20px;display:flex;flex-direction:column;align-items:center;gap:10px;
  cursor:grab;position:relative;
  transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .35s,background .35s;
  user-select:none;overflow:hidden;min-height:128px;
}
.sponsor-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(226,35,26,.13),transparent 65%);
  opacity:0;transition:opacity .4s;pointer-events:none;border-radius:inherit;
}
.sponsor-card:hover{border-color:var(--border-hover);transform:translateY(-6px) scale(1.025);
  box-shadow:0 22px 55px rgba(226,35,26,.2),0 0 0 1px rgba(226,35,26,.15);background:rgba(30,14,14,.94)}
.sponsor-card:hover::before{opacity:1}
.sponsor-card.dragging{opacity:.4;cursor:grabbing;transform:scale(.96);border-color:var(--red)!important}
.sponsor-card.drag-over{border-color:var(--red)!important;box-shadow:0 0 0 2px var(--red),0 0 30px rgba(226,35,26,.3)!important;transform:scale(1.04)!important}

.sponsor-logo-wrap{width:100%;height:44px;display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;transition:filter .35s}
.sponsor-logo-wrap svg{width:100%;height:100%;max-height:44px}
.sponsor-card:hover .sponsor-logo-wrap{filter:drop-shadow(0 0 10px rgba(226,35,26,.45))}

.sponsor-name{font-family:var(--font-accent);font-size:12px;font-weight:700;letter-spacing:2px;
  color:var(--text-muted);text-transform:uppercase;text-align:center;position:relative;z-index:1;
  transition:color .35s}
.sponsor-card:hover .sponsor-name{color:var(--text)}

.sponsor-tier{position:absolute;top:10px;right:10px;font-family:var(--font-accent);font-size:9px;
  letter-spacing:1.5px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase}
.tier-oro{background:rgba(212,170,40,.14);color:#d4aa28;border:1px solid rgba(212,170,40,.28)}
.tier-plata{background:rgba(180,190,200,.1);color:#9bb0c0;border:1px solid rgba(180,190,200,.22)}
.tier-bronce{background:rgba(180,120,70,.1);color:#c49060;border:1px solid rgba(180,120,70,.22)}

.add-sponsor{background:transparent;border:1.5px dashed rgba(226,35,26,.22);border-radius:18px;
  padding:26px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;cursor:pointer;min-height:128px;transition:border-color .3s,background .3s}
.add-sponsor:hover{border-color:rgba(226,35,26,.5);background:rgba(226,35,26,.04)}
.add-sponsor span{font-family:var(--font-accent);font-size:12px;letter-spacing:2px;
  color:rgba(226,35,26,.5);text-transform:uppercase;font-weight:700}
.plus-icon-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid rgba(226,35,26,.3);
  display:flex;align-items:center;justify-content:center;color:rgba(226,35,26,.5);
  font-size:20px;transition:border-color .3s,color .3s;line-height:1}
.add-sponsor:hover .plus-icon-btn{border-color:var(--red);color:var(--red)}

/* ── Sponsor ticker / marquee ──────────────────────────── */
.sp-ticker-wrap{
  width:100%;overflow:hidden;position:relative;
  margin-top:44px;padding:16px 0;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.sp-ticker{
  display:flex;white-space:nowrap;
}
.sp-ticker-track{
  display:inline-flex;align-items:center;
  gap:24px;
  animation:spTicker 20s linear infinite;
  will-change:transform;flex-shrink:0;
}
.sp-ticker-wrap:hover .sp-ticker-track{animation-play-state:paused}

/* Logo card de sponsor */
.sp-logo{
  flex-shrink:0;
  display:inline-flex;flex-direction:column;align-items:center;
  gap:5px;padding:12px 22px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--sp-border, rgba(255,255,255,.08));
  border-radius:12px;
  min-width:130px;
  transition:background .2s,border-color .2s,transform .2s;
  cursor:default;
}
.sp-logo:hover{
  background:rgba(255,255,255,.06);
  border-color:var(--sp-c, rgba(255,255,255,.2));
  transform:translateY(-2px);
}
.sp-logo-badge{
  font-family:'Sometype Mono',monospace;
  font-size:7px;letter-spacing:3px;text-transform:uppercase;
  padding:2px 8px;border-radius:20px;
  font-weight:600;line-height:1.4;
}
.sp-logo-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:17px;letter-spacing:2.5px;
  color:var(--sp-c, rgba(255,255,255,.75));
  white-space:nowrap;line-height:1;
}

/* Banner gobierno.gif */
.sp-banner-wrap{
  flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;
  border-radius:10px;
  padding:8px 20px;
  transition:background .2s;
}
.sp-banner-wrap:hover{background:#f8f8f8}
.sp-banner-img{
  display:block;
  height:52px;width:auto;
  max-width:380px;
  object-fit:contain;
}

@keyframes spTicker{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ── Ticker institucional rediseñado (om-ticker) ──────── */
.om-ticker-wrap{
  width:100%;overflow:hidden;
  padding:20px 0;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
}
.om-ticker-inner{display:flex;white-space:nowrap}
.om-ticker-track{
  display:inline-flex;align-items:center;
  gap:28px;flex-shrink:0;
  animation:omTicker 28s linear infinite;
  will-change:transform;
}
.om-ticker-wrap:hover .om-ticker-track{animation-play-state:paused}

/* Tarjeta de sponsor */
.om-sp-card{
  flex-shrink:0;
  display:inline-flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:6px;
  height:88px;min-width:160px;padding:0 24px;
  border-radius:14px;
  background:rgba(255,255,255,.03);
  border:1px solid;
  cursor:default;
  transition:background .25s,border-color .25s,transform .25s;
}
.om-sp-card:hover{background:rgba(255,255,255,.06);transform:translateY(-3px)}
.om-sp-badge{
  font-family:'Sometype Mono',monospace;
  font-size:8px;letter-spacing:3px;text-transform:uppercase;
  font-weight:600;padding:2px 9px;border-radius:20px;
}
.om-sp-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:21px;letter-spacing:3px;
  white-space:nowrap;line-height:1;
}

/* Banner gobierno.gif */
.om-gov-wrap{
  flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  height:88px;padding:8px 16px;
  border-radius:12px;background:#fff;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.om-gov-img{
  display:block;
  height:72px;width:auto;
  max-width:600px;
  object-fit:contain;
}

@keyframes omTicker{
  from{transform:translateX(0)}
  to{transform:translateX(-100%)}
}

/* ── Sección YouTube ───────────────────────────────────── */
.yt-section{
  padding:100px 5vw;
  position:relative;
  overflow:hidden;
}
.yt-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 70% 50%, rgba(226,35,26,.06) 0%, transparent 70%);
  pointer-events:none;
}
.yt-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.35fr;
  gap:64px;align-items:center;
}

/* Texto */
.yt-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(42px,5vw,64px);letter-spacing:3px;
  color:rgba(255,255,255,.9);
  line-height:1;margin:12px 0 18px;
}
.yt-title-accent{color:var(--red)}
.yt-desc{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px;line-height:1.75;
  color:rgba(255,255,255,.38);
  max-width:360px;margin-bottom:28px;
}
.yt-stats{
  display:flex;align-items:center;gap:16px;margin-bottom:32px;
}
.yt-stat{display:flex;flex-direction:column;gap:2px}
.yt-stat-num{
  font-family:'Bebas Neue',sans-serif;
  font-size:28px;letter-spacing:1px;color:rgba(255,255,255,.85);
}
.yt-stat-lbl{
  font-family:'Sometype Mono',monospace;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.25);
}
.yt-stat-div{width:1px;height:32px;background:rgba(255,255,255,.1);flex-shrink:0}
.yt-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:12px;
  background:var(--red);color:#fff;
  font-family:'Sometype Mono',monospace;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  text-decoration:none;
  transition:background .2s,transform .2s,box-shadow .2s;
  box-shadow:0 4px 24px rgba(226,35,26,.3);
}
.yt-cta:hover{background:#c01c13;transform:translateY(-2px);box-shadow:0 8px 32px rgba(226,35,26,.4)}

/* Player */
.yt-player-wrap{position:relative}
.yt-player-frame{
  position:relative;border-radius:20px;overflow:hidden;
  aspect-ratio:16/9;
  box-shadow:0 20px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.06);
}
.yt-thumb{
  position:absolute;inset:0;
  background-color:#0a0a0a;
  background-size:cover;background-position:center;
  transition:opacity .4s;
}
.yt-thumb-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,10,10,.7) 0%,rgba(226,35,26,.08) 100%);
}
.yt-band{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,transparent 48%,rgba(226,35,26,.12) 48%,rgba(226,35,26,.12) 52%,transparent 52%);
  pointer-events:none;
}
.yt-play-btn{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:72px;height:72px;
  border-radius:50%;
  background:rgba(226,35,26,.9);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s,box-shadow .2s;
  box-shadow:0 0 0 12px rgba(226,35,26,.15),0 8px 32px rgba(0,0,0,.5);
  z-index:2;
}
.yt-play-btn:hover{
  background:var(--red);
  transform:translate(-50%,-50%) scale(1.08);
  box-shadow:0 0 0 18px rgba(226,35,26,.12),0 12px 48px rgba(0,0,0,.6);
}
.yt-play-btn svg{margin-left:4px}
.yt-brand-overlay{
  position:absolute;bottom:16px;left:16px;
  display:flex;align-items:center;gap:10px;
  z-index:2;
}
.yt-brand-crest{
  width:30px;height:30px;object-fit:contain;
  border-radius:6px;background:rgba(0,0,0,.4);
  padding:3px;
}
.yt-brand-tag{
  font-family:'Bebas Neue',sans-serif;
  font-size:16px;letter-spacing:3px;
  color:rgba(255,255,255,.85);
  text-shadow:0 1px 8px rgba(0,0,0,.8);
}
.yt-iframe{
  position:absolute;inset:0;width:100%;height:100%;
  border:none;border-radius:20px;z-index:3;
}
/* Decoraciones externas */
.yt-deco{
  position:absolute;border-radius:50%;
  pointer-events:none;
}
.yt-deco-1{
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(226,35,26,.12) 0%,transparent 70%);
  top:-40px;right:-40px;
}
.yt-deco-2{
  width:140px;height:140px;
  background:radial-gradient(circle,rgba(255,255,255,.04) 0%,transparent 70%);
  bottom:-20px;left:-20px;
}
@media(max-width:860px){
  .yt-inner{grid-template-columns:1fr;gap:40px}
  .yt-desc{max-width:100%}
  .yt-player-wrap{order:-1}
}

.drag-hint{text-align:center;font-family:var(--font-accent);font-size:11px;letter-spacing:2.5px;
  color:var(--text-muted);margin-bottom:0;opacity:.6}

/* ===== TESTIMONIOS ===== */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}

.testi-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:22px;
  padding:30px 26px;position:relative;overflow:hidden;
  transition:transform .38s cubic-bezier(.16,1,.3,1),border-color .38s,box-shadow .38s,background .38s;
}
.testi-card::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(226,35,26,.09),transparent 58%);
  opacity:0;transition:opacity .4s;pointer-events:none;border-radius:inherit;
}
.testi-card:hover::after{opacity:1}
.testi-card:hover{border-color:rgba(226,35,26,.38);transform:translateY(-7px);
  box-shadow:0 26px 65px rgba(0,0,0,.5),0 0 0 1px rgba(226,35,26,.14);background:rgba(30,14,14,.92)}

.testi-quote{font-family:Georgia,serif;font-size:70px;line-height:.65;color:var(--red);
  opacity:.3;display:block;margin-bottom:8px;transition:opacity .38s}
.testi-card:hover .testi-quote{opacity:.65}

.testi-trip-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(226,35,26,.09);
  border:1px solid rgba(226,35,26,.18);color:rgba(226,35,26,.8);font-family:var(--font-accent);
  font-size:10px;font-weight:700;letter-spacing:1.5px;padding:3px 11px;border-radius:999px;
  text-transform:uppercase;margin-bottom:12px;transition:background .38s,border-color .38s}
.testi-card:hover .testi-trip-badge{background:rgba(226,35,26,.16);border-color:rgba(226,35,26,.38)}

.testi-stars{color:#d4aa28;font-size:13px;letter-spacing:2px;margin-bottom:12px}

.testi-text{font-size:14px;line-height:1.75;color:rgba(240,235,232,.78);margin-bottom:22px;
  font-style:italic;position:relative;z-index:1}

.testi-author{display:flex;align-items:center;gap:12px;position:relative;z-index:1}

.testi-avatar{width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--red-deep),#3a1010);
  border:1.5px solid rgba(226,35,26,.3);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:18px;color:#fff;flex-shrink:0;
  transition:border-color .38s,box-shadow .38s}
.testi-card:hover .testi-avatar{border-color:rgba(226,35,26,.65);box-shadow:0 0 18px rgba(226,35,26,.28)}

.testi-name{font-family:var(--font-accent);font-size:14px;font-weight:700;letter-spacing:.5px;
  color:var(--text);display:block}
.testi-meta{font-family:var(--font-accent);font-size:11px;color:var(--text-muted);
  letter-spacing:.5px;margin-top:2px}

@media(max-width:600px){
  .sponsors-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
}

/* ============================================================
   CALENDARIO — lista de próximos partidos (inspirado en ref.)
   ============================================================ */
.calendar-list{
  max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px;
}
.cal-row{
  display:flex;align-items:center;gap:18px;width:100%;text-align:left;
  background:var(--bg-card);border:1px solid var(--border);border-radius:16px;
  padding:16px 20px;cursor:pointer;color:var(--text);font-family:inherit;
  transition:.25s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(8px);
}
.cal-row:hover:not([disabled]){
  transform:translateX(6px);border-color:var(--red-glow);
  box-shadow:0 8px 30px rgba(226,35,26,.22);
}
.cal-row[disabled]{opacity:.55;cursor:default}
.cal-date{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:54px;line-height:1;
}
.cal-date b{font-family:var(--font-display);font-size:30px;color:var(--red-glow)}
.cal-date small{font-size:11px;letter-spacing:1px;color:var(--text);opacity:.6;margin-top:2px}
.cal-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}
.cal-teams{font-weight:700;font-size:1.05rem}
.cal-teams i{color:var(--red-glow);font-style:normal;font-weight:800;margin:0 4px}
.cal-meta{font-size:.82rem;opacity:.7}
.cal-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:88px}
.cal-badge{
  font-family:var(--font-display);font-size:12px;letter-spacing:1px;
  padding:3px 12px;border-radius:999px;
}
.cal-local{background:rgba(226,35,26,.18);color:var(--red-glow);border:1px solid rgba(226,35,26,.4)}
.cal-visitante{background:rgba(180,190,200,.12);color:#9bb0c0;border:1px solid rgba(180,190,200,.3)}
.cal-hora{font-size:.8rem;opacity:.7}
@media(max-width:560px){
  .cal-row{gap:12px;padding:14px}
  .cal-teams{font-size:.95rem}
  .cal-meta{font-size:.74rem}
  .cal-right{min-width:72px}
  .cal-date b{font-size:24px}
}

/* Resaltado del viaje al venir desde el Calendario */
.ticket.viaje-focus{
  animation:viajePulse 2.4s ease;
  border-color:var(--red-glow)!important;
}
@keyframes viajePulse{
  0%,100%{box-shadow:0 0 0 rgba(226,35,26,0)}
  20%,60%{box-shadow:0 0 0 4px rgba(226,35,26,.45),0 12px 40px rgba(226,35,26,.3)}
}

/* Desplegable "¿Qué incluye?" en los tickets */
.t-incluye{margin:10px 0;font-size:.85rem}
.t-incluye summary{cursor:pointer;color:var(--red-glow);font-weight:600;list-style:none}
.t-incluye summary::-webkit-details-marker{display:none}
.t-incluye summary::before{content:'▸ ';transition:.2s}
.t-incluye[open] summary::before{content:'▾ '}
.t-incluye ul{list-style:none;padding:8px 0 0;margin:0;display:flex;flex-direction:column;gap:4px}
.t-incluye li{opacity:.8}

/* Botón MercadoPago */
.mp-btn{background:#009ee3!important;margin-top:8px;text-decoration:none;display:block;text-align:center}
.mp-btn:hover{background:#0089c7!important}

/* ============================================================
   FIX TEMA CLARO — evitar texto blanco invisible
   ============================================================ */
[data-theme="light"] .brand{ color:var(--text); }
[data-theme="light"] .nav-links a:hover{ color:var(--red); }
[data-theme="light"] .sec-title{ color:var(--text); }
[data-theme="light"] .testi-text{ color:var(--text-2); }
[data-theme="light"] .testi-name{ color:var(--text); }
/* hover sobre dark bg en light mode → texto claro */
[data-theme="light"] .testi-card:hover .testi-text{ color:rgba(240,235,232,.85); }
[data-theme="light"] .testi-card:hover .testi-name{ color:#f0ede8; }
[data-theme="light"] .testi-card:hover .testi-meta{ color:rgba(240,235,232,.55); }
[data-theme="light"] .rc-team{ color:var(--text); }
[data-theme="light"] .ticket h3{ color:var(--text); }
[data-theme="light"] .cal-teams{ color:var(--text); }
[data-theme="light"] .team-box span{ color:var(--text); }
[data-theme="light"] .cd-box b{ color:var(--red); }
[data-theme="light"] .f-name{ color:var(--text); }
[data-theme="light"] .score{ color:var(--text); }
[data-theme="light"] .score.win{ color:#16a34a;text-shadow:none; }
[data-theme="light"] .score.loss{ color:#dc2626;text-shadow:none; }
[data-theme="light"] .score.draw{ color:#d97706;text-shadow:none; }
[data-theme="light"] .stat .s-val{ color:var(--red); }
/* Asegurar que el título de sección siempre tome el color del tema */
.sec-title{ color:var(--text); }
.testi-name{ color:var(--text); }

/* ============================================================
   AUTH (login / registro / recuperar) + DASHBOARD
   ============================================================ */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg-auth)}
/* Auth-card: override la definición anterior (línea ~1070) con mayor contraste */
.auth-card{
  width:100%;max-width:420px;
  background:linear-gradient(160deg,rgba(30,14,14,.96),rgba(8,4,4,.98));
  border:1px solid rgba(226,35,26,.35);
  border-radius:22px;padding:36px 30px;
  backdrop-filter:blur(24px) saturate(160%);
  box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 0 1px rgba(226,35,26,.1) inset;
  animation:popUp .45s cubic-bezier(.16,1,.3,1);
}
.auth-back{display:inline-block;margin-bottom:18px;color:var(--text-muted);text-decoration:none;font-size:13px}
.auth-back:hover{color:var(--red)}
/* Light mode override para auth-card */
[data-theme="light"] .auth-card{
  background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(250,245,245,.99));
  border-color:rgba(226,35,26,.25);
  box-shadow:0 20px 60px rgba(100,20,20,.12),0 0 0 1px rgba(226,35,26,.08) inset;
}
.auth-title{font-family:var(--font-display);font-size:38px;letter-spacing:1px;color:var(--text);line-height:1}
.auth-sub{color:var(--text-muted);font-size:14px;margin:6px 0 24px}
.auth-card .field{margin-bottom:16px}
.auth-card label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-2)}
.auth-card input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:15px;outline:none;transition:.2s}
.auth-card input:focus{border-color:var(--red)}
.auth-card .btn{width:100%;margin-top:8px}
.auth-alt{text-align:center;font-size:13px;color:var(--text-muted);margin-top:14px}
.auth-alt a{color:var(--red);text-decoration:none;font-weight:600}

.dash-wrap{max-width:900px;margin:0 auto;padding:24px;min-height:100vh}
.dash-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.dash-hero{display:flex;align-items:center;gap:18px;margin-bottom:30px}
.dash-avatar{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:var(--red);color:#fff;font-family:var(--font-display);font-size:26px}
.dash-name{font-family:var(--font-display);font-size:32px;color:var(--text);line-height:1}
.dash-meta{color:var(--text-muted);font-size:14px}
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px}
.dash-card h3{font-family:var(--font-display);font-size:22px;color:var(--text);margin-bottom:12px;letter-spacing:.5px}
.dash-empty{color:var(--text-muted);font-size:14px;line-height:1.6}
.dash-empty a{color:var(--red);text-decoration:none;font-weight:600}

/* ============================================================
   RESPONSIVE AFINADO — móvil first, ajustes finos
   ============================================================ */
@media(max-width:720px){
  /* Calendario: la fila se mantiene legible */
  .cal-row{gap:12px;padding:14px 16px}
  .cal-teams{font-size:.98rem}
  .cal-meta{font-size:.76rem}
  .cal-right{min-width:80px}
  .cal-date{min-width:46px}
  .cal-date b{font-size:26px}
  /* Tickets: una columna cómoda */
  .ticket-grid{grid-template-columns:1fr;gap:18px}
  /* Resultados en una columna */
  .results-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  /* Countdown compacto sin desbordar */
  .countdown{gap:8px}
  .cd-box{min-width:0;flex:1;padding:10px 6px}
  .cd-box b{font-size:28px}
  .cd-box small{font-size:9px}
  /* Match meta apilada */
  .match-meta{gap:12px;font-size:12px}
  /* Calendario: badge y hora alineados */
  .cal-row{flex-wrap:nowrap}
  .cal-badge{font-size:10px;padding:2px 8px}
  .cal-hora{font-size:.72rem}
  /* Títulos no tan gigantes en móvil */
  .sec-title{font-size:clamp(34px,11vw,56px)}
  /* Escudos del partido un poco más chicos */
  .team-logo-wrap{width:78px;height:78px}
  .vs{font-size:28px}
}
/* Imágenes y SVG nunca desbordan */
img,svg{max-width:100%;height:auto}
.crest-svg svg{height:auto}

/* Video hero: visible en todos los tamaños */

/* ============================================================
   HERO ORBS — fondo animado visible en móvil (sin video)
   ============================================================ */
.hero-orbs{
  position:absolute;inset:0;z-index:0;
  overflow:hidden;pointer-events:none;
}
.orb{
  position:absolute;border-radius:50%;
  filter:blur(100px);opacity:0;
  will-change:transform;
}
/* Solo visibles en móvil */
@media(max-width:768px){
  .orb-1{opacity:.72}
  .orb-2{opacity:.58}
  .orb-3{opacity:.48}
}
.orb-1{
  width:80vw;height:80vw;max-width:480px;max-height:480px;
  background:radial-gradient(circle,rgba(226,35,26,.75),rgba(155,15,10,.38) 55%,transparent 75%);
  top:-20%;left:-20%;
  animation:orbDrift1 13s ease-in-out infinite;
}
.orb-2{
  width:65vw;height:65vw;max-width:400px;max-height:400px;
  background:radial-gradient(circle,rgba(155,15,10,.65),rgba(80,5,5,.32) 55%,transparent 75%);
  bottom:-10%;right:-15%;
  animation:orbDrift2 16s ease-in-out infinite;
}
.orb-3{
  width:55vw;height:55vw;max-width:340px;max-height:340px;
  background:radial-gradient(circle,rgba(255,59,48,.42),rgba(155,15,10,.22) 60%,transparent 80%);
  top:38%;left:32%;
  animation:orbDrift3 19s ease-in-out infinite;
}
@keyframes orbDrift1{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(28px,-38px) scale(1.13)}
  66%{transform:translate(-18px,22px) scale(.92)}
}
@keyframes orbDrift2{
  0%,100%{transform:translate(0,0) scale(1)}
  40%{transform:translate(-32px,28px) scale(1.11)}
  75%{transform:translate(18px,-16px) scale(.96)}
}
@keyframes orbDrift3{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-22px,-28px) scale(1.16)}
}

/* ============================================================
   OFERTA WIDGET — minimizable, esquina inferior derecha
   ============================================================ */

/* Contenedor raíz */
.ow-root{
  position:fixed;bottom:20px;right:20px;z-index:1200;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
}

/* Botón trigger (estado minimizado) */
.ow-trigger{
  display:flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;
  border:none;border-radius:999px;
  padding:11px 18px;
  font-family:var(--font-display);font-size:15px;letter-spacing:1px;
  cursor:pointer;box-shadow:0 8px 30px rgba(226,35,26,.45);
  transition:.25s cubic-bezier(.16,1,.3,1);
}
.ow-trigger:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(226,35,26,.55)}
.ow-trigger.hidden{display:none}
.ow-trigger-dot{
  width:8px;height:8px;border-radius:50%;background:#fff;
  animation:pulse 1.4s infinite;flex-shrink:0;
}

/* Panel expandido */
.ow-panel{
  display:none;
  width:300px;max-width:calc(100vw - 40px);
  transform:translateY(10px);opacity:0;
  transition:transform .35s cubic-bezier(.16,1,.3,1), opacity .3s;
}
.ow-panel.open{
  display:block;
  animation:owSlideUp .35s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes owSlideUp{
  from{transform:translateY(12px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

/* Card */
.ow-card{
  background:linear-gradient(160deg,rgba(22,8,8,.95),rgba(6,2,2,.98));
  border:1px solid rgba(226,35,26,.3);
  border-radius:18px;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 40px rgba(226,35,26,.1);
  backdrop-filter:blur(16px);
  transform-style:preserve-3d;
  position:relative;
  transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.ow-shimmer{position:absolute;inset:0;pointer-events:none;border-radius:18px;z-index:0;transition:background .1s}

/* Header */
.ow-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px 4px;position:relative;z-index:1;
}
.ow-badge-live{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(226,35,26,.15);border:1px solid rgba(226,35,26,.4);
  color:#ff6b5b;font-family:var(--font-mono);font-size:9px;font-weight:700;
  letter-spacing:2px;padding:3px 9px;border-radius:999px;
}
.ow-dot{width:6px;height:6px;border-radius:50%;background:#ff4433;animation:pulse 1.3s infinite;flex-shrink:0}
.ow-close-btn{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.5);border-radius:7px;width:26px;height:26px;
  display:grid;place-items:center;cursor:pointer;font-size:12px;transition:.2s;
}
.ow-close-btn:hover{background:rgba(226,35,26,.2);color:#fff;border-color:rgba(226,35,26,.4)}

/* Hero title */
.ow-hero-title{
  padding:2px 14px 8px;
  font-family:var(--font-display);font-size:22px;letter-spacing:2px;
  color:#fff;position:relative;z-index:1;
  text-shadow:0 0 20px rgba(226,35,26,.5);
}
.ow-hero-title span{
  background:linear-gradient(135deg,#fff 30%,var(--red-glow));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Match + body */
.ow-match{
  background:rgba(226,35,26,.06);border:1px solid rgba(226,35,26,.12);
  border-radius:12px;padding:10px 12px;margin:0 14px;
}
.ow-teams{
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-display);font-size:18px;letter-spacing:1.5px;margin-bottom:6px;
}
.ow-team-r{color:#ff4433;text-shadow:0 0 10px rgba(226,35,26,.5)}
.ow-team-b{color:#d8d0d0}
.ow-vs{font-size:12px;color:rgba(255,255,255,.3);font-family:var(--font-mono)}
.ow-match-meta{
  display:flex;flex-wrap:wrap;gap:4px 12px;
  font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.5);
}

/* Scarcity */
.ow-scarcity{padding:8px 14px}
.ow-scarcity-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.5);margin-bottom:4px}
.ow-scarcity-tag{background:rgba(240,160,32,.15);border:1px solid rgba(240,160,32,.3);color:#f0a020;padding:2px 7px;border-radius:999px;font-size:8px;letter-spacing:1px;font-weight:700}
.ow-bar-bg{height:4px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden}
.ow-bar-fill{height:100%;width:76%;border-radius:999px;background:linear-gradient(90deg,var(--red),var(--red-glow));animation:owBarPulse 2s ease-in-out infinite}
@keyframes owBarPulse{0%,100%{opacity:1}50%{opacity:.65}}

/* Pricing */
.ow-pricing{
  background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.05);
  border-radius:12px;padding:10px 12px;margin:0 14px;
  display:flex;flex-direction:column;gap:7px;
}
.ow-pricing-label{font-family:var(--font-mono);font-size:9px;letter-spacing:1px;color:rgba(255,255,255,.4);text-transform:uppercase}
.ow-price-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ow-price-item{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:8px;padding:8px;display:flex;flex-direction:column;gap:3px;
}
.ow-price-item span{font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.4)}
.ow-price-item strong{font-family:var(--font-display);font-size:17px;color:#fff;letter-spacing:.5px}
.ow-price-item.ow-featured{border-color:rgba(226,35,26,.3);background:rgba(226,35,26,.07)}
.ow-price-item.ow-featured strong{color:var(--red-glow)}
.ow-traslado{font-size:10px;color:rgba(255,255,255,.4);padding-top:4px;border-top:1px solid rgba(255,255,255,.06)}
.ow-traslado strong{color:rgba(255,255,255,.75)}

/* Trust */
.ow-trust{
  margin:0 14px;display:flex;flex-direction:column;gap:3px;
  font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.45);
  padding:7px 10px;background:rgba(29,185,84,.05);border:1px solid rgba(29,185,84,.1);border-radius:10px;
}

/* CTA */
.ow-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin:0 14px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;font-weight:800;font-size:13px;
  padding:11px;border-radius:10px;text-decoration:none;
  box-shadow:0 6px 24px rgba(37,211,102,.25);
  transition:transform .2s,box-shadow .2s;
}
.ow-cta:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(37,211,102,.4)}

/* Contact */
.ow-contact{
  display:flex;flex-wrap:wrap;gap:4px 12px;justify-content:center;
  font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.25);
  letter-spacing:.5px;margin:0 14px 14px;
}

/* ── Oferta card — tema claro ───────────────────────────────── */
[data-theme="light"] .ow-card{
  background:linear-gradient(160deg,rgba(255,252,250,.98),rgba(255,247,245,1));
  border-color:rgba(226,35,26,.18);
  box-shadow:0 20px 60px rgba(100,20,20,.1),0 0 30px rgba(226,35,26,.05);
}
[data-theme="light"] .ow-close-btn{
  background:rgba(0,0,0,.05);
  border-color:rgba(0,0,0,.1);
  color:rgba(28,10,10,.5);
}
[data-theme="light"] .ow-close-btn:hover{
  background:rgba(226,35,26,.12);
  color:#c01010;
  border-color:rgba(226,35,26,.3);
}
[data-theme="light"] .ow-hero-title{
  color:#1c0a0a;
  text-shadow:none;
}
[data-theme="light"] .ow-hero-title span{
  background:linear-gradient(135deg,#1c0a0a 20%,var(--red));
  -webkit-background-clip:text;
  background-clip:text;
}
[data-theme="light"] .ow-match{
  background:rgba(226,35,26,.05);
  border-color:rgba(226,35,26,.15);
}
[data-theme="light"] .ow-team-b{ color:#1c0a0a }
[data-theme="light"] .ow-vs{ color:rgba(28,10,10,.35) }
[data-theme="light"] .ow-match-meta{ color:rgba(28,10,10,.5) }
[data-theme="light"] .ow-scarcity-row{ color:rgba(28,10,10,.45) }
[data-theme="light"] .ow-bar-bg{ background:rgba(0,0,0,.08) }
[data-theme="light"] .ow-pricing{
  background:rgba(0,0,0,.03);
  border-color:rgba(0,0,0,.07);
}
[data-theme="light"] .ow-pricing-label{ color:rgba(28,10,10,.45) }
[data-theme="light"] .ow-price-item{
  background:rgba(255,255,255,.7);
  border-color:rgba(0,0,0,.08);
}
[data-theme="light"] .ow-price-item span{ color:rgba(28,10,10,.45) }
[data-theme="light"] .ow-price-item strong{ color:#1c0a0a }
[data-theme="light"] .ow-price-item.ow-featured{
  border-color:rgba(226,35,26,.25);
  background:rgba(226,35,26,.06);
}
[data-theme="light"] .ow-traslado{
  color:rgba(28,10,10,.45);
  border-top-color:rgba(0,0,0,.07);
}
[data-theme="light"] .ow-traslado strong{ color:rgba(28,10,10,.8) }
[data-theme="light"] .ow-trust{
  color:rgba(28,10,10,.45);
  background:rgba(37,211,102,.06);
  border-color:rgba(37,211,102,.15);
}
[data-theme="light"] .ow-contact{ color:rgba(28,10,10,.3) }

/* ============================================================
   MEJORAS 3D GLOBALES — cards con perspectiva
   ============================================================ */
.result-card,.ticket{
  transform-style:preserve-3d;
  transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .4s;
}
.result-card:hover{
  transform:translateY(-8px) rotateX(3deg);
}
.ticket:hover{
  transform:translateY(-10px) rotateX(3deg) rotateY(-2deg);
}
.match-card{
  transform-style:preserve-3d;
  perspective:1000px;
}
/* Sección hero-stats con profundidad */
.hero-stats{
  display:flex;align-items:center;gap:32px;margin-top:48px;
  flex-wrap:wrap;justify-content:center;
}
.h-stat{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transform-style:preserve-3d;
}
.h-stat b{
  font-family:var(--font-display);font-size:clamp(36px,6vw,72px);
  color:#fff;line-height:1;
  text-shadow:0 0 30px rgba(226,35,26,.5),0 4px 16px rgba(0,0,0,.5);
}
.h-stat span{
  font-family:var(--font-mono);font-size:11px;letter-spacing:3px;
  color:rgba(255,255,255,.45);text-transform:uppercase;
}
.h-stat-sep{width:1px;height:48px;background:rgba(226,35,26,.25)}
/* CTAs del hero */
.hero-ctas{
  display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;justify-content:center;
}
.hero-btn-primary{
  background:linear-gradient(135deg,var(--red),var(--red-deep));
  color:#fff;padding:14px 32px;border-radius:12px;font-weight:700;font-size:15px;
  letter-spacing:.5px;text-decoration:none;display:inline-flex;align-items:center;
  gap:8px;box-shadow:0 8px 30px rgba(226,35,26,.45);
  transition:transform .3s,box-shadow .3s;
}
.hero-btn-primary:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 50px rgba(226,35,26,.6)}
.hero-btn-ghost{
  background:rgba(255,255,255,.06);backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,.15);color:#fff;
  padding:14px 32px;border-radius:12px;font-weight:700;font-size:15px;
  letter-spacing:.5px;text-decoration:none;display:inline-flex;align-items:center;
  gap:8px;transition:transform .3s,border-color .3s,box-shadow .3s;
}
.hero-btn-ghost:hover{
  transform:translateY(-4px);border-color:rgba(226,35,26,.5);
  box-shadow:0 8px 30px rgba(226,35,26,.2);
}
/* Mute button */
.hero-mute{
  position:absolute;bottom:30px;right:30px;z-index:4;
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.4);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;cursor:pointer;display:grid;place-items:center;
  transition:.25s;
}
.hero-mute:hover{border-color:var(--red);background:rgba(226,35,26,.2)}

/* ── Auth pages standalone ── */
.auth-section{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px;background:var(--bg-auth)}
.auth-crest{width:72px;height:72px;margin:0 auto 18px;border-radius:18px;background:linear-gradient(150deg,#1f1212,#0a0606);border:1px solid var(--border);display:grid;place-items:center;box-shadow:0 0 30px rgba(226,35,26,.3)}
.auth-crest img{width:44px;height:44px;object-fit:contain}
.auth-card h1{font-family:var(--font-display);font-size:32px;text-align:center;letter-spacing:1px;margin-bottom:4px}
.auth-sub{color:var(--text-muted);font-size:14px;text-align:center;margin-bottom:26px}
.auth-error{background:rgba(226,35,26,.12);border:1px solid rgba(226,35,26,.35);border-radius:10px;padding:12px 14px;font-size:14px;color:var(--red-glow);margin-bottom:16px}
.auth-links{display:flex;justify-content:center;gap:12px;margin-top:18px;font-size:13px;color:var(--text-muted)}
.auth-links a{color:var(--red);text-decoration:none}.auth-links a:hover{text-decoration:underline}
.btn-full{width:100%;margin-top:8px}

/* ── Dashboard standalone ── */
.dash-section{padding:100px 20px 60px;max-width:960px;margin:0 auto}
.dash-header{display:flex;align-items:center;gap:18px;margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.dash-header h1{font-family:var(--font-display);font-size:36px;letter-spacing:1px;margin:0}
.dash-sub{color:var(--text-muted);font-size:14px;margin:4px 0 0}
.dash-grid{display:grid;gap:24px}
.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:24px}
.d-stat{text-align:center}.d-stat b{display:block;font-family:var(--font-display);font-size:38px;color:var(--red)}.d-stat span{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.dash-tickets{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:28px}
.dash-tickets h2,.dash-actions h2{font-family:var(--font-display);font-size:22px;letter-spacing:1px;margin:0 0 18px}
.ticket-list{display:flex;flex-direction:column;gap:12px}
.t-row-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;gap:12px;flex-wrap:wrap}
.t-row-left{display:flex;flex-direction:column;gap:3px}.t-row-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.t-codigo{font-family:var(--font-mono);font-size:12px;color:var(--red-glow)}.t-partido{font-size:14px;font-weight:600}.t-fecha{font-size:12px;color:var(--text-muted)}
.t-qty{font-size:14px}.t-price{font-family:var(--font-display);font-size:18px}
.t-estado{font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:20px;text-transform:uppercase}
.t-estado.confirmed{background:rgba(29,185,84,.15);color:#1db954}.t-estado.pending{background:rgba(240,160,32,.15);color:#f0a020}.t-estado.cancelled{background:rgba(226,35,26,.15);color:var(--red)}
.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{color:var(--text-muted);margin-bottom:20px}
.dash-actions{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:28px}
.action-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px;background:var(--bg-2);border:1px solid var(--border);border-radius:14px;color:var(--text);text-decoration:none;font-size:13px;font-weight:600;transition:.2s;text-align:center}
.action-btn:hover{border-color:var(--red);transform:translateY(-2px)}.action-btn.logout{color:var(--red)}
@media(max-width:600px){.dash-stats{grid-template-columns:repeat(3,1fr);gap:8px}.dash-stats .d-stat b{font-size:28px}.t-row-item{flex-direction:column;align-items:flex-start}}

/* ══════════════════════════════════════════════════════
   CONTACTO — rediseño premium
══════════════════════════════════════════════════════ */
.contacto-section{
  position:relative;overflow:hidden;
  padding:120px 5vw 80px;
  background:radial-gradient(ellipse at 20% 50%,rgba(155,15,10,.18) 0%,transparent 55%),
             radial-gradient(ellipse at 80% 20%,rgba(226,35,26,.09) 0%,transparent 50%),
             var(--bg);
}
.ctc-bg-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.ctc-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.25}
.ctc-orb-1{width:500px;height:500px;background:radial-gradient(circle,#9b0f0a,transparent);top:-120px;left:-100px}
.ctc-orb-2{width:400px;height:400px;background:radial-gradient(circle,#e2231a,transparent);bottom:-100px;right:-80px;opacity:.12}
.ctc-grid{position:absolute;inset:0;width:100%;height:100%;opacity:.6}

.ctc-inner{position:relative;max-width:1200px;margin:0 auto}
.ctc-header{text-align:center;margin-bottom:70px}

.ctc-body{
  display:grid;
  grid-template-columns:1fr 1.25fr;
  gap:48px;
  align-items:start;
}

/* ── Panel izquierdo ── */
.ctc-brand-row{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.ctc-logo-wrap{position:relative;flex-shrink:0}
.ctc-logo-wrap img{width:60px;height:60px;object-fit:contain;border-radius:16px;border:1px solid rgba(226,35,26,.3);background:rgba(226,35,26,.08);padding:6px}
.ctc-logo-glow{position:absolute;inset:-4px;border-radius:20px;background:radial-gradient(circle,rgba(226,35,26,.35),transparent 70%);pointer-events:none;animation:ctcGlow 2.5s ease-in-out infinite}
@keyframes ctcGlow{0%,100%{opacity:.6}50%{opacity:1}}
.ctc-brand-name{font-family:var(--font-display);font-size:20px;letter-spacing:1px;margin:0}
.ctc-brand-loc{color:var(--text-muted);font-size:13px;margin:3px 0 0}
.ctc-tagline{color:var(--text-2);font-size:14px;line-height:1.7;margin-bottom:30px}

/* Canales */
.ctc-channels{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.ctc-channel{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border-radius:14px;
  background:rgba(20,11,11,.55);
  border:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  text-decoration:none;color:var(--text);
  transition:.3s cubic-bezier(.16,1,.3,1);
  position:relative;overflow:hidden;
}
.ctc-channel::before{content:"";position:absolute;inset:0;opacity:0;transition:.3s;border-radius:inherit}
.ctc-channel:hover{transform:translateX(6px)}
.ctc-channel:hover::before{opacity:1}

/* Color de acento por canal — borde + glow neon suave */
.ctc-wa{
  box-shadow:0 0 0 1px rgba(37,211,102,.18),0 0 18px rgba(37,211,102,.07),0 4px 22px rgba(0,0,0,.2);
}
.ctc-wa::before{background:linear-gradient(90deg,rgba(37,211,102,.08),transparent)}
.ctc-wa:hover{
  border-color:rgba(37,211,102,.35);
  box-shadow:0 0 0 1px rgba(37,211,102,.45),0 0 30px rgba(37,211,102,.18),0 8px 32px rgba(0,0,0,.25);
}
.ctc-ig{
  box-shadow:0 0 0 1px rgba(193,53,132,.18),0 0 18px rgba(193,53,132,.07),0 4px 22px rgba(0,0,0,.2);
}
.ctc-ig::before{background:linear-gradient(90deg,rgba(193,53,132,.08),transparent)}
.ctc-ig:hover{
  border-color:rgba(193,53,132,.35);
  box-shadow:0 0 0 1px rgba(193,53,132,.45),0 0 30px rgba(193,53,132,.18),0 8px 32px rgba(0,0,0,.25);
}
.ctc-email{
  box-shadow:0 0 0 1px rgba(226,35,26,.2),0 0 18px rgba(226,35,26,.08),0 4px 22px rgba(0,0,0,.2);
}
.ctc-email::before{background:linear-gradient(90deg,rgba(226,35,26,.08),transparent)}
.ctc-email:hover{
  border-color:rgba(226,35,26,.4);
  box-shadow:0 0 0 1px rgba(226,35,26,.5),0 0 30px rgba(226,35,26,.2),0 8px 32px rgba(0,0,0,.25);
}

.ctc-ch-icon{
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  flex-shrink:0;
}
.ctc-wa .ctc-ch-icon{color:#25d366}
.ctc-ig .ctc-ch-icon{color:#c13584}
.ctc-email .ctc-ch-icon{color:var(--red)}
.ctc-ch-body{flex:1}.ctc-ch-body b{display:block;font-size:14px;font-weight:700}.ctc-ch-body small{color:var(--text-muted);font-size:12px}
.ctc-ch-arrow{color:var(--text-muted);font-size:16px;transition:.2s}.ctc-channel:hover .ctc-ch-arrow{color:var(--text);transform:translate(2px,-2px)}

.ctc-horario{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-radius:10px;
  background:rgba(29,185,84,.07);border:1px solid rgba(29,185,84,.2);
  font-size:13px;color:var(--text-2);
}
.ctc-dot-live{width:8px;height:8px;border-radius:50%;background:#1db954;flex-shrink:0;animation:pulse 1.4s infinite}

/* ── Panel derecho: formulario ── */
.ctc-form-wrap{
  background:rgba(14,7,7,.65);
  border:1px solid rgba(226,35,26,.14);
  border-radius:24px;
  padding:36px;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 0 0 1px rgba(226,35,26,.1),0 0 40px rgba(226,35,26,.07),0 40px 80px rgba(0,0,0,.4);
  position:relative;overflow:hidden;
}
.ctc-form-wrap::before{
  content:"";position:absolute;top:-1px;left:15%;right:15%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(226,35,26,.7),transparent);
}
.ctc-form-header{margin-bottom:28px}
.ctc-form-title{font-family:var(--font-display);font-size:22px;letter-spacing:1px;margin:0 0 4px}
.ctc-form-sub{color:var(--text-muted);font-size:13px;margin:0}

.ctc-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ctc-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;position:relative}
.ctc-field label{font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);transition:.2s}
.ctc-field.focused label{color:var(--red)}
.ctc-field input,.ctc-field textarea,.ctc-field select{
  background:rgba(10,6,6,.55);border:1px solid var(--border);border-radius:10px;
  color:var(--text);font-family:var(--font-body);font-size:14px;
  padding:12px 14px;outline:none;transition:.2s;resize:none;
  -webkit-appearance:none;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.ctc-field input::placeholder,.ctc-field textarea::placeholder{color:var(--text-muted);opacity:.7}
.ctc-field input:focus,.ctc-field textarea:focus,.ctc-field select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(226,35,26,.12);background:rgba(14,7,7,.75)}
.ctc-field textarea{min-height:130px}
.ctc-select-wrap{position:relative}
.ctc-select-wrap select{width:100%;padding-right:36px;cursor:pointer}
.ctc-select-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}

.ctc-form-footer{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.form-feedback{width:100%;font-size:13px;border-radius:8px;padding:0;margin:0;min-height:0}
.form-feedback.ok{color:#1db954;display:flex;align-items:center;gap:6px}
.form-feedback.err{color:var(--red-glow)}
.ctc-ok-icon{display:inline-flex;width:18px;height:18px;border-radius:50%;background:rgba(29,185,84,.2);align-items:center;justify-content:center;font-size:11px;color:#1db954}

.ctc-submit{
  display:flex;align-items:center;gap:10px;
  background:var(--red);color:#fff;
  border:none;border-radius:12px;
  padding:14px 28px;
  font-family:var(--font-display);font-size:17px;letter-spacing:1px;
  cursor:pointer;transition:.25s cubic-bezier(.16,1,.3,1);
  position:relative;overflow:hidden;
}
.ctc-submit::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);pointer-events:none}
.ctc-submit:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(226,35,26,.4)}
.ctc-submit:active{transform:translateY(0)}
.ctc-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Footer social */
/* ══ FOOTER ════════════════════════════════════════════════ */
.site-footer{
  border-top:1px solid rgba(255,255,255,.07);
  padding:56px 5vw 0;
  background:var(--bg);
  position:relative;
}
.site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(226,35,26,.3) 30%,rgba(226,35,26,.3) 70%,transparent);
}
.footer-inner{max-width:1100px;margin:0 auto}

/* Grid 3 columnas */
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1.2fr;
  gap:48px;
  padding-bottom:48px;
}

/* Columna 1 — Marca */
.ft-col--brand{}
.ft-logo-wrap{
  width:52px;height:52px;
  border-radius:12px;
  background:rgba(226,35,26,.06);
  border:1px solid rgba(226,35,26,.15);
  display:grid;place-items:center;
  margin-bottom:16px;
  overflow:hidden;
}
.ft-logo{width:40px;height:40px;object-fit:contain;display:block}
.ft-brand-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:20px;letter-spacing:2px;
  color:rgba(255,255,255,.8);
  margin:0 0 8px;
}
.ft-tagline{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;line-height:1.7;
  color:rgba(255,255,255,.28);
  margin:0 0 20px;
  max-width:240px;
}
.ft-social-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.ft-soc-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:8px;
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.38);
  text-decoration:none;
  font-family:'Sometype Mono',monospace;
  font-size:10px;letter-spacing:1px;
  transition:border-color .2s,color .2s,background .2s;
}
.ft-soc-btn:hover{border-color:rgba(226,35,26,.4);color:rgba(226,35,26,.9);background:rgba(226,35,26,.05)}

/* Título de columna */
.ft-col-title{
  font-family:'Sometype Mono',monospace;
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(226,35,26,.6);
  margin:0 0 14px;
}

/* Lista de links */
.ft-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.ft-nav li a{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:13px;color:rgba(255,255,255,.38);
  text-decoration:none;
  transition:color .2s;
  display:inline-flex;align-items:center;gap:6px;
}
.ft-nav li a::before{
  content:'';width:0;height:1px;
  background:rgba(226,35,26,.6);
  transition:width .2s;
  flex-shrink:0;
}
.ft-nav li a:hover{color:rgba(255,255,255,.75)}
.ft-nav li a:hover::before{width:12px}
.ft-location{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;color:rgba(255,255,255,.22);
}

/* Barra inferior */
.ft-bottom{padding:20px 0 24px}
.ft-bottom-line{
  width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06) 20%,rgba(255,255,255,.06) 80%,transparent);
  margin-bottom:18px;
}
.ft-bottom-inner{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:8px;
}
.ft-copy{
  font-family:'Sometype Mono',monospace;
  font-size:10px;letter-spacing:.8px;
  color:rgba(255,255,255,.18);
  margin:0;
}
.ft-copy a{color:rgba(255,255,255,.25);text-decoration:none;border-bottom:1px solid rgba(226,35,26,.2);transition:.2s}
.ft-copy a:hover{color:rgba(226,35,26,.7);border-bottom-color:rgba(226,35,26,.5)}

/* Clases de footer viejo — ya no se usan */
.footer-row,.footer-divider,.footer-dot,.footer-legal,
.footer-author,.footer-brand,.footer-social,
.footer-name,.footer-loc{display:none!important}

/* Responsive footer */
@media(max-width:860px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .ft-col--brand{grid-column:1/-1}
  .ft-tagline{max-width:100%}
}
@media(max-width:540px){
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .ft-col--brand{grid-column:auto}
  .ft-bottom-inner{flex-direction:column;align-items:flex-start;gap:4px}
  .ft-copy--right{order:-1}
  .site-footer{padding:40px 5vw 0}
}

/* Responsive contacto */
@media(max-width:900px){
  .ctc-body{grid-template-columns:1fr}
  .ctc-form-wrap{padding:28px 22px}
}
@media(max-width:560px){
  .ctc-field-row{grid-template-columns:1fr}
  .ctc-form-footer{align-items:stretch}
  .ctc-submit{justify-content:center;width:100%}
  .contacto-section{padding:80px 5vw 60px}
}

/* ══════════════════════════════════════
   CLIMA STRIP — resultados section
══════════════════════════════════════ */
.clima-strip{
  position:relative;
  display:flex;align-items:center;
  background:linear-gradient(135deg,rgba(8,4,4,.92),rgba(16,9,9,.88));
  border:1px solid rgba(226,35,26,.14);
  border-radius:16px;
  overflow:hidden;
  margin-bottom:32px;
  min-height:62px;
  backdrop-filter:blur(16px);
}
.clima-strip::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:repeating-linear-gradient(
    0deg,transparent,transparent 3px,
    rgba(255,255,255,.009) 3px,rgba(255,255,255,.009) 4px
  );
}
.clima-strip::before{
  content:'';position:absolute;left:0;top:10%;bottom:10%;
  width:2px;border-radius:2px;z-index:2;
  background:linear-gradient(180deg,transparent,rgba(226,35,26,.7) 50%,transparent);
}
.cs-loc{
  display:flex;align-items:center;gap:12px;
  padding:14px 20px 14px 26px;
  border-right:1px solid rgba(255,255,255,.055);
  flex-shrink:0;position:relative;z-index:1;
}
.cs-ping{position:relative;width:10px;height:10px;flex-shrink:0}
.cs-ping::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px var(--green);
}
.cs-ping::after{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  background:transparent;border:1.5px solid rgba(29,185,84,.4);
  animation:csPingRipple 2.2s ease-out infinite;
}
@keyframes csPingRipple{
  0%{inset:-5px;opacity:.5}
  100%{inset:-14px;opacity:0}
}
.cs-city{
  font-family:var(--font-display);font-size:13px;
  letter-spacing:3px;color:rgba(255,255,255,.7);
  display:block;line-height:1;
}
.cs-coord{
  font-family:var(--font-mono);font-size:8px;
  letter-spacing:1.2px;color:rgba(255,255,255,.18);
  display:block;margin-top:4px;
}
.cs-center{
  flex:1;display:flex;align-items:center;
  min-width:0;overflow:hidden;position:relative;z-index:1;
}
.cs-temp-block{
  display:flex;align-items:center;gap:5px;
  padding:0 18px;flex-shrink:0;
  border-right:1px solid rgba(255,255,255,.055);
}
.cs-temp-val{
  font-family:var(--font-display);font-size:28px;
  letter-spacing:1px;color:rgba(255,255,255,.88);line-height:1;
}
.cs-temp-icon{font-size:18px;line-height:1}
.cs-ticker-wrap{
  flex:1;min-width:0;overflow:hidden;
  padding:0 18px;display:flex;align-items:center;
}
.cs-ticker-wrap > div{background:transparent!important;width:100%}
.cs-right{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 18px;border-left:1px solid rgba(255,255,255,.055);
  flex-shrink:0;position:relative;z-index:1;
}
.cs-live-badge{
  display:flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:8.5px;
  letter-spacing:2.5px;color:rgba(255,255,255,.28);
}
.cs-live-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px var(--green);
  animation:csDotPulse 2s ease-in-out infinite;
}
@keyframes csDotPulse{0%,100%{opacity:1}50%{opacity:.25}}
.cs-flag{font-size:16px;opacity:.55}
@media(max-width:600px){
  .cs-coord,.cs-right{display:none}
  .cs-loc{padding:12px 14px 12px 20px;gap:9px}
  .cs-temp-val{font-size:22px}
}

/* ══════════════════════════════════════
   WEATHER hero stat
══════════════════════════════════════ */
.weather-hero-stat b{
  display:flex;align-items:center;gap:6px;
  font-family:var(--font-display);
  font-size:clamp(28px,4vw,52px);
  color:#fff;line-height:1;
  text-shadow:0 0 30px rgba(226,35,26,.5),0 4px 16px rgba(0,0,0,.5);
}
.weather-icon-em{font-style:normal;font-size:.75em;line-height:1}

/* ── TBD badge — rival sin confirmar ── */
.tbd-badge{
  width:96px;height:96px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(226,35,26,.08);
  border:2px dashed rgba(226,35,26,.35);
  font-family:var(--font-display);font-size:42px;
  color:rgba(226,35,26,.5);
  animation:tbdPulse 2.4s ease-in-out infinite;
}
@keyframes tbdPulse{0%,100%{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1)}}

/* ══════════════════════════════════════
   JUGADOR page
══════════════════════════════════════ */
.jugador-page{background:var(--bg);min-height:100vh}
.jug-header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 5vw;
  background:var(--bg-nav);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.jug-back{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--text-muted);text-decoration:none;font-size:14px;
  font-family:var(--font-mono);letter-spacing:.5px;
  transition:color .2s;
}
.jug-back:hover{color:var(--text)}
.jug-brand{
  display:flex;align-items:center;gap:8px;text-decoration:none;
  color:#fff;font-family:var(--font-display);font-size:16px;letter-spacing:1px;
}
.jug-brand img{border-radius:6px}
.jug-main{max-width:1000px;margin:0 auto;padding:40px 20px 80px}
.jug-notfound{text-align:center;padding:80px 20px}
.jug-notfound .jug-nf-icon{font-size:72px;margin-bottom:24px}
.jug-notfound h1{font-family:var(--font-display);font-size:36px;letter-spacing:1px;margin-bottom:12px}
.jug-notfound p{color:var(--text-muted);margin-bottom:32px}

/* Hero */
.jug-hero{
  position:relative;overflow:hidden;
  border-radius:24px;margin-bottom:32px;
  background:var(--bg-card);border:1px solid var(--border);
}
.jug-hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 30% 50%,rgba(226,35,26,.18),transparent 60%);
}
.jug-hero-inner{
  position:relative;z-index:1;
  display:flex;align-items:flex-end;gap:40px;padding:40px;
}
.jug-photo-wrap{
  flex-shrink:0;width:180px;height:220px;
  border-radius:16px;overflow:hidden;
  background:rgba(226,35,26,.06);border:1px solid var(--border);
}
.jug-photo{width:100%;height:100%;object-fit:cover;object-position:top center}
.jug-photo-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--text-muted)}
.jug-hero-info{flex:1}
.jug-team-badge{
  font-family:var(--font-mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--red);margin-bottom:8px;
}
.jug-name{
  font-family:var(--font-display);
  font-size:clamp(32px,5vw,60px);
  letter-spacing:1px;line-height:1;margin:0 0 12px;
  text-shadow:0 4px 20px rgba(0,0,0,.4);
}
.jug-position-badge{
  display:inline-block;
  background:rgba(226,35,26,.15);border:1px solid rgba(226,35,26,.3);
  color:var(--red-glow);border-radius:20px;
  padding:4px 12px;font-size:12px;font-family:var(--font-mono);
  letter-spacing:.8px;text-transform:uppercase;margin-bottom:24px;
}
.jug-quick-stats{display:flex;gap:24px;flex-wrap:wrap}
.jug-qs{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.jug-qs b{font-family:var(--font-display);font-size:28px;color:#fff;line-height:1}
.jug-qs span{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.35)}

/* Content */
.jug-content{display:flex;flex-direction:column;gap:24px}
.jug-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.jug-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:20px;padding:28px;
}
.jug-card-title{font-family:var(--font-display);font-size:18px;letter-spacing:1px;margin:0 0 20px;color:var(--text)}
.jug-data-grid{display:flex;flex-direction:column;gap:0}
.jug-datum{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04);gap:16px;
}
.jug-datum:last-child{border-bottom:0}
.jug-datum span{font-size:13px;color:var(--text-muted)}
.jug-datum b{font-size:14px;color:var(--text);font-weight:600;text-align:right}
.jug-stat-row{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.jug-stat-row:last-child{border-bottom:0}
.jug-stat-league{font-size:12px;color:var(--red);font-family:var(--font-mono);letter-spacing:.5px;display:block;margin-bottom:10px}
.jug-stat-nums{display:flex;gap:20px;flex-wrap:wrap}
.jug-snum{display:flex;flex-direction:column;align-items:center;gap:2px}
.jug-snum b{font-family:var(--font-display);font-size:28px;color:#fff;line-height:1}
.jug-snum span{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.jug-bio-text{font-size:14px;line-height:1.8;color:var(--text-2)}
.jug-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.jug-gallery img{width:100%;border-radius:12px;object-fit:cover;aspect-ratio:16/9;border:1px solid var(--border)}
.jug-ext-links{display:flex;gap:12px;flex-wrap:wrap;padding-top:8px}

@media(max-width:640px){
  .jug-hero-inner{flex-direction:column;align-items:center;text-align:center;padding:28px 20px}
  .jug-quick-stats{justify-content:center}
  .jug-photo-wrap{width:140px;height:170px}
  .jug-qs{align-items:center}
}

/* ══════════════════════════════════════════════════
   DASHBOARD — Mi Panel
══════════════════════════════════════════════════ */
.db-wrap{
  max-width:1080px;margin:0 auto;
  padding:100px 5vw 80px;
  display:flex;flex-direction:column;gap:28px;
}

/* ── Hero card ───────────────────────────────────── */
.db-hero{
  position:relative;overflow:hidden;
  border-radius:24px;
  background:linear-gradient(145deg,rgba(30,10,10,.92),rgba(14,6,6,.95));
  border:1px solid rgba(226,35,26,.22);
  box-shadow:0 24px 80px rgba(0,0,0,.55),0 0 0 1px rgba(226,35,26,.1);
  padding:36px 40px 0;
}
.db-hero-stripes{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:repeating-linear-gradient(
    -55deg,
    transparent 0,transparent 28px,
    rgba(226,35,26,.025) 28px,rgba(226,35,26,.025) 30px
  );
}
.db-hero-glow{
  position:absolute;top:-40%;right:-10%;width:400px;height:400px;
  border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(226,35,26,.12) 0%,transparent 70%);
}
.db-identity{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:32px;
  margin-bottom:32px;
}

/* Avatar */
.db-avatar-wrap{
  display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;
}
.db-avatar{
  position:relative;width:110px;height:110px;border-radius:50%;
  background:linear-gradient(145deg,rgba(226,35,26,.2),rgba(60,10,10,.8));
  border:2px solid rgba(226,35,26,.4);
  box-shadow:0 0 0 4px rgba(226,35,26,.08),0 8px 32px rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
  transition:border-color .3s,box-shadow .3s;
}
.db-avatar:hover{border-color:rgba(226,35,26,.7);box-shadow:0 0 0 4px rgba(226,35,26,.15),0 0 30px rgba(226,35,26,.25)}
.db-av-img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.db-av-init{
  font-family:var(--font-display);font-size:40px;
  color:rgba(255,255,255,.75);letter-spacing:2px;
}
.db-av-overlay{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(0,0,0,.55);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  color:#fff;font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
  opacity:0;transition:opacity .25s;cursor:pointer;
}
.db-avatar:hover .db-av-overlay{opacity:1}
.db-av-input{display:none}
.db-av-status{
  font-family:var(--font-mono);font-size:9px;letter-spacing:1px;
  color:rgba(255,255,255,.3);min-height:14px;transition:color .3s;
}
.db-av-status.ok{color:var(--green)}
.db-av-status.err{color:var(--red)}
.db-av-status.uploading{color:rgba(255,255,255,.5)}

/* Bienvenida */
.db-welcome{flex:1;min-width:0}
.db-eyebrow{
  display:block;font-family:var(--font-mono);font-size:10px;
  letter-spacing:4px;color:rgba(226,35,26,.7);
  margin-bottom:4px;
}
.db-name{
  font-family:var(--font-display);
  font-size:clamp(28px,5vw,56px);
  letter-spacing:2px;line-height:1;
  color:#fff;
  text-shadow:0 0 60px rgba(226,35,26,.3),0 4px 20px rgba(0,0,0,.5);
  margin-bottom:12px;
}
.db-meta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.db-nivel{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:20px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(226,35,26,.35);
  color:var(--nivel-color, var(--red));
}
.db-since{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:1px;
  color:rgba(255,255,255,.28);
}

/* KPI Strip */
.db-kpi-strip{
  position:relative;z-index:1;
  display:flex;align-items:stretch;
  border-top:1px solid rgba(226,35,26,.1);
  background:rgba(0,0,0,.2);
  border-radius:0 0 24px 24px;
  margin:0 -40px;
}
.db-kpi{
  flex:1;display:flex;flex-direction:column;align-items:center;
  padding:18px 10px;gap:4px;
  position:relative;
}
.db-kpi-sep{width:1px;background:rgba(226,35,26,.1);align-self:stretch;margin:12px 0}
.db-kpi-val{
  font-family:var(--font-display);
  font-size:clamp(20px,3vw,30px);
  color:#fff;letter-spacing:1px;line-height:1;
}
.db-kpi span{
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:2px;color:rgba(255,255,255,.3);
  text-transform:uppercase;
}

/* ── Mid grid ─────────────────────────────────────── */
.db-mid-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* Panel genérico */
.db-panel{
  border-radius:20px;
  background:var(--bg-card);
  border:1px solid var(--border);
  padding:28px;
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow-card);
}
.db-panel-eye{
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:3px;color:rgba(226,35,26,.6);
  text-transform:uppercase;margin-bottom:4px;
}
.db-panel-title{
  font-family:var(--font-display);font-size:20px;
  letter-spacing:2px;color:var(--text);
  margin-bottom:20px;
}

/* Próximo partido */
.db-match-comp{
  display:inline-block;
  font-family:var(--font-mono);font-size:9px;letter-spacing:2px;
  padding:3px 10px;border-radius:20px;
  background:rgba(226,35,26,.1);border:1px solid rgba(226,35,26,.2);
  color:rgba(226,35,26,.8);margin-bottom:16px;
}
.db-match-teams{
  display:flex;align-items:center;gap:14px;
  margin-bottom:16px;
}
.db-mt{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;flex:1;font-family:var(--font-display);
  font-size:15px;letter-spacing:1px;color:var(--text);
}
.db-mt img{border-radius:8px;object-fit:contain}
.db-mt-vs{
  font-family:var(--font-display);font-size:22px;
  color:rgba(226,35,26,.6);letter-spacing:3px;flex-shrink:0;
}
.db-match-info{
  display:flex;flex-direction:column;gap:5px;
  margin-bottom:20px;
}
.db-match-info span{
  font-size:12px;color:var(--text-muted);
  display:flex;align-items:center;gap:6px;
}
.db-match-btn{width:100%;justify-content:center;font-size:13px}

/* Acciones rápidas */
.db-action-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.db-action{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:14px 8px;border-radius:14px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.055);
  color:var(--text-muted);font-size:11px;
  text-decoration:none;cursor:pointer;
  transition:background .25s,border-color .25s,color .25s,transform .2s;
  font-family:var(--font-mono);letter-spacing:.5px;
}
.db-action:hover{
  background:rgba(226,35,26,.08);
  border-color:rgba(226,35,26,.28);
  color:var(--text);transform:translateY(-2px);
}
.db-ac-icon{font-size:20px;line-height:1}
.db-ac-logout{border-color:rgba(226,35,26,.15)}
.db-ac-logout:hover{background:rgba(226,35,26,.12);border-color:rgba(226,35,26,.4);color:var(--red)}

/* ── Mis viajes ───────────────────────────────────── */
.db-viajes{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:20px;padding:28px;
  backdrop-filter:blur(12px);box-shadow:var(--shadow-card);
}
.db-section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.db-section-title{
  font-family:var(--font-display);font-size:24px;
  letter-spacing:3px;color:var(--text);
}
.db-badge-count{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;
  padding:4px 12px;border-radius:20px;
  background:rgba(226,35,26,.1);border:1px solid rgba(226,35,26,.2);
  color:rgba(226,35,26,.8);
}

/* Empty state */
.db-empty{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:40px 20px;text-align:center;
}
.db-empty-icon{opacity:.45;margin-bottom:4px}
.db-empty-title{font-family:var(--font-display);font-size:20px;letter-spacing:1px;color:var(--text-muted)}
.db-empty-sub{font-size:13px;color:rgba(255,255,255,.25);max-width:320px}

/* Boarding passes */
.db-passes{display:flex;flex-direction:column;gap:14px}
.db-pass{
  display:grid;grid-template-columns:1fr auto 220px;
  border-radius:14px;overflow:hidden;
  background:linear-gradient(135deg,rgba(20,10,10,.85),rgba(12,6,6,.9));
  border:1px solid rgba(226,35,26,.14);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
  transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s;
}
.db-pass:hover{
  transform:translateY(-3px);
  border-color:rgba(226,35,26,.35);
  box-shadow:0 12px 40px rgba(0,0,0,.45),0 0 0 1px rgba(226,35,26,.12);
}
.db-pass.s-ok   { border-left:3px solid var(--green) }
.db-pass.s-pend { border-left:3px solid var(--amber) }
.db-pass.s-cancel{ border-left:3px solid rgba(226,35,26,.4); opacity:.7 }

/* Pass left */
.db-pass-left{
  padding:22px 24px;
  display:flex;flex-direction:column;justify-content:center;gap:10px;
}
.db-pass-route{
  display:flex;align-items:center;gap:12px;
}
.db-pass-city{display:flex;flex-direction:column}
.db-pass-city-r{align-items:flex-end}
.db-pass-iata{
  font-family:var(--font-display);font-size:26px;
  letter-spacing:2px;color:#fff;line-height:1;
}
.db-pass-full{
  font-family:var(--font-mono);font-size:8px;
  letter-spacing:1.5px;color:rgba(255,255,255,.25);
  text-transform:uppercase;
}
.db-pass-rival{
  font-family:var(--font-accent);font-size:14px;
  color:var(--text-muted);letter-spacing:.5px;
}
.db-pass-rival strong{color:var(--text)}

/* Perforación */
.db-pass-perf{
  width:24px;position:relative;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;
}
.db-pass-perf::before,.db-pass-perf::after{
  content:'';position:absolute;
  width:16px;height:16px;border-radius:50%;
  background:var(--bg);
  left:50%;transform:translateX(-50%);
  box-shadow:inset 0 0 0 1px rgba(226,35,26,.1);
}
.db-pass-perf::before{top:-8px}
.db-pass-perf::after{bottom:-8px}
.db-pass-perf .db-pass-scissors{
  font-size:11px;color:rgba(226,35,26,.2);
  writing-mode:vertical-rl;
  border-left:1px dashed rgba(226,35,26,.15);
  padding:8px 0;height:60%;
  display:flex;align-items:center;justify-content:center;
}

/* Pass right */
.db-pass-right{
  background:rgba(226,35,26,.04);
  border-left:1px dashed rgba(226,35,26,.12);
  padding:18px 20px;
  display:flex;flex-direction:column;justify-content:space-between;gap:12px;
}
.db-pass-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.db-pass-code{
  font-family:var(--font-mono);font-size:13px;
  letter-spacing:2px;color:rgba(255,255,255,.5);
}
.db-estado-chip{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
}
.db-estado-chip.s-ok{background:rgba(29,185,84,.1);border:1px solid rgba(29,185,84,.3);color:var(--green)}
.db-estado-chip.s-pend{background:rgba(240,160,32,.1);border:1px solid rgba(240,160,32,.3);color:var(--amber)}
.db-estado-chip.s-cancel{background:rgba(226,35,26,.08);border:1px solid rgba(226,35,26,.2);color:rgba(226,35,26,.6)}

.db-pass-details{display:flex;gap:16px;flex-wrap:wrap}
.db-pd{display:flex;flex-direction:column;gap:2px}
.db-pd-label{font-family:var(--font-mono);font-size:7.5px;letter-spacing:2px;color:rgba(255,255,255,.2);text-transform:uppercase}
.db-pd-val{font-family:var(--font-mono);font-size:12px;color:rgba(255,255,255,.65)}
.db-pass-price{color:#fff;font-size:14px!important;font-weight:700}

/* ── db-pass-v2: boarding pass rediseñado ─────────────────── */
.db-pass.db-pass-v2{display:flex;flex-direction:column}

/* Header */
.db-pass-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;
  border-bottom:1px dashed rgba(226,35,26,.14);
}
.db-pass-torneo{
  font-family:var(--font-mono);font-size:8px;letter-spacing:2.5px;
  color:rgba(255,255,255,.28);text-transform:uppercase;
}
.db-pass-hright{display:flex;align-items:center;gap:10px}

/* Match section */
.db-pass-match{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;gap:8px;
}
.db-pass-team{
  display:flex;flex-direction:column;align-items:center;
  gap:7px;flex:0 0 auto;
}
.db-pass-badge{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.db-pass-badge-river{
  background:rgba(226,35,26,.12);border:1px solid rgba(226,35,26,.25);
}
.db-pass-badge-rival{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  font-family:var(--font-display);font-size:15px;color:rgba(255,255,255,.45);
}
.db-pass-tname{
  font-family:var(--font-mono);font-size:8px;letter-spacing:2px;
  color:rgba(255,255,255,.42);text-transform:uppercase;text-align:center;max-width:80px;
}
.db-pass-vs-block{
  display:flex;flex-direction:column;align-items:center;
  gap:2px;flex:1;text-align:center;
}
.db-pass-vs-txt{
  font-family:var(--font-display);font-size:24px;
  color:var(--red);text-shadow:0 0 16px rgba(226,35,26,.45);line-height:1;
}
.db-pass-fecha-p{
  font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
  color:rgba(255,255,255,.48);text-transform:uppercase;
}
.db-pass-hora-p{
  font-family:var(--font-display);font-size:20px;
  color:var(--red-glow);line-height:1.1;
}
.db-pass-estadio-txt{
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:.8px;
  color:rgba(255,255,255,.22);
}

/* Perforación horizontal (override de la versión vertical legacy) */
.db-pass.db-pass-v2 .db-pass-perf{
  display:flex;align-items:center;padding:0 10px;
  margin:0;width:auto;position:static;
}
.db-pass.db-pass-v2 .db-pass-perf::before,
.db-pass.db-pass-v2 .db-pass-perf::after{display:none}
.db-pass-perf-line{flex:1;border-top:1px dashed rgba(226,35,26,.18)}
.db-pass.db-pass-v2 .db-pass-perf .db-pass-scissors{
  font-size:12px;color:rgba(226,35,26,.3);
  writing-mode:initial;border:none;padding:0 8px;
  height:auto;display:block;
}

/* Travel/route section */
.db-pass-travel{padding:14px 18px;display:flex;flex-direction:column;gap:9px}
.db-pass.db-pass-v2 .db-pass-route{display:flex;align-items:center;gap:10px}
.db-pass-arrow-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.db-pass-bus-icon{font-size:13px}
.db-pass-time-dep{
  font-family:var(--font-display);font-size:16px;
  color:var(--amber);line-height:1;margin-top:2px;
}
.db-pass-pto-salida{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:.8px;
  color:rgba(255,255,255,.28);margin:0;
}
.db-pass-incluye{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.db-pass-chip{
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:1px;
  padding:3px 9px;border-radius:20px;
  border:1px solid rgba(29,185,84,.3);
  color:rgba(29,185,84,.7);background:rgba(29,185,84,.06);
}

/* Footer */
.db-pass-foot{
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:12px 18px;
  border-top:1px dashed rgba(226,35,26,.12);
  gap:12px;
}
.db-pass-foot-left{display:flex;flex-direction:column;gap:1px}
.db-pass-foot-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.db-pass.db-pass-v2 .db-pass-price{
  font-family:var(--font-display);font-size:22px;color:#fff;line-height:1;
}

/* Actions row */
.db-pass-actions{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px 16px;
  border-top:1px solid rgba(255,255,255,.04);
}

/* ── Botón COMPLETAR PAGO ── */
.db-pass-btn-pay{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:12px;
  background:linear-gradient(135deg,#b01010 0%,#e2231a 45%,#b01010 100%);
  background-size:200% 100%;
  border:1px solid rgba(226,35,26,.55);
  color:#fff;cursor:pointer;
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;font-weight:700;
  box-shadow:0 4px 18px rgba(226,35,26,.35),inset 0 1px 0 rgba(255,255,255,.12);
  transition:background-position .4s ease,transform .2s ease,
             box-shadow .2s ease,border-color .2s ease;
}
/* shimmer sweep */
.db-pass-btn-pay::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.18) 50%,transparent 65%);
  transform:translateX(-100%);
  transition:transform .55s ease;
}
.db-pass-btn-pay:hover:not(:disabled)::before{transform:translateX(100%)}
.db-pass-btn-pay:hover:not(:disabled){
  background-position:right center;
  transform:translateY(-2px);
  border-color:rgba(226,35,26,.85);
  box-shadow:0 8px 32px rgba(226,35,26,.55),
             0 0 0 1px rgba(226,35,26,.3),
             inset 0 1px 0 rgba(255,255,255,.18);
}
.db-pass-btn-pay:active:not(:disabled){
  transform:translateY(0) scale(.97);
  box-shadow:0 0 0 3px rgba(226,35,26,.25),
             0 0 24px rgba(226,35,26,.65),
             0 0 48px rgba(226,35,26,.25);
}
.db-pass-btn-pay.neon-flash{
  animation:pass-neon-burst .65s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes pass-neon-burst{
  0%  {box-shadow:0 4px 18px rgba(226,35,26,.35)}
  25% {box-shadow:0 0 0 4px rgba(226,35,26,.35),0 0 32px rgba(226,35,26,.75),0 0 64px rgba(226,35,26,.35)}
  70% {box-shadow:0 0 0 1px rgba(226,35,26,.2),0 0 18px rgba(226,35,26,.5),0 0 36px rgba(226,35,26,.2)}
  100%{box-shadow:0 8px 32px rgba(226,35,26,.45)}
}
.db-pass-btn-pay:disabled{opacity:.5;cursor:wait;transform:none}
.db-pass-btn-pay:disabled::before{display:none}

/* ── Botón CANCELAR ── */
.db-pass-btn-cancel{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 15px;border-radius:10px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.28);cursor:pointer;
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:1.5px;
  margin-left:auto;
  transition:border-color .25s,color .25s,background .25s,box-shadow .25s,transform .15s;
}
.db-pass-btn-cancel:hover:not(:disabled){
  border-color:rgba(226,35,26,.3);
  color:rgba(226,35,26,.6);
  background:rgba(226,35,26,.05);
  box-shadow:0 0 12px rgba(226,35,26,.12);
}
.db-pass-btn-cancel:active:not(:disabled){
  transform:scale(.95);
  box-shadow:0 0 18px rgba(226,35,26,.2);
}
.db-pass-btn-cancel:disabled{opacity:.35;cursor:wait}

/* ── Modal editar perfil ────────────────────────── */
.db-modal-bg{
  position:fixed;inset:0;z-index:800;
  background:rgba(4,2,2,.82);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;
  transition:opacity .3s cubic-bezier(.16,1,.3,1);
}
.db-modal-bg.open{opacity:1;pointer-events:auto}
.db-modal{
  position:relative;
  width:100%;max-width:440px;
  background:linear-gradient(160deg,rgba(26,14,14,.98),rgba(10,6,6,.98));
  border:1px solid rgba(226,35,26,.25);
  border-radius:20px;
  padding:36px 32px;
  box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 1px rgba(226,35,26,.08);
  transform:translateY(20px);
  transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.db-modal-bg.open .db-modal{transform:translateY(0)}
.db-modal-close{
  position:absolute;top:16px;right:16px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.4);border-radius:8px;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s,color .2s;
}
.db-modal-close:hover{background:rgba(226,35,26,.15);color:#fff;border-color:rgba(226,35,26,.3)}
.db-modal-icon{font-size:28px;margin-bottom:8px;text-align:center}
.db-modal-title{
  font-family:var(--font-display);font-size:22px;
  letter-spacing:2px;text-align:center;
  margin-bottom:24px;color:var(--text);
}

/* Responsive */
@media(max-width:768px){
  .db-wrap{padding:88px 4vw 60px;gap:20px}
  .db-hero{padding:28px 24px 0}
  .db-identity{gap:20px}
  .db-avatar{width:88px;height:88px}
  .db-av-init{font-size:32px}
  .db-kpi-strip{margin:0 -24px}
  .db-kpi{padding:14px 6px}
  .db-mid-grid{grid-template-columns:1fr}
  .db-pass{grid-template-columns:1fr auto 180px}
  .db-pass-iata{font-size:20px}
  .db-action-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:540px){
  .db-hero{padding:24px 18px 0}
  .db-identity{flex-direction:column;align-items:center;text-align:center}
  .db-meta-row{justify-content:center}
  .db-kpi-strip{margin:0 -18px;flex-wrap:wrap}
  .db-kpi{min-width:50%}
  .db-kpi-sep{display:none}
  .db-pass{grid-template-columns:1fr}
  .db-pass-perf,.db-pass-right{display:none}
  .db-pass-left{padding:16px 18px}
  .db-pass.s-ok,.db-pass.s-pend,.db-pass.s-cancel{border-left-width:3px}
  /* Mostrar estado en mobile directamente */
  .db-pass-left::after{
    content:attr(data-estado);
    font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
    color:rgba(255,255,255,.4);
  }
  .db-action-grid{grid-template-columns:repeat(2,1fr)}
}

/* form-feedback.ok para el modal perfil */
.form-feedback.ok{color:var(--green);font-size:13px;padding:8px 0}

/* ── Clima navbar — fix tema claro ─────── */
[data-theme="light"] .nav-weather{
  background:rgba(226,35,26,.06);
  border-color:rgba(226,35,26,.22);
}
[data-theme="light"] .nav-weather:hover{
  background:rgba(226,35,26,.12);
  border-color:rgba(226,35,26,.45);
}
[data-theme="light"] .nw-temp{color:var(--text)}
[data-theme="light"] .nw-city{color:var(--text-muted)}

/* ── Footer: íconos sociales con neon ─────── */
.ft-icon{
  background:var(--ft-icon-bg);
  border:1px solid var(--ft-icon-border);
  color:var(--ft-icon-color);
  border-radius:14px;
  transition:
    border-color .28s cubic-bezier(.34,1.56,.64,1),
    color        .28s cubic-bezier(.34,1.56,.64,1),
    background   .28s cubic-bezier(.34,1.56,.64,1),
    box-shadow   .28s cubic-bezier(.34,1.56,.64,1),
    transform    .28s cubic-bezier(.34,1.56,.64,1);
  will-change:transform,box-shadow;
}
.ft-icon:hover{transform:translateY(-4px) scale(1.08)}

/* WhatsApp — neon verde */
.ft-icon-wa:hover{
  border-color:rgba(37,211,102,.75);
  color:#25d366;
  background:rgba(37,211,102,.1);
  box-shadow:
    0 0 0 1px rgba(37,211,102,.35),
    0 0 10px rgba(37,211,102,.55),
    0 0 24px rgba(37,211,102,.22),
    inset 0 0 10px rgba(37,211,102,.1);
}
/* Instagram — neon fucsia */
.ft-icon-ig:hover{
  border-color:rgba(225,48,108,.75);
  color:#e1306c;
  background:rgba(225,48,108,.1);
  box-shadow:
    0 0 0 1px rgba(225,48,108,.35),
    0 0 10px rgba(225,48,108,.55),
    0 0 24px rgba(225,48,108,.22),
    inset 0 0 10px rgba(225,48,108,.1);
}
/* YouTube — neon rojo */
.ft-icon-yt:hover{
  border-color:rgba(255,0,0,.75);
  color:#ff0000;
  background:rgba(255,0,0,.1);
  box-shadow:
    0 0 0 1px rgba(255,0,0,.35),
    0 0 10px rgba(255,0,0,.6),
    0 0 26px rgba(255,0,0,.22),
    inset 0 0 10px rgba(255,0,0,.1);
}
/* TikTok — neon cian */
.ft-icon-tt:hover{
  border-color:rgba(105,201,208,.75);
  color:#69c9d0;
  background:rgba(105,201,208,.1);
  box-shadow:
    0 0 0 1px rgba(105,201,208,.35),
    0 0 10px rgba(105,201,208,.55),
    0 0 24px rgba(105,201,208,.22),
    inset 0 0 10px rgba(105,201,208,.1);
}
.ft-nav-link{color:var(--ft-link);text-decoration:none;transition:color .2s}
.ft-nav-link:hover{color:var(--ft-link-hover)}
.ft-contact-link{color:var(--ft-copy);text-decoration:none;transition:color .2s}
.ft-contact-link:hover{color:var(--ft-link)}

/* ── Carousel mobile ─────────────────────────────────────────── */
@media(max-width:600px){
  .proximo-carousel{max-width:100%}
  .proximo-slide .team-logo-wrap{width:72px;height:72px;border-radius:14px}
  .proximo-slide .vs-row{gap:16px;margin:20px 0}
  .proximo-slide .vs{font-size:36px}
  .proximo-slide .team-box span{font-size:12px}
  .proximo-slide .countdown{gap:6px;margin:20px 0 14px}
  .proximo-slide .cd-box{padding:10px 8px;min-width:56px}
  .proximo-slide .cd-box b{font-size:28px}
  .proximo-arrow{width:32px;height:32px;font-size:18px}
  .proximo-prev{left:6px}
  .proximo-next{right:6px}
}

/* ============================================================
   LIQUID GLASS DESIGN SYSTEM — iOS 26 inspired
   Frosted glass with specular highlights, depth and blur
   ============================================================ */

:root {
  --glass-bg:        rgba(255,255,255,.065);
  --glass-bg-2:      rgba(255,255,255,.03);
  --glass-border:    rgba(255,255,255,.13);
  --glass-highlight: rgba(255,255,255,.22);
  --glass-shadow:    rgba(0,0,0,.5);
  --glass-blur:      blur(18px) saturate(180%) brightness(1.03);
  --glass-inset:     inset 0 1.5px 0 rgba(255,255,255,.20), inset 0 -1px 0 rgba(0,0,0,.12);
}
[data-theme="light"] {
  --glass-bg:        rgba(255,255,255,.62);
  --glass-bg-2:      rgba(255,255,255,.42);
  --glass-border:    rgba(0,0,0,.09);
  --glass-highlight: rgba(255,255,255,.92);
  --glass-shadow:    rgba(0,0,0,.10);
  --glass-inset:     inset 0 1.5px 0 rgba(255,255,255,.88), inset 0 -1px 0 rgba(0,0,0,.04);
}

/* ── Liquid Glass: result cards ────────────────────────────── */
.result-card {
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  background: linear-gradient(145deg, var(--glass-bg) 0%, var(--glass-bg-2) 100%);
  border-color: var(--glass-border);
  box-shadow:
    0 8px 32px var(--glass-shadow),
    0 2px 8px rgba(0,0,0,.25),
    var(--glass-inset);
}
.result-card::after {
  content:'';
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 45%);
}
.result-card:hover {
  box-shadow:
    0 24px 64px var(--glass-shadow),
    0 0 0 1px rgba(226,35,26,.28),
    var(--glass-inset),
    0 0 28px rgba(226,35,26,.10);
}

/* ── Liquid Glass: match-card (big upcoming) ───────────────── */
.match-card {
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  background: linear-gradient(145deg, var(--glass-bg) 0%, var(--glass-bg-2) 100%) !important;
  border-color: var(--glass-border);
  box-shadow:
    0 30px 80px var(--glass-shadow),
    0 4px 16px rgba(0,0,0,.3),
    var(--glass-inset) !important;
}

/* ── Liquid Glass: small prox-up cards ─────────────────────── */
.prox-up-card {
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  background: linear-gradient(145deg, var(--glass-bg), var(--glass-bg-2)) !important;
  border-color: var(--glass-border) !important;
  box-shadow:
    0 4px 20px var(--glass-shadow),
    var(--glass-inset);
}
.prox-up-card:hover {
  border-color: rgba(226,35,26,.35) !important;
  box-shadow:
    0 12px 40px var(--glass-shadow),
    0 0 0 1px rgba(226,35,26,.22),
    var(--glass-inset);
}

/* ── Liquid Glass: countdown boxes ─────────────────────────── */
.cd-box {
  backdrop-filter: blur(12px) saturate(160%);
  -webkit-backdrop-filter: blur(12px) saturate(160%);
  background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.03)) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: var(--glass-inset), 0 4px 16px rgba(0,0,0,.35);
}

/* ── Liquid Glass: navigation scrolled ─────────────────────── */
nav.scrolled {
  backdrop-filter: blur(28px) saturate(200%) brightness(.88);
  -webkit-backdrop-filter: blur(28px) saturate(200%) brightness(.88);
  background: rgba(8,4,4,.62) !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.05), 0 4px 24px rgba(0,0,0,.45) !important;
}

/* ── Liquid Glass: stat cards (hero stats) ─────────────────── */
.stat {
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  background: linear-gradient(145deg, var(--glass-bg), var(--glass-bg-2)) !important;
  border: 1px solid var(--glass-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.3), var(--glass-inset) !important;
}

/* ── Liquid Glass: testi cards ─────────────────────────────── */
.testi-card {
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  background: linear-gradient(145deg, var(--glass-bg), var(--glass-bg-2)) !important;
  border-color: var(--glass-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.3), var(--glass-inset) !important;
}

/* ── Liquid Glass: contact channels ────────────────────────── */
.ctc-channel {
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  background: linear-gradient(135deg, var(--glass-bg), var(--glass-bg-2)) !important;
  border-color: var(--glass-border) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.22), var(--glass-inset) !important;
}
.ctc-channel:hover {
  box-shadow: 0 8px 28px rgba(0,0,0,.32), var(--glass-inset) !important;
}

/* ── Liquid Glass: YouTube channel color ───────────────────── */
.ctc-yt {
  background: linear-gradient(135deg, rgba(255,50,50,.07), rgba(255,50,50,.02)) !important;
  border-color: rgba(255,50,50,.18) !important;
  color: #ff4444 !important;
}
.ctc-yt:hover {
  background: linear-gradient(135deg, rgba(255,50,50,.14), rgba(255,50,50,.06)) !important;
  border-color: rgba(255,50,50,.45) !important;
  box-shadow: 0 0 24px rgba(255,50,50,.18), var(--glass-inset) !important;
}

/* ── Liquid Glass: TikTok channel color ────────────────────── */
.ctc-tt {
  background: linear-gradient(135deg, rgba(105,201,208,.07), rgba(105,201,208,.02)) !important;
  border-color: rgba(105,201,208,.18) !important;
  color: #69c9d0 !important;
}
.ctc-tt:hover {
  background: linear-gradient(135deg, rgba(105,201,208,.14), rgba(105,201,208,.06)) !important;
  border-color: rgba(105,201,208,.45) !important;
  box-shadow: 0 0 24px rgba(105,201,208,.18), var(--glass-inset) !important;
}

/* ── Liquid Glass: pills (score badges) ────────────────────── */
.pill {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* ── Liquid Glass: video cover label ───────────────────────── */
.yt-label-glass {
  backdrop-filter: blur(10px) saturate(160%);
  -webkit-backdrop-filter: blur(10px) saturate(160%);
  background: rgba(0,0,0,.55) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: var(--glass-inset);
}

/* ── Liquid Glass: modal overlay ───────────────────────────── */
#omVideoModal {
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
}

/* ── Specular shimmer on match-card (subtle light streak) ──── */
.match-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.28) 30%,
    rgba(255,255,255,.42) 50%,
    rgba(255,255,255,.28) 70%,
    transparent 100%);
  border-radius: 24px 24px 0 0;
  pointer-events: none;
}

/* ── Contact channel: icon base glass ──────────────────────── */
.ctc-ch-icon {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* ── Footer glass strip ─────────────────────────────────────── */
footer {
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
}

/* ── Nav glass always-on (not just scrolled) ────────────────── */
nav {
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  transition: backdrop-filter .4s ease, background .4s ease, box-shadow .4s ease;
}
nav.scrolled {
  backdrop-filter: blur(28px) saturate(200%) brightness(.88) !important;
  -webkit-backdrop-filter: blur(28px) saturate(200%) brightness(.88) !important;
}

/* ══════════════════════════════════════════════════════════════
   SPONSORS OFICIALES (Betano + Hostinger)
══════════════════════════════════════════════════════════════ */

.sp-betano-wrap {
  position: relative;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.07);
  border-top: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  margin-bottom: 12px;
}
.sp-betano-label {
  position: absolute;
  top: 10px;
  left: 14px;
  z-index: 2;
  font-family: 'Sometype Mono', monospace;
  font-size: 7.5px;
  letter-spacing: 3px;
  color: rgba(255,255,255,.35);
  text-transform: uppercase;
  background: rgba(0,0,0,.5);
  padding: 3px 10px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.08);
}
.sp-betano-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  max-height: 120px;
  object-position: center;
  opacity: .9;
  transition: opacity .3s;
}
.sp-betano-wrap:hover .sp-betano-img { opacity: 1; }

.sp-host-wrap {
  display: block;
  text-decoration: none;
  border-radius: 14px;
  border: 1px solid rgba(255,180,40,.18);
  border-top: 1px solid rgba(255,210,100,.22);
  background: linear-gradient(135deg, rgba(255,160,0,.07) 0%, rgba(30,12,0,.6) 100%);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  box-shadow: 0 4px 20px rgba(255,140,0,.08), inset 0 1px 0 rgba(255,200,60,.1);
  transition: box-shadow .3s, border-color .3s, transform .25s;
  overflow: hidden;
}
.sp-host-wrap:hover {
  border-color: rgba(255,180,40,.38);
  box-shadow: 0 8px 32px rgba(255,140,0,.16), inset 0 1px 0 rgba(255,200,60,.15);
  transform: translateY(-2px);
}
.sp-host-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 16px 22px;
  flex-wrap: wrap;
}
.sp-host-img {
  height: 40px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
  filter: brightness(1.05);
}
.sp-host-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 120px;
}
.sp-host-label {
  font-family: 'Sometype Mono', monospace;
  font-size: 8px;
  letter-spacing: 3px;
  color: rgba(255,180,40,.65);
  text-transform: uppercase;
}
.sp-host-sub {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 15px;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,.65);
}
.sp-host-cta {
  font-family: 'Sometype Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: rgba(255,180,40,.85);
  padding: 7px 14px;
  border-radius: 8px;
  border: 1px solid rgba(255,180,40,.25);
  background: rgba(255,140,0,.08);
  white-space: nowrap;
  transition: background .2s, border-color .2s;
  flex-shrink: 0;
}
.sp-host-wrap:hover .sp-host-cta {
  background: rgba(255,140,0,.16);
  border-color: rgba(255,180,40,.45);
}

[data-theme="light"] .sp-betano-wrap {
  background: rgba(255,255,255,.6);
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 6px 24px rgba(0,0,0,.08);
}
[data-theme="light"] .sp-betano-label {
  background: rgba(255,255,255,.75);
  color: rgba(0,0,0,.4);
  border-color: rgba(0,0,0,.08);
}
[data-theme="light"] .sp-host-wrap {
  background: linear-gradient(135deg, rgba(255,180,0,.06) 0%, rgba(255,255,255,.8) 100%);
  border-color: rgba(200,140,0,.22);
  box-shadow: 0 4px 18px rgba(255,140,0,.07);
}
[data-theme="light"] .sp-host-sub { color: rgba(30,15,0,.7); }
[data-theme="light"] .sp-host-cta {
  color: rgba(160,90,0,.85);
  border-color: rgba(180,100,0,.22);
  background: rgba(255,140,0,.06);
}
