/* =====================================================================
   Horizon Padel - nightlife.css
   Capa de diseño compartida "nightlife cinemático".
   Se carga DESPUÉS de styles.css. Prefijo .nl- para no colisionar.
   Azul eléctrico #0057ff de base + --nl-accent por página.
   ===================================================================== */

:root {
  --nl-bg: #05070f;
  --nl-bg-2: #070a16;
  --nl-bg-3: #0c0710;
  --nl-blue: #0057ff;
  --nl-blue-bright: #1a8fff;
  --nl-blue-glow: #00aaff;
  --nl-accent: #ff8c38;          /* por defecto naranja fuego; cada página lo redefine */
  --nl-accent-glow: #ffae6b;
  --nl-glass: rgba(255, 255, 255, 0.04);
  --nl-glass-strong: rgba(255, 255, 255, 0.07);
  --nl-stroke: rgba(255, 255, 255, 0.09);
  --nl-stroke-soft: rgba(255, 255, 255, 0.06);
  --nl-text: #ffffff;
  --nl-text-soft: rgba(255, 255, 255, 0.72);
  --nl-shadow-blue: 0 0 40px rgba(0, 120, 255, 0.35);
  --nl-shadow-accent: 0 0 46px rgba(255, 140, 56, 0.38);
  --nl-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* nlAurora: animación de la aurora del fondo de página (body::before) */
@keyframes nlAurora {
  0%   { transform: translate3d(-3%, -2%, 0) scale(1) rotate(0deg); }
  50%  { transform: translate3d(4%, 3%, 0) scale(1.14) rotate(7deg); }
  100% { transform: translate3d(-2%, 2%, 0) scale(1.06) rotate(-6deg); }
}

/* ====================== Reveal on scroll ====================== */
.nl-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s var(--nl-ease), transform 0.7s var(--nl-ease);
  will-change: opacity, transform;
}
.nl-reveal.is-visible { opacity: 1; transform: none; }

/* ====================== Animaciones compartidas ====================== */
/* nlPulse: dot pulsante de la cinta superior. nlShimmer: brillo que recorre
   la cinta superior y el CTA principal de la home. */
@keyframes nlPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
@keyframes nlShimmer { 0% { left: -120%; } 55%,100% { left: 140%; } }

