/* ============================================================
   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);
}

[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);
}
*{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:201}
.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 */
.burger{
  display:flex;flex-direction:column;gap:6px;
  cursor:pointer;background:none;border:0;
  padding:8px;z-index:201;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 — split-panel cinematic
══════════════════════════════════════ */
#navMenu{
  position:fixed;inset:0;z-index:199;
  display:flex;
  clip-path:polygon(0 0,100% 0,100% 0,0 0);
  visibility:hidden;
  pointer-events:none;
  transition:clip-path .8s cubic-bezier(.16,1,.3,1),visibility 0s .8s;
}
#navMenu.is-open{
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  visibility:visible;
  pointer-events:auto;
  transition:clip-path .8s cubic-bezier(.16,1,.3,1),visibility 0s 0s;
}

/* grain sobre todo el panel */
#navMenu::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:3;
  opacity:.035;
  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");
}

/* ── Layout dos columnas ── */
.nm-inner{
  display:grid;
  grid-template-columns:55fr 45fr;
  width:100%;height:100%;
  position:relative;z-index:1;
}

/* ── Columna izquierda ── */
.nm-left{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:clamp(80px,10vh,120px) clamp(40px,6vw,84px) 48px;
  background:#070303;
  border-right:1px solid rgba(226,35,26,.1);
}

.nm-eyebrow{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:4px;text-transform:uppercase;
  color:rgba(226,35,26,.5);margin:0 0 44px;
}

/* ítems de menú */
.nm-nav{display:flex;flex-direction:column}

.nm-item{
  display:flex;align-items:baseline;gap:20px;
  text-decoration:none;
  padding:clamp(10px,1.6vh,18px) 0;
  border-bottom:1px solid rgba(255,255,255,.055);
  position:relative;overflow:hidden;
}
.nm-item:first-child{border-top:1px solid rgba(255,255,255,.055)}

/* línea roja que crece en hover */
.nm-item::after{
  content:'';position:absolute;bottom:-1px;left:0;
  height:1px;width:0;background:var(--red);
  transition:width .5s cubic-bezier(.16,1,.3,1);
}
.nm-item:hover::after{width:100%}

.nm-num{
  font-family:var(--font-mono);
  font-size:clamp(10px,.9vw,12px);letter-spacing:1px;
  color:rgba(226,35,26,.38);
  flex-shrink:0;width:22px;padding-top:6px;
  transition:color .3s;
}
.nm-item:hover .nm-num{color:var(--red)}

.nm-label-wrap{overflow:hidden;display:block}
.nm-label{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(48px,7.5vw,100px);
  letter-spacing:1px;text-transform:uppercase;
  color:rgba(245,240,236,.8);
  line-height:.95;
  transform:translateY(115%);
  transition:transform .72s cubic-bezier(.16,1,.3,1),color .3s;
}
.nm-item:hover .nm-label{color:#fff}

/* reveal escalonado al abrir */
#navMenu.is-open .nm-item:nth-child(1) .nm-label{transform:translateY(0);transition-delay:.16s}
#navMenu.is-open .nm-item:nth-child(2) .nm-label{transform:translateY(0);transition-delay:.24s}
#navMenu.is-open .nm-item:nth-child(3) .nm-label{transform:translateY(0);transition-delay:.32s}
#navMenu.is-open .nm-item:nth-child(4) .nm-label{transform:translateY(0);transition-delay:.40s}

/* ── Footer izquierda ── */
.nm-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:22px;
  border-top:1px solid rgba(255,255,255,.055);
}
.nm-tagline{
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.16);
}
.nm-foot-actions{display:flex;align-items:center;gap:12px}