/* ====================== Reduced motion ====================== */
@media (prefers-reduced-motion: reduce) {
  html[data-page] body::before { animation: none !important; }
  .nl-topbar::before, .nl-topbar-dot { animation: none !important; }
  .nl-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ====================== CINTA SUPERIOR (anuncio Torneo) ====================== */
.nl-topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1100;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  height: 40px; padding: 0 18px; overflow: hidden; white-space: nowrap;
  background: linear-gradient(90deg, var(--nl-blue) 0%, #0a78ff 45%, var(--nl-accent) 100%);
  color: #fff; text-decoration: none;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 0.96rem; font-weight: 600; letter-spacing: 0.07em; text-transform: uppercase;
  box-shadow: 0 2px 18px rgba(0,0,0,0.45);
  transition: filter 0.25s var(--nl-ease);
}
.nl-topbar:hover { filter: brightness(1.1); }
.nl-topbar > * { position: relative; z-index: 1; }
.nl-topbar::before {
  content: ''; position: absolute; top: 0; left: -130%; width: 48%; height: 100%; z-index: 0;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.38), transparent);
  transform: skewX(-18deg); animation: nlShimmer 4.5s ease-in-out infinite;
}
.nl-topbar-dot {
  width: 8px; height: 8px; border-radius: 50%; flex: none;
  background: #fff; box-shadow: 0 0 10px #fff, 0 0 18px var(--nl-accent-glow);
  animation: nlPulse 1.5s ease-in-out infinite;
}
.nl-topbar-txt { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nl-topbar-txt strong { font-weight: 800; letter-spacing: 0.1em; }
.nl-topbar-cta {
  background: rgba(0,0,0,0.28); padding: 3px 12px; border-radius: 999px;
  font-weight: 700; white-space: nowrap; flex: none;
}
@media (max-width: 720px) {
  .nl-topbar { font-size: 0.74rem; gap: 8px; padding: 0 10px; letter-spacing: 0.04em; }
  .nl-topbar-cta { padding: 2px 9px; }
  .nl-topbar-extra { display: none; }
}

/* ====================== NAV (glass + glow) ====================== */
#site-nav nav {
  position: fixed;
  top: 40px; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  height: 72px;
  padding: 0 5%;
  background: rgba(5, 7, 15, 0.55);
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--nl-stroke-soft);
  transition: height 0.3s var(--nl-ease), background 0.3s var(--nl-ease), box-shadow 0.3s var(--nl-ease);
}
#site-nav.is-scrolled nav {
  height: 60px;
  background: rgba(5, 7, 15, 0.85);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45), 0 0 0 1px var(--nl-stroke-soft);
}
#site-nav .nav-logo img { height: 30px; width: auto; display: block; }
#site-nav .nav-links {
  display: flex; align-items: center; gap: 26px;
  list-style: none; margin: 0; padding: 0;
}
#site-nav .nav-links a {
  position: relative;
  color: var(--nl-text-soft);
  text-decoration: none;
  font-family: 'Barlow', sans-serif;
  font-weight: 500; font-size: 15px;
  transition: color 0.25s var(--nl-ease);
}
#site-nav .nav-links a::after {
  content: '';
  position: absolute; left: 0; bottom: -6px;
  width: 0; height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, var(--nl-blue), var(--nl-accent));
  transition: width 0.3s var(--nl-ease);
}
#site-nav .nav-links a:hover { color: #fff; }
#site-nav .nav-links a:hover::after,
#site-nav .nav-links a.active::after { width: 100%; }
#site-nav .nav-links a.active { color: #fff; }
#site-nav .nav-links .nav-wa {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: 999px;
  color: #fff;
  background: linear-gradient(100deg, var(--nl-blue), var(--nl-blue-glow));
  box-shadow: var(--nl-shadow-blue);
}
#site-nav .nav-links .nav-wa::after { display: none; }
#site-nav .nav-links .nav-wa:hover { transform: translateY(-1px); }

/* ====================== FOOTER (glow) ====================== */
#site-footer footer {
  position: relative;
  background: var(--nl-bg);
  border-top: 1px solid var(--nl-stroke-soft);
  padding: 64px 5% 28px;
  overflow: hidden;
}
#site-footer footer::before {
  content: '';
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--nl-blue-glow), var(--nl-accent), transparent);
  opacity: 0.7;
}
#site-footer .footer-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 32px;
  max-width: 1180px; margin: 0 auto 40px;
}
#site-footer .footer-logo img { height: 34px; width: auto; }
#site-footer .footer-desc { color: var(--nl-text-soft); font-size: 14px; line-height: 1.6; margin: 14px 0 18px; max-width: 280px; }
#site-footer .footer-col h4 {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase;
  letter-spacing: 2px; font-size: 14px; color: #fff; margin: 0 0 14px;
}
#site-footer .footer-col ul { list-style: none; margin: 0; padding: 0; }
#site-footer .footer-col li { margin-bottom: 9px; }
#site-footer .footer-col a, #site-footer .footer-desc a { color: var(--nl-text-soft); text-decoration: none; font-size: 14px; transition: color 0.25s var(--nl-ease); }
#site-footer .footer-col a:hover { color: var(--nl-blue-glow); }
#site-footer .social-links { display: flex; gap: 12px; }
#site-footer .social-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--nl-stroke); color: var(--nl-text-soft);
  background: var(--nl-glass);
  transition: color 0.25s var(--nl-ease), border-color 0.25s var(--nl-ease), box-shadow 0.25s var(--nl-ease), transform 0.25s var(--nl-ease);
}
#site-footer .social-link:hover { color: #fff; border-color: var(--nl-blue-glow); box-shadow: var(--nl-shadow-blue); transform: translateY(-2px); }
#site-footer .footer-bottom {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  max-width: 1180px; margin: 0 auto; padding-top: 20px;
  border-top: 1px solid var(--nl-stroke-soft);
  font-size: 13px; color: var(--nl-text-soft);
}
#site-footer .footer-bottom a { color: var(--nl-text-soft); text-decoration: none; }
#site-footer .footer-bottom a:hover { color: var(--nl-blue-glow); }

@media (max-width: 900px) {
  #site-footer .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  #site-footer .footer-top { grid-template-columns: 1fr; }
  #site-footer .footer-bottom { flex-direction: column; text-align: center; }
}

/* ====================== Acento UNIFICADO (idéntico en TODA la web) ======================
   Azul eléctrico (#0057ff, base) + naranja fuego (#ff8c38). El mismo degradado en todas
   las páginas para máxima coherencia. */
html[data-page] { --nl-accent: #ff8c38; --nl-accent-glow: #ffae6b; }

/* =====================================================================
   GENERAL — realce para TODAS las páginas con data-page (interiores).
   Usa --nl-accent (cada página define el suyo). La home tiene reglas
   más específicas (html[data-page="home"]) que ganan donde haga falta.
   ===================================================================== */
html[data-page] .section-label {
  color: var(--nl-blue-glow) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
html[data-page] .section-title {
  background: linear-gradient(108deg, #ffffff 0%, #ffffff 42%, var(--nl-blue-bright) 70%, var(--nl-accent) 104%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 0 30px rgba(0, 150, 255, 0.26));
}
/* Tarjetas comunes de interiores: glass + glow + elevación (spotlight lo añade el JS) */
html[data-page] .evento-card,
html[data-page] .sede-card,
html[data-page] .stat-card,
html[data-page] .premio-item,
html[data-page] .nos-valor,
html[data-page] .cap-card,
html[data-page] .contacto-card {
  transition: transform 0.4s var(--nl-ease), box-shadow 0.4s var(--nl-ease), border-color 0.4s var(--nl-ease) !important;
}
html[data-page] .evento-card:hover,
html[data-page] .sede-card:hover,
html[data-page] .stat-card:hover,
html[data-page] .premio-item:hover,
html[data-page] .nos-valor:hover,
html[data-page] .cap-card:hover,
html[data-page] .contacto-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--nl-shadow-blue) !important;
  border-color: rgba(0, 150, 255, 0.42) !important;
}
/* Acento secundario por página en los números/stat destacados */
html[data-page] .stat-number {
  text-shadow: 0 0 24px color-mix(in srgb, var(--nl-accent) 55%, transparent);
}

/* ===== TARJETAS UNIFICADAS (simetría en toda la web) =====
   Todas las "cards" de todas las páginas comparten: glass + línea de acento arriba + hover-glow. */
html[data-page] .stat-card,
html[data-page] .sede-card,
html[data-page] .premio-item,
html[data-page] .como-step,
html[data-page] .beneficio-card,
html[data-page] .nos-club-card,
html[data-page] .nos-stat-card,
html[data-page] .valor-card,
html[data-page] .equipo-card,
html[data-page] .contacto-card,
html[data-page] .cap-card,
html[data-page] .evento-card {
  position: relative;
  background: rgba(9, 12, 22, 0.62) !important;
  border: 1px solid var(--nl-stroke) !important;
  border-radius: 16px !important;
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  transition: transform 0.4s var(--nl-ease), box-shadow 0.4s var(--nl-ease), border-color 0.4s var(--nl-ease) !important;
}
html[data-page] .stat-card::after,
html[data-page] .sede-card::after,
html[data-page] .premio-item::after,
html[data-page] .como-step::after,
html[data-page] .beneficio-card::after,
html[data-page] .nos-club-card::after,
html[data-page] .nos-stat-card::after,
html[data-page] .valor-card::after,
html[data-page] .equipo-card::after,
html[data-page] .contacto-card::after,
html[data-page] .cap-card::after {
  content: ''; position: absolute; top: 0; left: 14px; right: 14px; height: 2px; z-index: 2;
  background: linear-gradient(90deg, transparent, var(--nl-blue), var(--nl-accent), transparent);
  opacity: 0.85;
}
html[data-page] .stat-card:hover,
html[data-page] .sede-card:hover,
html[data-page] .premio-item:hover,
html[data-page] .como-step:hover,
html[data-page] .beneficio-card:hover,
html[data-page] .nos-club-card:hover,
html[data-page] .nos-stat-card:hover,
html[data-page] .valor-card:hover,
html[data-page] .equipo-card:hover,
html[data-page] .contacto-card:hover,
html[data-page] .cap-card:hover,
html[data-page] .evento-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--nl-shadow-blue) !important;
  border-color: color-mix(in srgb, var(--nl-accent) 45%, transparent) !important;
}