.nm-foot-actions button{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  color:#fff;border-radius:8px;
  padding:8px 13px;cursor:pointer;
  font-size:16px;line-height:1;
  transition:background .2s,border-color .2s;
}
.nm-foot-actions button:hover{background:rgba(226,35,26,.18);border-color:rgba(226,35,26,.42)}
.nm-close-btn{font-size:14px!important;color:rgba(255,255,255,.6)!important}
.nm-close-btn:hover{color:#fff!important}
.nm-pwa-btn{display:flex!important;align-items:center;gap:6px;font-family:var(--font-display);font-size:11px!important;letter-spacing:1.5px;text-transform:uppercase}
.nm-pwa-btn[style*="none"]{display:none!important}

.nm-login-link{
  font-family:var(--font-display);font-size:13px;
  letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.42);text-decoration:none;
  transition:color .3s;
}
.nm-login-link:hover{color:#fff}

/* ── Columna derecha — visual decorativo ── */
.nm-right{
  display:flex;align-items:center;justify-content:center;
  background:#050101;
  position:relative;overflow:hidden;
}

/* gran texto de fondo "RP" */
.nm-right::before{
  content:'RP';
  position:absolute;
  font-family:var(--font-display);
  font-size:clamp(240px,30vw,420px);
  color:rgba(226,35,26,.045);
  line-height:1;letter-spacing:-8px;
  user-select:none;pointer-events:none;
}

/* blob de glow rojizo centrado */
.nm-right::after{
  content:'';position:absolute;
  width:60%;aspect-ratio:1;
  background:radial-gradient(circle,rgba(226,35,26,.12) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}

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

.nm-visual-img{
  width:clamp(100px,15vw,200px);height:auto;object-fit:contain;
  filter:drop-shadow(0 0 60px rgba(226,35,26,.45));
  opacity:0;transform:translateY(22px) scale(.9);
  transition:opacity .65s cubic-bezier(.16,1,.3,1) .32s,
             transform .65s cubic-bezier(.16,1,.3,1) .32s;
}
#navMenu.is-open .nm-visual-img{opacity:1;transform:translateY(0) scale(1)}

.nm-visual-text{
  font-family:var(--font-display);
  font-size:clamp(12px,1.4vw,18px);
  letter-spacing:7px;text-transform:uppercase;
  text-align:center;line-height:1.3;
  color:rgba(255,255,255,.09);
  user-select:none;margin:0;
}

.nm-visual-stats{display:flex;gap:28px;margin-top:6px}

.nm-vs{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  opacity:0;transform:translateY(16px);
  transition:opacity .5s cubic-bezier(.16,1,.3,1),
             transform .5s cubic-bezier(.16,1,.3,1);
}
.nm-vs:nth-child(1){transition-delay:.46s}
.nm-vs:nth-child(2){transition-delay:.54s}
.nm-vs:nth-child(3){transition-delay:.62s}
#navMenu.is-open .nm-vs{opacity:1;transform:translateY(0)}

.nm-vs b{
  font-family:var(--font-display);
  font-size:clamp(28px,3.8vw,52px);
  color:var(--red);line-height:1;
}
.nm-vs small{
  font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(255,255,255,.32);
}

/* ── Mobile ── */
@media(max-width:767px){
  .nm-inner{grid-template-columns:1fr}
  .nm-right{display:none}
  .nm-left{padding:88px 28px 40px;border-right:none}
  .nm-label{font-size:clamp(42px,13vw,64px)}
  .nm-tagline{display:none}
}

/* Overlay: ya no se necesita separado */
.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 ---------- */
.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;
}

/* ── 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: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); }

/* ── Pompa de jabón — goleador ───────────────────────────── */
.scorer-bubble{
  position:absolute;
  top:-48px; right:14px;
  width:90px; height:90px;
  border-radius:50%;
  pointer-events:none;
  overflow:hidden;
  opacity:0;
  transform:scale(.45);
  transform-origin:center bottom;
  transition:opacity .4s cubic-bezier(.16,1,.3,1),
             transform .45s cubic-bezier(.16,1,.3,1);
  z-index:20;
}
.result-card:hover .scorer-bubble{
  opacity:1;
  transform:scale(1);
}
.sb-soap{
  position:absolute;inset:0;border-radius:50%;pointer-events:none;z-index:2;
  background:
    radial-gradient(circle at 28% 25%,rgba(255,255,255,.65) 0%,transparent 42%),
    radial-gradient(circle at 75% 75%,rgba(255,255,255,.15) 0%,transparent 35%),
    conic-gradient(from 0deg,
      rgba(226,35,26,.5),rgba(255,200,80,.35),rgba(100,220,255,.4),
      rgba(180,80,255,.35),rgba(226,35,26,.5)
    );
  mix-blend-mode:screen;
  animation:soapSpin 4s linear infinite;
}
[data-theme="light"] .sb-soap{ mix-blend-mode:multiply; opacity:.6; }
@keyframes soapSpin{0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(360deg)}}
.scorer-bubble::before{
  content:'';position:absolute;inset:0;border-radius:50%;z-index:3;
  border:1.5px solid rgba(255,255,255,.4);
  box-shadow:inset 0 0 16px rgba(255,255,255,.2),
             inset 0 -4px 12px rgba(0,0,0,.3),
             0 6px 24px rgba(0,0,0,.35);
}
.sb-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;object-position:bottom;
  z-index:1;border-radius:50%;
  transition:opacity .25s ease,transform .25s ease;
}
.sb-name{
  position:absolute;bottom:7px;left:50%;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:7.5px;letter-spacing:1.5px;font-weight:700;
  color:#fff;text-align:center;white-space:nowrap;
  z-index:4;text-shadow:0 1px 6px rgba(0,0,0,.9);
  max-width:82px;overflow:hidden;text-overflow:ellipsis;
  transition:opacity .2s ease;
}

/* ── 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,.85),rgba(10,6,6,.95));border:1px solid var(--border);border-radius:24px;padding:42px;width:100%;max-width:440px;backdrop-filter:blur(16px);box-shadow:0 40px 100px rgba(0,0,0,.6);animation:popUp .5s 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)}

.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{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:36px 30px;backdrop-filter:blur(12px);box-shadow:var(--shadow-card)}
.auth-back{display:inline-block;margin-bottom:18px;color:var(--text-muted);text-decoration:none;font-size:13px}
.auth-back:hover{color:var(--red)}
.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 */
.site-footer{border-top:1px solid var(--border);padding:40px 5vw;background:var(--bg)}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:28px;flex-wrap:wrap;justify-content:space-between}
.footer-social{display:flex;gap:14px}
.footer-social a{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);display:grid;place-items:center;color:var(--text-muted);transition:.2s}.footer-social a:hover{border-color:var(--red);color:var(--red)}
.footer-legal{font-size:12px;color:var(--text-muted);line-height:1.8}
.footer-author{color:#5a4a4a}.footer-author a{color:var(--text-muted);text-decoration:none;border-bottom:1px solid rgba(226,35,26,.3);transition:.2s}.footer-author a:hover{color:var(--red);border-bottom-color:var(--red)}

/* 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)}}

/* ── Scorer bubble — pointer events on hover ── */
.result-card:hover .scorer-bubble{
  pointer-events:auto;
  cursor:pointer;
}

/* ══════════════════════════════════════
   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}

/* ── 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}