/* ===== FONDO CINEMATOGRÁFICO de toda la página (interiores), estilo torneo ===== */
html[data-page] body {
  background:
    radial-gradient(130% 46% at 50% 0%, rgba(0, 100, 255, 0.20), transparent 70%),
    radial-gradient(130% 48% at 50% 100%, color-mix(in srgb, var(--nl-accent) 16%, transparent), transparent 70%),
    linear-gradient(180deg, #05070f 0%, #06080f 50%, #08060d 100%) !important;
  background-attachment: fixed !important;
}
/* Aurora muy sutil en los bordes (apenas perceptible, elegante) */
html[data-page] body::before {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(48% 30% at 16% 5%, rgba(0, 150, 255, 0.16), transparent 66%),
    radial-gradient(50% 32% at 84% 97%, color-mix(in srgb, var(--nl-accent) 16%, transparent), transparent 66%);
  filter: blur(44px);
  opacity: 0.85;
  animation: nlAurora 24s ease-in-out infinite alternate;
}
/* Rejilla sutil fija sobre el fondo */
html[data-page] body::after {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.4;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  -webkit-mask-image: radial-gradient(circle at 50% 35%, #000 25%, transparent 75%);
          mask-image: radial-gradient(circle at 50% 35%, #000 25%, transparent 75%);
}
/* Que las secciones y TODOS los heroes dejen ver el fondo unificado (sin fondos propios opacos) */
html[data-page] main > section,
html[data-page] body > section,
html[data-page] #site-hero,
html[data-page] [class$="-hero"] {
  background: transparent !important;
  position: relative; z-index: 0;
}
/* Neutralizar también los pseudo-fondos opacos de heroes propios (p.ej. ranking) */
html[data-page]:not([data-page="home"]) .ranking-hero::before,
html[data-page]:not([data-page="home"]) .ranking-hero::after {
  background: transparent !important;
}
/* Partículas visibles dentro de cualquier hero (por encima del fondo, debajo del contenido) */
html[data-page] .nl-particles { z-index: 0; }

/* ===== NAV premium: subrayado degradado que se desliza + glow al pasar ===== */
#site-nav .nav-links a:not(.nav-wa) {
  position: relative;
  padding: 8px 2px;
  background: none !important;
  border: none !important;
  font-family: 'Barlow', sans-serif !important;
  font-weight: 400 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55) !important;
  transition: color 0.35s var(--nl-ease), letter-spacing 0.35s var(--nl-ease);
}
/* Subrayado: usamos la barra deslizante (.nl-nav-underline, posicionada por nightlife.js).
   Ocultamos cualquier ::after individual (heredado de styles.css). */
#site-nav .nav-links a:not(.nav-wa)::after { display: none !important; }
#site-nav .nav-links a:not(.nav-wa):hover { color: #fff !important; letter-spacing: 0.28em !important; }
#site-nav .nav-links a.active:not(.nav-wa) { color: #fff !important; }
.nl-nav-underline {
  position: absolute; bottom: -4px; left: 0; height: 2px; width: 0;
  background: linear-gradient(90deg, var(--nl-blue), var(--nl-accent));
  border-radius: 2px;
  box-shadow: 0 0 14px color-mix(in srgb, var(--nl-accent) 55%, var(--nl-blue));
  opacity: 0; pointer-events: none; z-index: 1;
  transition: left 0.42s cubic-bezier(0.65,0,0.35,1), width 0.42s cubic-bezier(0.65,0,0.35,1), opacity 0.3s var(--nl-ease);
}

/* Botón Torneo del menú móvil (la versión escritorio se sustituyó por la cinta superior) */
.mobile-menu a.m-torneo {
  background: linear-gradient(100deg, var(--nl-blue), var(--nl-accent)) !important;
  color: #fff !important; font-weight: 700;
  border-radius: 12px; text-align: center;
  box-shadow: 0 0 20px color-mix(in srgb, var(--nl-accent) 40%, transparent);
}

/* =====================================================================
   HOME — transformación visible del cuerpo (estética torneo)
   Scoped a html[data-page="home"]. Overrides sobre styles.css.
   ===================================================================== */

/* Fondo cinematográfico global de la home + glow entre secciones */
html[data-page="home"] body { background: var(--nl-bg); }
html[data-page="home"] main,
html[data-page="home"] section:not(.hero) { position: relative; isolation: isolate; }
html[data-page="home"] section:not(.hero)::before {
  content: '';
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(90% 60% at 15% 0%, rgba(0, 87, 255, 0.12), transparent 60%),
    radial-gradient(90% 60% at 85% 100%, color-mix(in srgb, var(--nl-accent) 14%, transparent), transparent 60%);
}

/* Eyebrow / label de sección */
html[data-page="home"] .section-label {
  color: var(--nl-blue-glow) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}

/* Títulos GIGANTES con degradado + glow (como el torneo) */
html[data-page="home"] .section-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-weight: 400 !important;
  font-size: clamp(2.6rem, 6.5vw, 5.4rem) !important;
  line-height: 0.94 !important;
  letter-spacing: 0.02em !important;
  background: linear-gradient(108deg, #ffffff 0%, #ffffff 40%, var(--nl-blue-bright) 68%, var(--nl-accent) 104%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 0 34px rgba(0, 150, 255, 0.35));
}

/* Hero headline (segunda línea): refuerzo de glow sin tocar el clip de texto original */
html[data-page="home"] .hero-headline span {
  filter: drop-shadow(0 0 30px rgba(0, 170, 255, 0.45));
}

/* Tarjetas glass con línea de acento + glow + hover (stats, sedes, premios, eventos, banners) */
html[data-page="home"] .stat-card,
html[data-page="home"] .sede-card,
html[data-page="home"] .premio-item,
html[data-page="home"] .evento-card,
html[data-page="home"] .wa-banner {
  position: relative;
  background: rgba(9, 12, 22, 0.62) !important;
  border: 1px solid var(--nl-stroke) !important;
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border-radius: 16px !important;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  transition: transform 0.4s var(--nl-ease), box-shadow 0.4s var(--nl-ease), border-color 0.4s var(--nl-ease) !important;
}
html[data-page="home"] .sede-card::before,
html[data-page="home"] .evento-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px; z-index: 2;
  background: linear-gradient(90deg, var(--nl-blue), var(--nl-accent));
}
html[data-page="home"] .stat-card:hover,
html[data-page="home"] .sede-card:hover,
html[data-page="home"] .premio-item:hover,
html[data-page="home"] .evento-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(0, 150, 255, 0.42) !important;
  box-shadow: var(--nl-shadow-blue) !important;
}

/* Números de stats tipo marcador con glow */
html[data-page="home"] .stat-number {
  font-family: 'Bebas Neue', sans-serif !important;
  color: #fff !important;
  text-shadow: 0 0 26px rgba(0, 150, 255, 0.55);
}
html[data-page="home"] .stat-label {
  font-family: 'Barlow Condensed', sans-serif !important;
  letter-spacing: 0.14em !important; text-transform: uppercase !important;
}

/* Botón primario con degradado + shimmer */
html[data-page="home"] .btn-primary {
  position: relative; overflow: hidden;
  background: linear-gradient(100deg, var(--nl-blue) 0%, var(--nl-blue-glow) 100%) !important;
  border: none !important;
  box-shadow: var(--nl-shadow-blue) !important;
}
html[data-page="home"] .btn-primary::after {
  content: '';
  position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-18deg);
  animation: nlShimmer 3.4s ease-in-out infinite;
}

/* Premios: realce del título y de la medalla de oro */
html[data-page="home"] .premios-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  letter-spacing: 0.08em; color: #fff;
}
html[data-page="home"] .premio-item.gold { box-shadow: inset 0 0 0 1px rgba(255, 210, 74, 0.35); }

@media (prefers-reduced-motion: reduce) {
  html[data-page="home"] .btn-primary::after { animation: none !important; }
}

/* ====================== Partículas flotantes (hero home) ====================== */
.nl-particles {
  position: absolute; inset: 0; z-index: -1;
  overflow: hidden; pointer-events: none;
}
.nl-particle {
  position: absolute; bottom: -12px; border-radius: 50%;
  background: var(--nl-blue-glow);
  box-shadow: 0 0 8px var(--nl-blue-glow);
  animation-name: nlFloatUp;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}
.nl-particle--accent { background: var(--nl-accent); box-shadow: 0 0 8px var(--nl-accent-glow); }
@keyframes nlFloatUp {
  0%   { transform: translateY(0) scale(1);    opacity: 0; }
  12%  { opacity: 0.9; }
  88%  { opacity: 0.9; }
  100% { transform: translateY(-92vh) scale(0.4); opacity: 0; }
}

/* Hero home: contexto de apilado propio */
html[data-page="home"] .hero { isolation: isolate; }

/* ====================== Separadores con glow entre secciones (home) ====================== */
html[data-page="home"] section:not(.hero)::after {
  content: '';
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: min(680px, 78%); height: 1px; z-index: -1;
  background: linear-gradient(90deg, transparent, var(--nl-blue-glow), var(--nl-accent), transparent);
  opacity: 0.5;
}

@media (prefers-reduced-motion: reduce) {
  .nl-particle { animation: none !important; opacity: 0 !important; }
}

/* ====================== Barra de progreso de scroll ====================== */
.nl-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0;
  z-index: 1200; pointer-events: none;
  background: linear-gradient(90deg, var(--nl-blue), var(--nl-blue-glow), var(--nl-accent));
  box-shadow: 0 0 12px rgba(0, 170, 255, 0.6);
  transition: width 0.1s linear;
}

/* ====================== Spotlight que sigue al cursor (tarjetas) ====================== */
.nl-spot { position: relative; }
.nl-spot::after {
  content: ''; position: absolute; inset: 0; z-index: 1;
  border-radius: inherit; pointer-events: none; opacity: 0;
  background: radial-gradient(220px circle at var(--mx, 50%) var(--my, 50%), rgba(0, 170, 255, 0.16), transparent 60%);
  transition: opacity 0.3s var(--nl-ease);
}
.nl-spot:hover::after { opacity: 1; }
.trn-btn, .btn-primary, .btn-wa, .nav-wa {
  transition: transform 0.18s var(--nl-ease), box-shadow 0.25s var(--nl-ease), background 0.25s var(--nl-ease);
}

/* Brillo que recorre el título gigante del hero (home) + parallax suave */
html[data-page="home"] .trn-title {
  transition: transform 0.25s var(--nl-ease);
  will-change: transform;
  filter: drop-shadow(0 6px 26px rgba(0, 0, 0, 0.75));
}
/* Garantizar visibilidad del título aunque la animación de entrada esté desactivada (reduced-motion) */
html[data-page="home"] .trn-title-1,
html[data-page="home"] .trn-title-2 { opacity: 1 !important; }
html[data-page="home"] .trn-title-1 {
  background: none !important;
  -webkit-text-fill-color: #ffffff !important;
  color: #ffffff !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.65), 0 0 30px rgba(0,0,0,0.4);
}
html[data-page="home"] .trn-hero-meta {
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.85);
}
html[data-page="home"] .trn-eyebrow {
  background: rgba(5, 7, 15, 0.55);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.8);
}
/* Capas del hero sobre la foto (foto en z-index:0; contenido y partículas por encima) */
html[data-page="home"] .trn-hero-particles { z-index: 1; }
html[data-page="home"] .trn-hero-inner { z-index: 2; }

/* Scrim oscuro detrás del bloque de texto del hero (legibilidad garantizada sobre la foto) */
html[data-page="home"] .trn-hero-inner { position: relative; }
html[data-page="home"] .trn-hero-inner::before {
  content: ''; position: absolute; z-index: -1; pointer-events: none;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: min(1180px, 94%); height: 116%;
  background: radial-gradient(58% 56% at 50% 46%, rgba(5,7,15,0.78) 0%, rgba(5,7,15,0.40) 60%, rgba(5,7,15,0) 78%);
}
html[data-page="home"] .trn-hero-particles { transition: transform 0.3s var(--nl-ease); will-change: transform; }
html[data-page="home"] .trn-title-2 {
  background-size: 220% auto;
  animation: nlTitleFlow 7s linear infinite;
}
@keyframes nlTitleFlow {
  0%   { background-position: 0% center; }
  100% { background-position: 220% center; }
}

/* Foto real de pista de fondo en el hero (home) con overlay cinematográfico + Ken Burns */
html[data-page="home"] .nl-hero-photo {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(180deg, rgba(5,7,15,0.40) 0%, rgba(5,7,15,0.42) 44%, rgba(5,7,15,0.80) 76%, rgba(5,7,15,0.98) 100%),
    url("../images/hero-home.jpg?v=1");
  background-size: cover;
  background-position: center 42%;
  animation: nlKenBurns 26s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes nlKenBurns {
  from { transform: scale(1.06); }
  to   { transform: scale(1.18); }
}
/* Ocultar las capas decorativas oscuras del torneo en la home: la FOTO es el fondo.
   (trn-hero-bg/aurora/beams/glow-line tapaban la imagen). Mantenemos partículas + título. */
html[data-page="home"] .trn-glow-line,
html[data-page="home"] .trn-hero-bg,
html[data-page="home"] .trn-aurora,
html[data-page="home"] .trn-beams { display: none; }
html[data-page="home"] .trn-hero::before { display: none; }
html[data-page="home"] .trn-title::after { display: none; }

/* Con foto detrás, el fondo del hero solo aporta los glows (base transparente) */
html[data-page="home"] .trn-hero-bg {
  background:
    radial-gradient(115% 90% at 50% -16%, rgba(0,120,255,0.32) 0%, transparent 56%),
    radial-gradient(135% 105% at 50% 120%, rgba(255,106,0,0.30) 0%, transparent 60%);
}

/* Haz de luz que gira lentamente tras el título (home) */
html[data-page="home"] .trn-hero { overflow: hidden; }
html[data-page="home"] .trn-hero::before {
  content: ''; position: absolute; z-index: -2;
  top: 50%; left: 50%; width: 140vw; height: 140vw;
  transform: translate(-50%, -50%);
  background: conic-gradient(from 0deg,
    transparent 0deg, rgba(0,120,255,0.10) 30deg, transparent 70deg,
    transparent 180deg, rgba(255,140,56,0.08) 210deg, transparent 250deg, transparent 360deg);
  animation: nlBeamSpin 28s linear infinite;
  pointer-events: none;
}
@keyframes nlBeamSpin { to { transform: translate(-50%, -50%) rotate(360deg); } }

@media (prefers-reduced-motion: reduce) {
  .nl-progress { display: none; }
  .nl-spot::after { display: none; }
  html[data-page="home"] .trn-title-2 { animation: none !important; }
  html[data-page="home"] .trn-hero::before { animation: none !important; }
  html[data-page="home"] .nl-hero-photo { animation: none !important; }
}

/* ====================== FAQ (home + americanas) ====================== */
html:is([data-page="home"], [data-page="americanas"]) .faq-list {
  max-width: 820px; margin: 44px auto 0;
  display: flex; flex-direction: column; gap: 0.75rem; text-align: left;
}
html:is([data-page="home"], [data-page="americanas"]) details.faq-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(0, 100, 255, 0.13);
  border-radius: 14px; overflow: hidden;
  transition: border-color 0.2s var(--nl-ease), background 0.2s var(--nl-ease);
}
html:is([data-page="home"], [data-page="americanas"]) details.faq-item[open] {
  border-color: rgba(0, 170, 255, 0.24);
  background: rgba(0, 87, 255, 0.04);
}
html:is([data-page="home"], [data-page="americanas"]) summary.faq-question {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.3rem 1.6rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.12rem; font-weight: 700; color: #fff; letter-spacing: 0.03em;
  cursor: pointer; list-style: none; user-select: none;
}
html:is([data-page="home"], [data-page="americanas"]) summary.faq-question::-webkit-details-marker { display: none; }
html:is([data-page="home"], [data-page="americanas"]) .faq-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(0, 87, 255, 0.12); border: 1px solid rgba(0, 100, 255, 0.22);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: #fff;
  transition: background 0.2s var(--nl-ease), transform 0.3s var(--nl-ease);
}
html:is([data-page="home"], [data-page="americanas"]) details[open] .faq-icon {
  background: rgba(0, 87, 255, 0.24); transform: rotate(45deg);
}
html:is([data-page="home"], [data-page="americanas"]) .faq-answer {
  padding: 0 1.6rem 1.3rem; margin: 0;
  font-size: 0.95rem; line-height: 1.7; color: var(--nl-text-soft);
}
html:is([data-page="home"], [data-page="americanas"]) .faq-answer a { color: var(--nl-blue-glow); text-decoration: none; }
html:is([data-page="home"], [data-page="americanas"]) .faq-answer a:hover { text-decoration: underline; }

/* =====================================================================
   MÓVIL — correcciones responsive globales (nav, cinta, fondo)
   ===================================================================== */
/* Fallback sólido oscuro: que NUNCA asome el blanco del navegador detrás
   del fondo (causa de los "parches en blanco" al hacer scroll en móvil). */
html, html[data-page], html[data-page] body { background-color: #05070f; }

@media (max-width: 900px) {
  /* NAV: ocultar los enlaces de escritorio y mostrar SOLO el menú
     hamburguesa. Sin esto los 7 enlaces se amontonan sobre el logo. */
  #site-nav .nav-links { display: none !important; }
  #site-nav nav .hamburger { display: flex !important; }
  .nl-nav-underline { display: none !important; }
  /* El menú móvil debe abrirse por debajo de la cinta (40px) + nav (72px). */
  #site-nav .mobile-menu { top: 112px; }

  /* FONDO: en móvil 'background-attachment: fixed' provoca parpadeos
     blancos y saltos de color al hacer scroll (mala compatibilidad y la
     barra de URL dinámica). Se desactiva. */
  html[data-page] body { background-attachment: scroll !important; }
}

/* ===== MÓVIL: compactar para que no haya que desplazar tanto (≤600px) ===== */
@media (max-width: 600px) {
  /* Menos hueco vertical entre secciones (antes ~72-80px arriba y abajo
     = ~150px de hueco entre cada bloque). Se excluyen los hero. */
  html[data-page] main > section:not([class*="hero"]),
  html[data-page] body > section:not([class*="hero"]),
  html[data-page] main > div > section:not([class*="hero"]) {
    padding-top: 46px !important;
    padding-bottom: 46px !important;
  }
  /* Títulos de sección algo más contenidos en pantalla pequeña. */
  html[data-page] .section-title {
    font-size: clamp(30px, 8.4vw, 36px) !important;
    line-height: 1.02;
  }
  /* Evitar desbordes horizontales accidentales. */
  html[data-page] body { overflow-x: hidden; }
}
