
/* /assets/css/shell.css
   =========================================================
   Movistar Arena — Shell (estructura global)
   Mobile-first · SSR-friendly · Alto rendimiento
   ========================================================= */


/* =========================================================
   0) Reset mínimo + base
   ========================================================= */
*{ box-sizing: border-box; }
html{ height: 100%; }

body{
  margin: 0;

  font-family: var(--font-sans);
  font-weight: var(--fw-section-body);
  font-size: var(--fs-section-body);
  line-height: var(--lh-section-body);

  overflow-x: hidden;
  position: relative;

  background: var(--bg-base);
  color: var(--text);
}

section {
	padding: var(--pad--section);
}


.section-hero{
  position: relative;
  min-height: 90svh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  color: white;
}

/* Imagen */

.section-hero__media{
  position: absolute;
  inset: 0;
  z-index: 0;
}

.section-hero__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Overlay oscuro + azul MA */

.section-hero__overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(
      to bottom,
      rgba(8,12,24,0.35) 0%,
      rgba(8,12,24,0.55) 40%,
      rgba(8,12,24,0.85) 100%
    ),
    radial-gradient(
      1200px 600px at 70% 20%,
      rgba(var(--ma-blue-rgb), .35),
      transparent 60%
    );
}

/* Contenido */

.section-hero__content{
  position: relative;
  z-index: 2;
  padding-bottom: 60px;
  max-width: 780px;
}

/* Kicker */

.section-hero__kicker{
  font-size: var(--fs-element-nav);
  letter-spacing: .12em;
  text-transform: uppercase;
  opacity: .8;
  margin-bottom: 14px;
}

/* Título */

.section-hero__title{
  font-size: var(--fs-hero-title);
  line-height: var(--lh-hero-title);
  font-weight:  var(--fw-hero-title);
  margin: 0 0 16px;
  letter-spacing: -0.02em;
  
}

/* Lead */

.section-hero__lead{
  font-size: var(--fs-hero-lead);
  line-height: var(--lh-hero-lead);
  max-width: 60ch;
  margin-bottom: 24px;
  opacity: .92;
}

/* Botones */

.section-hero__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* Responsive */

@media (max-width: 768px){
  .section-hero{
    min-height: 75svh;
  }

  .section-hero__content{
    padding-bottom: 40px;
  }
}

/* HERO más bajo */
.section-hero--compact{
  min-height: clamp(260px, 42vh, 460px);
}
.section-hero--compact .section-hero__content{
  padding-top: clamp(24px, 5vh, 56px);
  padding-bottom: clamp(18px, 4vh, 44px);
}


a{ color: inherit; text-decoration: none; }

/* Accesibilidad: focus visible */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline: 3px solid color-mix(in srgb, var(--brand) 65%, transparent);
  outline-offset: 3px;
  border-radius: var(--r-md);
}

/* Utilidades */

/* Vuelo a una seccion #- Aplica a cualquier elemento que pueda ser target */
/* Para saltos por #hash (muy fiable) */
html{
  scroll-padding-top: var(--header-h);
}

/* Extra: también ayuda en scrollIntoView() y casos varios */
:target{
  scroll-margin-top: var(--header-h);
}

/* Suave (y respetuoso con reduce motion) */
@media (prefers-reduced-motion: no-preference){
  html{ scroll-behavior: smooth; }
}

.sr-only{
  position:absolute;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.muted{ color: var(--muted); margin: 0 0 12px; }

/* Skip link */
.skip-link{
  position:absolute;
  left:10px; top:10px;
  padding:10px 12px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transform: translateY(-140%);
  transition: transform var(--dur-2) var(--ease);
  z-index: 9999;
}
.skip-link:focus{ transform: translateY(0); }


/* =========================================================
   1) Layout Shell (sticky footer) — FLEX robusto
   ========================================================= */
body.ma-shell{
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;

  min-width: 0; /* clave: flex children pueden encoger sin overflow */
}

body.ma-shell > main{
  min-width: 0;
  /* Evita “saltos” y asegura que el footer se empuje correctamente */
  min-height: calc(
    100vh
    - var(--header-h, 0px)
    - var(--footer-top-h, 0px)
  );
}

@supports (height: 100svh){
  body.ma-shell > main{
    min-height: calc(
      100svh
      - var(--header-h, 0px)
      - var(--footer-top-h, 0px)
    );
  }
}

/* Footer abajo cuando hay espacio */
body.ma-shell > footer{ margin-top: auto; }


/* =========================================================
   2) Fondo animado (global)
   ========================================================= */
body::before{
  content:"";
  position: fixed;
  inset: -35%;
  z-index: -2;
  pointer-events: none;

  background:
    radial-gradient(900px 700px, rgba(var(--color-fondo-degradado-1), var(--alfa-fondo-degradado-1)), transparent var(--transparent-fondo-degradado)),
    radial-gradient(820px 720px, rgba(var(--color-fondo-degradado-2), var(--alfa-fondo-degradado-2)), transparent var(--transparent-fondo-degradado)),
    radial-gradient(900px 820px, rgba(var(--color-fondo-degradado-3), var(--alfa-fondo-degradado-3)), transparent var(--transparent-fondo-degradado)),
    radial-gradient(920px 720px, rgba(var(--color-fondo-degradado-4), var(--alfa-fondo-degradado-4)), transparent var(--transparent-fondo-degradado)),
    radial-gradient(1020px 920px, rgba(var(--color-fondo-degradado-5), var(--alfa-fondo-degradado-5)), transparent var(--transparent-fondo-degradado));

  background-repeat: no-repeat;

  background-size:
    1200px 900px,
    1100px 900px,
    1200px 1000px,
    1000px 900px,
    1300px 1100px;

  filter: blur(52px) saturate(2.2) contrast(1.12);
  transform-origin: 50% 50%;
  animation:
    blobDriftA 56s ease-in-out infinite,
    blobOrbitA 42s linear infinite;

  will-change: transform, filter, background-position;
}

body::after{
  content:"";
  position: fixed;
  inset: -40%;
  z-index: -1;
  pointer-events: none;

  background:
    radial-gradient(700px 650px, rgba(var(--ma-cream-rgb), .08), transparent 60%),
    radial-gradient(560px 520px, rgba(34,197,94,.18), transparent 64%),
    radial-gradient(600px 560px, rgba(11,92,255,.35), transparent 66%),
    radial-gradient(520px 520px, rgba(11,92,255,.26), transparent 64%),
    radial-gradient(620px 560px, rgba(255,80,220,.30), transparent 62%);

  background-repeat: no-repeat;

  background-size:
    1600px 1200px,
    820px 760px,
    900px 820px,
    780px 740px,
    860px 780px;

  mix-blend-mode: screen;
  opacity: .92;
  filter: blur(26px) saturate(2.0);

  transform-origin: 50% 50%;
  animation:
    blobDriftB 44s ease-in-out infinite,
    blobOrbitB 33s linear infinite;

  will-change: transform, filter, background-position, opacity;
}

@keyframes blobDriftA{
  0%{ background-position: 10% 20%, 75% 10%, 55% 85%, 95% 35%, 40% 110%;
      filter: blur(52px) saturate(2.2) contrast(1.12) hue-rotate(0deg); }
  25%{ background-position: 85% 10%, -10% 40%, 30% -10%, 55% 120%, 110% 55%;
       filter: blur(58px) saturate(2.5) contrast(1.10) hue-rotate(10deg); }
  50%{ background-position: 120% 55%, 20% 120%, -20% 35%, 40% -20%, 70% 10%;
       filter: blur(54px) saturate(2.35) contrast(1.14) hue-rotate(-12deg); }
  75%{ background-position: 35% 120%, 110% 65%, 70% 5%, -25% 55%, 10% -20%;
       filter: blur(60px) saturate(2.6) contrast(1.10) hue-rotate(18deg); }
  100%{ background-position: 10% 20%, 75% 10%, 55% 85%, 95% 35%, 40% 110%;
        filter: blur(52px) saturate(2.2) contrast(1.12) hue-rotate(0deg); }
}

@keyframes blobDriftB{
  0%{ background-position: 50% 50%, 20% 80%, 90% 75%, 10% 20%, 80% 15%;
      opacity: .88; filter: blur(26px) saturate(2.0) hue-rotate(0deg); }
  30%{ background-position: 40% 60%, 110% 30%, 30% -10%, -20% 70%, 60% 120%;
       opacity: .97; filter: blur(30px) saturate(2.3) hue-rotate(-16deg); }
  60%{ background-position: 60% 40%, -25% 25%, 120% 45%, 55% 120%, 5% -20%;
       opacity: .92; filter: blur(28px) saturate(2.15) hue-rotate(22deg); }
  100%{ background-position: 50% 50%, 20% 80%, 90% 75%, 10% 20%, 80% 15%;
        opacity: .88; filter: blur(26px) saturate(2.0) hue-rotate(0deg); }
}

@keyframes blobOrbitA{
  0%{ transform: rotate(0deg) scale(1.06); }
  50%{ transform: rotate(180deg) scale(1.10); }
  100%{ transform: rotate(360deg) scale(1.06); }
}
@keyframes blobOrbitB{
  0%{ transform: rotate(360deg) scale(1.02); }
  50%{ transform: rotate(180deg) scale(1.07); }
  100%{ transform: rotate(0deg) scale(1.02); }
}

@media (prefers-reduced-motion: reduce){
  body::before, body::after{ animation: none !important; }
}


/* =========================================================
   3) Helpers (glass + overlays + radius + spacing)
   ========================================================= */
.border-none {
	border: none !important;
}
.bg-none {
	background: none !important;
}



.bg-glass{
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  background: var(--ma-relleno-cristal);
  border-bottom: 1px solid var(--border);
}
.bg-glass-white{
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) !important;
  background: var(--w-relleno-cristal) !important;
  border-bottom: 1px solid var(--border) !important;
}

.bg-dark-blue{ background:var(--ma-dark-blue) !important;}
.bg-blue{ background:var(--ma-blue) !important;}
.bg-aqua{ background:var(--ma-aqua-100) !important;}
.bg-green{ background:var(--ma-green-100) !important;}
.bg-yellow{ background:var(--ma-yellow-100) !important;}
.bg-coral{ background:var(--ma-coral-100) !important;}
.bg-cream{ background:var(--ma-cream) !important;}

.text-ink { color:var(--ma-ink) !important;}
.text-dark-blue{ color:var(--ma-dark-blue) !important;}
.text-blue{ color:var(--ma-blue) !important;}
.text-aqua{ color:var(--ma-aqua-100) !important;}
.text-green{ color:var(--ma-green-100) !important;}
.text-yellow{ color:var(--ma-yellow-100) !important;}
.text-coral{ color:var(--ma-coral-100) !important;}
.text-cream{ color:var(--ma-cream) !important;}



.overlay-gradiente-up{
  background: linear-gradient(to top,
    rgba(var(--ma-dark-blue-rgb), 1) 25%,
    rgba(var(--ma-dark-blue-rgb), .55) 50%,
    rgba(var(--ma-dark-blue-rgb), .25) 70%,
    rgba(var(--ma-dark-blue-rgb), 0) 100%
  );
}
.overlay-min-gradiente-up{
  background: linear-gradient(to top,
    rgba(var(--ma-dark-blue-rgb), 1) 15%,
    rgba(var(--ma-dark-blue-rgb), 0) 40%
  );
}
.overlay-gradiente-down{
  background: linear-gradient(to bottom,
    rgba(var(--ma-dark-blue-rgb), 1) 25%,
    rgba(var(--ma-dark-blue-rgb), .55) 50%,
    rgba(var(--ma-dark-blue-rgb), .25) 70%,
    rgba(var(--ma-dark-blue-rgb), 0) 100%
  );
}
.overlay-min-gradiente-down{
  background: linear-gradient(to bottom,
    rgba(var(--ma-dark-blue-rgb), 1) 15%,
    rgba(var(--ma-dark-blue-rgb), 0) 40%
  );
}
.overlay-gradiente-up-down{
  background: linear-gradient(to bottom,
    rgba(var(--ma-dark-blue-rgb), 1) 0%,
    rgba(var(--ma-dark-blue-rgb), .85) 18%,
    rgba(var(--ma-dark-blue-rgb), .35) 40%,
    rgba(var(--ma-dark-blue-rgb), 0) 50%,
    rgba(var(--ma-dark-blue-rgb), .35) 60%,
    rgba(var(--ma-dark-blue-rgb), .85) 82%,
    rgba(var(--ma-dark-blue-rgb), 1) 100%
  );
}
.overlay-mini-gradiente-up-down{
  background: linear-gradient(to bottom,
    rgba(var(--ma-dark-blue-rgb), 1) 15%,
    rgba(var(--ma-dark-blue-rgb), 0) 50%,
    rgba(var(--ma-dark-blue-rgb), 0) 60%,
    rgba(var(--ma-dark-blue-rgb), 1) 85%
  );
}

.br-16{ border-radius: 16px; }



.fw-7{ font-weight: 700 !important; }
.o-100{ opacity: 1 !important; }
.color-text{ color: var(--text); }




/* Spacing helpers */
.m-0{ margin:0px !important; }
.mt-0,.my-0{ margin-top:0px !important; }
.mt-1,.my-1{ margin-top:.25rem !important; }
.mt-2,.my-2{ margin-top:.5rem !important; }
.mt-3,.my-3{ margin-top:1rem !important; }
.mt-4,.my-4{ margin-top:1.5rem !important; }
.mt-5,.my-5{ margin-top:3rem !important; }

.mb-0,.my-0{ margin-bottom:0px !important; }
.mb-1,.my-1{ margin-bottom:.25rem !important; }
.mb-2,.my-2{ margin-bottom:.5rem !important; }
.mb-3,.my-3{ margin-bottom:1rem !important; }
.mb-4,.my-4{ margin-bottom:1.5rem !important; }
.mb-5,.my-5{ margin-bottom:3rem !important; }


.ml-1,.mx-1{ margin-left:.25rem !important; } .ml-2,.mx-2{ margin-left:.5rem !important; }
.ml-3,.mx-3{ margin-left:1rem !important; }  .ml-4,.mx-4{ margin-left:1.5rem !important; }
.ml-5,.mx-5{ margin-left:3rem !important; }

.mr-1,.mx-1{ margin-right:.25rem !important; } .mr-2,.mx-2{ margin-right:.5rem !important; }
.mr-3,.mx-3{ margin-right:1rem !important; }  .mr-4,.mx-4{ margin-right:1.5rem !important; }
.mr-5,.mx-5{ margin-right:3rem !important; }

.p-0 { padding:0px !important; } 
.pt-0,.py-0{ padding-top:0px !important; } 
.pt-1,.py-1{ padding-top:.25rem !important; }
.pt-2,.py-2{ padding-top:.5rem !important; }
.pt-3,.py-3{ padding-top:1rem !important; }
.pt-4,.py-4{ padding-top:1.5rem !important; }
.pt-5,.py-5{ padding-top:3rem !important; }

.pb-0,.py-0{ padding-bottom:0px !important; }
.pb-1,.py-1{ padding-bottom:.25rem !important; } 
.pb-2,.py-2{ padding-bottom:.5rem !important; }
.pb-3,.py-3{ padding-bottom:1rem !important; }
.pb-4,.py-4{ padding-bottom:1.5rem !important; }
.pb-5,.py-5{ padding-bottom:3rem !important; }

.pl-1,.px-1{ padding-left:.25rem !important; } .pl-2,.px-2{ padding-left:.5rem !important; }
.pl-3,.px-3{ padding-left:1rem !important; }  .pl-4,.px-4{ padding-left:1.5rem !important; }
.pl-5,.px-5{ padding-left:3rem !important; }

.pr-1,.px-1{ padding-right:.25rem !important; } .pr-2,.px-2{ padding-right:.5rem !important; }
.pr-3,.px-3{ padding-right:1rem !important; }  .pr-4,.px-4{ padding-right:1.5rem !important; }
.pr-5,.px-5{ padding-right:3rem !important; }


/* =========================================================
   Display utilities (Bootstrap-like)
   Breakpoint LG = 881px
   ========================================================= */

.d-none  { display: none !important; }
.d-block { display: block !important; }
.d-flex  { display: flex !important; }

/* Desktop ≥ 881px */
@media (min-width: 881px){
  .d-lg-none  { display: none !important; }
  .d-lg-block { display: block !important; }
  .d-lg-flex  { display: flex !important; }
}

/* Mobile ≤ 880px */
@media (max-width: 880px){
  .d-mobile-none  { display: none !important; }
  .d-mobile-block { display: block !important; }
  .d-mobile-flex  { display: flex !important; }
}

.w-90{
  width: 90% !important;
  
}

.h-100{
	height: 100% !important;
}
.vh-20{
  height: 20vh !important;
}

/* =========================================================
   4) Header (global) + navegación
   ========================================================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 100;
}

.site-header__inner{
  position: relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: var(--gap);
  padding: 12px var(--pad);
  max-width: var(--container);
  margin: 0 auto;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:44px;
}
.brand img{ display:block; height:40px; width:auto; }

.site-nav{
  display:none;
  gap:16px;
}
.site-nav a{
  color: var(--muted);
  padding: 10px 10px;
  border-radius: var(--r-md);
  font-size: var(--fs-element-nav);
  line-height: var(--lh-element-nav);
  font-weight: var(--fw-element-nav);
}

.site-nav a.is-active,
.site-nav a[aria-current="page"]{
  color: var(--text);
  background: rgba(var(--ma-cream-rgb), 0.08);
  border: 1px solid var(--border);
}

@media (min-width: 960px){
  .site-nav{ display:flex; }
}


/* =========================================================
   4.1) Header — Mobile hamburger + drawer
   ========================================================= */
.nav-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px; height:44px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(var(--ma-cream-rgb), 0.06);
  color: var(--text);
  cursor:pointer;
}

.nav-toggle__bars{
  width:18px; height:12px;
  position:relative;
  display:inline-block;
}
.nav-toggle__bars::before{
  content:"";
  position:absolute;
  left:0; right:0;
  top:1px;
  height:2px;
  border-radius:2px;
  background: currentColor;
  opacity:.9;
  box-shadow: 0 4px 0 currentColor, 0 8px 0 currentColor;
}

/* Desktop: ocultamos toggle */
@media (min-width: 960px){
  .nav-toggle{ display:none; }
}
/* Mobile: ocultamos el nav horizontal */
@media (max-width: 959.98px){
  .site-nav{ display:none !important; }
}

/* Drawer */
.mobile-nav{
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: 1fr;
}
.mobile-nav[hidden]{ display:none; }

.mobile-nav__backdrop{
  position:absolute;
  inset:0;
  background: rgba(var(--ma-ink-rgb), 0.55);
  border:0;
}

.mobile-nav__panel{
  position:absolute;
  top:10px; right:10px; left:10px;
  max-width:520px;
  margin-left:auto;

  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(8, 12, 24, .92);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  box-shadow: 0 18px 42px rgba(0,0,0,.35);

  transform: translateY(-8px);
  opacity: 0;
  transition: opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease);
}
body.nav-open .mobile-nav__panel{
  opacity:1;
  transform: translateY(0);
}

.mobile-nav__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.mobile-nav__title{ font-weight: 800; letter-spacing: .2px; }

.mobile-nav__close{
  width:44px; height:44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(234,240,255,.92);
  cursor:pointer;
}

.mobile-nav__links{
  display:grid;
  padding:10px;
  gap:6px;
}
.mobile-nav__links a{
  display:flex;
  align-items:center;
  min-height:44px;
  padding:10px 12px;
  border-radius: 12px;
  color: rgba(234,240,255,.86);
  border: 1px solid transparent;
}
.mobile-nav__links a.is-active,
.mobile-nav__links a[aria-current="page"]{
  color: rgba(234,240,255,.96);
  background: rgba(var(--ma-cream-rgb), 0.08);
  border-color: rgba(255,255,255,.12);
}

body.nav-open{ overflow: hidden; }


/* =========================================================
   5) Contenedores de página
   ========================================================= */
.page{
  max-width: var(--container);
  margin: 0 auto;
  padding: var(--pad) var(--pad) 40px;
  min-width: 0;
  width: 100%;
}

/* Main full-bleed */
.w-full{
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
}


/* Page head (si lo usas) */
.page-head h1,
/*
.page-head__title h1{
  margin: 0;
  font-size: var(--fs-section-title);
  line-height: var(--lh-section-title);
  font-weight: var(--fw-section-title);
  letter-spacing: -0.4px;
}
*/
.page-head h1, .page-head__title h1 {
    margin: 0;
    font-size: var(--fs-section-title);
    line-height: var(--lh-section-title);
    font-weight: var(--fw-section-title);
    letter-spacing: -0.4px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

#venue-toggle{
  margin-left: auto !important; /* empuja el botón a la derecha */
}

@media (max-width:640px){
  #venue-toggle{
    margin-left: 0;
    margin-top: .4rem;
    align-self: flex-start;
  }
}

.page-head p,
.page-head__sub{
  margin: 8px 0 0;
  color: var(--muted);
  font-size: var(--fs-section-subtitle);
  line-height: var(--lh-section-subtitle);
  font-weight: var(--fw-section-subtitle);
}

.row{
  --min: 280px;
  --gap: 20px;

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--min), 1fr));
  gap: var(--gap);
}



/* =========================================================
   5.1) Page without header (hero full-bleed detrás del header)
   ========================================================= */

.page-without-header{ padding-top: 0 !important; }

.page-without-header .page-hero--main,
.page-without-header .page-hero--full{
  margin-top: calc(var(--header-h, 0px) * -1);
  padding-top: var(--header-h, 0px);
}

/* Header transparente encima del hero (mejora progresiva con :has) */
body:has(main.page-without-header) header.site-header.bg-glass{
  background: transparent !important;
  border-bottom-color: transparent !important;
  backdrop-filter: none !important;
}

/* Alturas del hero cuando hay page-without-header */
body:has(main.page-without-header) .page-hero--main{
  min-height: 70vh;
  max-height: 70vh;
	
  padding-top: var(--header-h, 0px);
}
@supports (height: 1svh){
  body:has(main.page-without-header) .page-hero--main{
    min-height: 70svh;
    max-height: 70svh;
  }
}

body:has(main.page-without-header) .page-hero--full{
  min-height: 100vh;
  max-height: 100vh;
  padding-top: var(--header-h, 0px);
}
@supports (height: 1svh){
  body:has(main.page-without-header) .page-hero--full{
    min-height: 100svh;
    max-height: 100svh;
  }
}


/* =========================================================
   5.2) Split + hero sections (bloques)
   ========================================================= */
.page-split{
  display:flex;
  flex-direction:column;
  gap:0;
}

.page-hero{
  position: relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow: visible;
}

/* Variantes de altura */
.page-hero--full{
  min-height: calc(100svh - var(--header-h, 0px));
  min-height: calc(100vh  - var(--header-h, 0px));
  position: relative;
  z-index: 99;
}
.page-hero--main{
  min-height: calc(70svh - var(--header-h, 0px));
  min-height: calc(70vh  - var(--header-h, 0px));
  position: relative;
  z-index: 99;
}

/*Carrusel */


/* Fin Carrusel */



.page-hero--strip{
  min-height: 20svh;
  min-height: 20vh;
}

.page-hero--ticker{
  min-height: 10svh;
  min-height: 10vh;
}

/* Inner del hero (contenedor) */
.page-hero__inner{
  position: relative;
  z-index: 2;
  width: min(1180px, 100%);
  margin: 0 auto;
  padding-inline: var(--pad);
  min-width: 0;
}

/* Compatibilidad con tu typo: overlay / overlay_ */
.page-hero--overlay::before,
.page-hero--overlay_::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background: radial-gradient(1200px 600px at 50% 40%, rgba(11,92,255,.12), rgba(8,12,24,.55));
  pointer-events:none;
}
/* =========================================================
   6) Hero layout (ROBUSTO con/sin media)
   - Base: 1-col
   - Right oculto por defecto (para no romper cuando no hay media)
   - Split: por .hero--split o por :has(media)
   - Mobile: orden: [countdown] [right] [left] (tu countdown va dentro de right)
   ========================================================= */

.hero{
  display:grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
  min-height: 100%;
}

.hero__right{
  display:flex;
  justify-content: flex-end;
  overflow: visible;
}

@media (max-width: 880px){
  .hero{
    grid-template-columns: 1fr;
    gap: 24px;

    align-items: start;

    grid-template-areas:
      "media"
      "content";
  }
  .hero__right{
   flex-direction: column;    
    align-items: center;
    justify-content: flex-start;
    
  }
  .hero__left{
    grid-area: content;
  }
	
	.hero__img {
		
	}
	
}

/* Desktop: poster vertical */
.hero__float{
  /*width: min(420px, 100%);*/
  aspect-ratio: 762 / 1080;
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  background: radial-gradient(900px 600px at 30% 20%, rgba(11,92,255,.18), rgba(0,0,0,.12));
  box-shadow: 0 26px 70px rgba(0,0,0,.45);
  transform-style: preserve-3d;
  will-change: transform;
	
  z-index: 5;   /* encima del overlay */

  /* estado neutro */
  transform:
	perspective(800px)  /* antes 1100px → más profundidad */
    translate3d(0,0,0)
    rotateX(0deg)
    rotateY(0deg)
    scale(1);

  /* cuando vuelve a reposo, transición suave */
  transition:
    transform 520ms cubic-bezier(.16,.84,.26,1),
    filter 520ms cubic-bezier(.16,.84,.26,1);
}


/* Móvil */
@media (max-width: 768px){
  .hero__float{
    aspect-ratio: 940 / 450;
    width: min(520px, 100%); /* opcional */
  }
}

.hero__float.is-active{
  /* al mover: se siente más vivo, pero sin volverse loco */
  transition:
    transform 90ms linear,
    filter 180ms ease-out;
  filter: saturate(1.06) contrast(1.03);
}

/*
.hero__float::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(800px 500px at 20% 20%, rgba(11,92,255,.22), rgba(0,0,0,0));
  pointer-events:none;
  mix-blend-mode: screen;
  opacity:.85;
}
*/
@media (prefers-reduced-motion: reduce){
  .hero__float,
  .hero__float.is-active{
    transition:none;
    transform:none !important;
    filter:none !important;
  }
}

.hero__picture{
  display:inline-block;
}

.hero__img{
  width:100%;
  height:auto;
  display:block;
  object-fit: contain;   /* ✅ no recorta */
  object-position: center;
}

/*********
fin tarjeta hero
********/



/* =========================================================
   7) UI base (reutilizable)
   ========================================================= */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(var(--ma-cream-rgb), 0.07);
  color: var(--text);
  user-select: none;

  transition: transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease);

  font-size: var(--fs-element-button);
  line-height: var(--lh-element-button);
  font-weight: var(--fw-element-button);
  padding: 10px;
}
.btn:active{ transform: translateY(1px); }



.btn--primary{
  border-color: color-mix(in srgb, var(--brand) 35%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--brand) 100%, transparent),
    color-mix(in srgb, var(--brand) 70%, transparent)
  );
  box-shadow: 0 14px 40px color-mix(in srgb, var(--brand) 22%, transparent);
}

.btn--ghost{ background: rgba(var(--ma-cream-rgb), 0); border:0px; }


.btn--dark--blue{
  background: rgba(var(--ma-dark-blue-rgb), 1) !important;
  color: rgba(var(--ma-cream-rgb), 1) !important;
}
.btn--darkblue--outline{
  background-color: rgba(var(--ma-dark-blue-rgb), 0.3) !important;
  color: rgba(var(--ma-cream-rgb), 1) !important;
  border: 1px solid var(--ma-dark-blue-100) !important;
}

.btn--blue{
  background: rgba(var(--ma-blue-rgb), 1) !important;
  color: rgba(var(--ma-cream-rgb), 1) !important;
}
.btn--blue--outline{
  background-color: rgba(var(--ma-blue-rgb), 0.3) !important;
  color: rgba(var(--ma-blue-rgb), 1) !important;
  border: 1px solid var(--ma-blue-100) !important;
}

.btn--aqua{
  background: rgba(var(--ma-aqua-rgb), 1) !important;
  color: rgba(var(--ma-ink-rgb), 1) !important;
}
.btn--aqua--outline{
  background-color: rgba(var(--ma-aqua-rgb), 0.3) !important;
  color: rgba(var(--ma-aqua-rgb), 1) !important;
  border: 1px solid var(--ma-aqua-100) !important;
}

.btn--green{
  background: rgba(var(--ma-green-rgb), 1) !important;
  color: rgba(var(--ma-ink-rgb), 1) !important;
}
.btn--green--outline{
  background-color: rgba(var(--ma-green-rgb), 0.3) !important;
  color: rgba(var(--ma-green-rgb), 1) !important;
  border: 1px solid var(--ma-green-100) !important;
}

.btn--yellow{
  background: rgba(var(--ma-yellow-rgb), 1) !important;
  color: rgba(var(--ma-ink-rgb), 1) !important;
}
.btn--yellow--outline{
  background-color: rgba(var(--ma-yellow-rgb), 0.3) !important;
  color: rgba(var(--ma-yellow-rgb), 1) !important;
  border: 1px solid var(--ma-yellow-100) !important;
}

.btn--coral{
  background: rgba(var(--ma-coral-rgb), 1) !important;
  color: rgba(var(--ma-ink-rgb), 1) !important;
}
.btn--coral--outline{
  background-color: rgba(var(--ma-coral-rgb), 0.3) !important;
  color: rgba(var(--ma-coral-rgb), 1) !important;
  border: 1px solid var(--ma-coral-100) !important;
}

/* =========================================================
   Reveal hover (solo si añades .revealhover)
   - Hover y teclado (focus-visible)
   - Transición suave
   ========================================================= */

.btn.revealhover{
  transition:
    background-color .22s ease,
    color .22s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    transform .22s ease;
}

/* (opcional) micro feedback */
.btn.revealhover:hover{ transform: translateY(-1px);  transform: scale(1.15); transform-origin: center center; box-shadow: var(--shadow-2); z-index: 1; }
.btn.revealhover:active{ transform: translateY(0px); }

/* --------- Mapeo: solid -> outline por color ---------- */

/* DARK BLUE */
.btn.revealhover.btn--dark--blue:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-dark-blue-rgb), 0.3) !important;
  color: rgba(var(--ma-cream-rgb), 1) !important;
  border: 1px solid var(--ma-dark-blue-100) !important;
}

/* BLUE */
.btn.revealhover.btn--blue:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-blue-rgb), 0.3) !important;
  color: rgba(var(--ma-blue-rgb), 1) !important;
  border: 1px solid var(--ma-blue-100) !important;
}

/* AQUA */
.btn.revealhover.btn--aqua:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-aqua-rgb), 0.3) !important;
  color: rgba(var(--ma-aqua-rgb), 1) !important;
  border: 1px solid var(--ma-aqua-100) !important;
}

/* GREEN */
.btn.revealhover.btn--green:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-green-rgb), 0.3) !important;
  color: rgba(var(--ma-green-rgb), 1) !important;
  border: 1px solid var(--ma-green-100) !important;
}

/* YELLOW */
.btn.revealhover.btn--yellow:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-yellow-rgb), 0.3) !important;
  color: rgba(var(--ma-yellow-rgb), 1) !important;
  border: 1px solid var(--ma-yellow-100) !important;
}

/* CORAL */
.btn.revealhover.btn--coral:is(:hover, :focus-visible){
  background-color: rgba(var(--ma-coral-rgb), 0.3) !important;
  color: rgba(var(--ma-coral-rgb), 1) !important;
  border: 1px solid var(--ma-coral-100) !important;
}

/* PRIMARY (si quieres también “reveal” en primary) */
.btn.revealhover.btn--primary:is(:hover, :focus-visible){
  /* ejemplo: baja intensidad y deja borde más marcado */
  background: color-mix(in srgb, var(--brand) 18%, transparent);
  border-color: color-mix(in srgb, var(--brand) 55%, transparent);
  box-shadow: 0 10px 30px color-mix(in srgb, var(--brand) 16%, transparent);
}

/* GHOST (si quieres que ghost “aparezca” en hover) */
.btn.revealhover.btn--ghost:is(:hover, :focus-visible){
  background: rgba(var(--ma-cream-rgb), .06);
}

.btn-100{ width: 100% !important; }
.btn--xxl{ width: 100px !important; height: 100px !important; }
.btn--xl { width: 60px !important;  height: 60px !important; }
.btn--lg { width: 44px !important;  height: 44px !important; }
.btn--md { width: 34px !important;  height: 34px !important; border-radius: 12px !important; }
.btn--sm { width: 16px !important;  height: 16px !important; border-radius: 6px !important; }

.btn--w-auto {width: inherit !important; padding: 15px;}

.btn.is-disabled{ opacity:.6; cursor:default; pointer-events:none; }

.icon-btn{
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(var(--ma-cream-rgb), 0.06); /* FIX */
  transition: transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease);
  padding: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.icon-btn svg{
  width: 22px;
  height: 22px;
  padding: 0;
}

.icon-btn:active{ transform: translateY(1px); }
.icon-btn--share{ justify-self: end; }

.icon--btn-left{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.icon--btn-left .btn__icon{
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
}
/*
.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;

  padding: 10px 12px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(var(--ma-cream-rgb), 0.06);
  color: var(--text);

  white-space: nowrap;
  font-size: var(--fs-element-body);
  line-height: var(--lh-element-body);
  font-weight: var(--fw-element-body);
}
*/
.chip {
    display: inline-flex;
    align-items: center;
    height: 26px;
    padding: 15px;
    border-radius: var(--r-md);
    font-size: var(--fs-element-badge);
    font-weight: var(--fw-element-badge);
	line-height: var(--lh-element-body);
    letter-spacing: .02em;
    border: 1px solid var(--border);
    background: rgba(var(--ma-cream-rgb), 0.06);
}


/* =========================================================
   7.1) UI Primitives: Divider + Badge
   - FIX: badge duplicado => una única definición
   ========================================================= */
.badge{
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  color: white;
  letter-spacing: .2px;
  white-space: nowrap;
  left: 12px;
  top: 12px;
  padding: 10px 12px;
  border-radius: var(--r-md);
  font-size: var(--fs-element-badge);
  line-height: var(--lh-element-badge);
  font-weight: var(--fw-element-badge);
  border: 1px solid var(--border);
  background: rgba(var(--ma-ink-rgb), 0.35);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
  backdrop-filter: blur(12px) saturate(1.1);
  text-transform: uppercase;
}

/* Badge de estado/colores semánticos */
.badge--brand{
  --badge-bg: color-mix(in srgb, var(--brand) 18%, transparent);
  --badge-bd: color-mix(in srgb, var(--brand) 35%, transparent);
}
.badge--ok{
  --badge-bg: rgba(34,197,94,.16);
  --badge-bd: rgba(34,197,94,.30);
}
.badge--warn{
  --badge-bg: rgba(var(--ma-yellow-rgb), .18);
  --badge-bd: rgba(var(--ma-yellow-rgb), .35);
  --badge-fg: rgba(var(--ma-yellow-rgb), 1);
}
.badge--danger{
  --badge-bg: rgba(255,80,80,.16);
  --badge-bd: rgba(255,80,80,.30);
}

.badge--green{
  --badge-bg: rgba(var(--ma-green-rgb), .18);
  --badge-bd: rgba(var(--ma-green-rgb), .35);
  --badge-fg: rgba(var(--ma-green-rgb), 1);
}



/* Badge compacto */
.badge--sm{
  padding: 5px 8px;
  font-size: 11px;
}

/* Icono opcional dentro de badge */
.badge__dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  opacity: .9;
}

.badge--soldout,
.badge--cancelled{
  left: 50%;
  top: 50%;
  transform: translateX(-50%) rotate(-15deg);
  width: max-content;
  border-color: var(--warning);
  background: var(--ma-danger);
  font-size: var(--fs-section-title);
  font-weight: var(--font-weight-extrabold);
}

/* =========================================================
   Badges (originales)
   ========================================================= 
.badge{
  left: 12px;
  top: 12px;
  padding: 10px 12px;
  border-radius: var(--r-md);
  font-size: var(--fs-element-badge);
  line-height: var(--lh-element-badge);
  font-weight: var(--fw-element-badge);
  border: 1px solid var(--border);
  background: rgba(var(--ma-ink-rgb), 0.35);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
  backdrop-filter: blur(12px) saturate(1.1);
  text-transform: uppercase;
}

.badge--soldout,
.badge--cancelled{
  left: 50%;
  top: 50%;
  transform: translateX(-50%) rotate(-15deg);
  width: max-content;
  border-color: var(--warning);
  background: var(--ma-danger);
  font-size: var(--fs-section-title);
  font-weight: var(--font-weight-extrabold);
}

*/

.side-divider{
  height: 1px;
  background: rgba(255,255,255,.10);
  margin: 12px 0;
}


.divider{
  

  border: 0;
  height: var(--divider-size);
  background: var(--divider-color);
  margin: var(--divider-gap) 0;
  opacity: .95;
}

/* Variante “suave” */
.divider--soft{
  --divider-color: rgba(255,255,255,.08);
  opacity: .9;
}

/* Variante “strong” */
.divider--strong{
  --divider-color: rgba(255,255,255,.16);
  opacity: 1;
}

/* Divider con texto centrado */
.divider--label{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
  background: transparent;
  height: auto;
  margin: var(--divider-gap) 0;
}
.divider--label::before,
.divider--label::after{
  content:"";
  height: var(--divider-size);
  background: var(--divider-color);
}
.divider__text{
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}

/* Divider vertical (para toolbar/acciones inline) */
.divider--v{
  display: inline-block;
  width: var(--divider-size);
  height: 1.2em;
  background: var(--divider-color);
  margin: 0 10px;
  vertical-align: middle;
}


/* =========================================================
   8) Sheets / Modals (CSS-only :target)
   ========================================================= */
.sheet, .modal{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-2) var(--ease);
  z-index: 9500;
}

.sheet:target, .modal:target{
  opacity: 1;
  pointer-events: auto;
}

.sheet__backdrop, .modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(var(--ma-ink-rgb), 0.55);
  backdrop-filter: blur(6px);
}

.sheet__panel, .modal__panel{
  width: min(var(--container), calc(100vw - 24px));
  margin: 12px;
  border-radius: 18px 18px 0 0;
  border: 1px solid var(--border);
  position: relative;
  z-index: 1;

  background: rgba(var(--ma-ink-rgb), .5);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  box-shadow: 0 18px 42px rgba(0,0,0,.35);

  max-height: calc(100vh - 24px);
  overflow: auto;
}

.sheet__head, .modal__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 16px var(--pad);
  border-bottom: 1px solid var(--border);
}

.sheet__head h2, .modal__head h2{
  margin: 0;
  font-size: var(--fs-section-subtitle);
  line-height: var(--lh-section-subtitle);
  font-weight: var(--fw-section-subtitle);
}

.sheet__body, .modal__body{ padding: 14px var(--pad) 18px; }
.sheet__footer, .modal__footer{
  padding: 12px var(--pad) 16px;
  border-top: 1px solid var(--border);
}

@media (min-width: 900px){
  .modal{ place-items: center; }
  .modal__panel{
    border-radius: 18px;
    max-width: 520px;
  }
}


/* =========================================================
   9) Event info (bloque del hero)
   - Mantener modo (A): “tarjeta centrada” en 1-col
   - FIX: container-type solo donde lo necesitas
   ========================================================= */

/* En desktop lo quieres centrado tipo “tarjeta” */
.event-info__content{
  container-type: inline-size;
  left: 0; right: 0;
  z-index: 2;
  width: 100%;
  margin: 0;
  min-width: 0;
}

.event-info__content.event-sales{
	display:grid;
    grid-template-columns: minmax(0, 1fr) ; 
    align-items: center;
	gap: 25px;
  }

.event-info__row{
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  border-bottom: 1px solid rgba(var(--ma-blue-rgb), 1);
  padding-bottom: 25px;

  min-width: 0;
}



.event-info__date-block{
  display: grid;
  grid-auto-rows: min-content;
  justify-items: center;
  padding: 10px 2px;
  border-radius: 14px;
  min-width: 86px;
  aspect-ratio: 1 / 1;
  align-content: center;
}

.event-info__date-month{
  font-size: 12px;
  letter-spacing: .12em;
  opacity: .9;
}
.event-info__date-day{
  font-size: 30px;
  line-height: 1;
  font-weight: 700;
  margin-top: 2px;
}

.event-info__content.event-sales .event-info__date-day{
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  margin-top: 2px;
}

.event-info__date-year{
  font-size: 12px;
  opacity: .85;
  margin-top: 2px;
}

.event-info__text-block{ min-width: 0; }

.event-info__text-meta-line{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 14px;
  opacity: .95;
  margin-bottom: 0;
  color: rgba(var(--ma-aqua-rgb), 1);
}
.event-info__text-meta-line .sep{ opacity: .7; }

.event-info__tex-title{
  margin: 0;
  font-size: clamp(28px, 6vw, 48px);
  line-height: 1.05;
  min-width: 0;
}

.event-info__content.event-sales .event-info__tex-title {
	font-size: clamp(19px, 4vw, 32px);
}

.event-info__tex-sub{
  margin: 0;
  font-size: 14px;
  opacity: .9;
}

.event-info__actions-block{
  display: flex;
  flex-direction: column;
  gap: 12px;              /* separación vertical entre iconos y CTAs */
  align-items: stretch;
}

.event-media-block {
	border-radius: var(--r-md);
}

.event-media-block img{
	width: 100% !important;
	padding: 20px 0px 20px 0px;
	
}


/* Iconos: pueden envolver en varias filas */
.actions-icons{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  row-gap: 12px;          /* separación vertical cuando saltan de línea */
}

/* CTAs: móvil en columna (Entradas arriba, Info debajo) */
.actions-ctas{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;              /* separación vertical entre Entradas e Info */
}
.actions-ctas .btn{
  width: 100%;
}

.event-info__row.event-sales .actions-ctas{
  	grid-template-columns: 1fr 1fr;
  }


/* Container queries: cuando estrecha, los CTAs saltan abajo y se hacen “grid” */
@container (max-width: 820px){
  .event-info__row{
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
  }
	
 .event-info__row.event-sales{
  grid-template-columns: auto minmax(0, 1fr);

}
	


	
	
  .event-info__actions-block{
    grid-column: 1 / -1;
    margin-top: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    justify-content: start;
  }
	


  .event-info__actions-block .btn{
    width: 100%;
    white-space: nowrap;
  }
	
}

/* Desktop: acciones a la derecha en fila */
@media (min-width: 821px){
	
	.event-info__content.event-sales {
    display: grid;
    grid-template-columns: auto minmax(0px, 1fr);
    align-items: center;
    gap: 25px;
}

	.event-media-block{
  height: 20svh;
  height: 20vh;
}
	
	.event-media-block img{
		height: 100% !important;
	}
	.event-info__row.event-sales{
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
	padding:0px 0px 25px 0px !important;
	margin: 0px !important;

}

.event-info__row.event-sales img{
	padding: 25px 0px 25px 0px !important;

}
	
  .event-info__actions-block{
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    justify-self: end;
    gap: 12px;
    margin-top: 0;
  }
	
	.event-info__row.event-sales  .event-info__actions-block{
		margin: 0px !important;
	}
	.actions-ctas{
    grid-template-columns: 1fr 1fr;
  }
	
.event-info__row.event-sales .actions-ctas{
  	grid-template-columns: 1fr;
  }
	
	
  .event-info__actions-block .btn{
    width: auto;
  }
	
  
	
	
}

/* Móvil “real”: vuelve al flujo (y deja de ser tarjeta estrecha) */
@media (max-width: 880px){
  .event-info__content{
    position: static;
    left:auto; right:auto; bottom:auto;
    width: 100% !important;
    margin: 0;
  }
	
  
	
}



/*APPLE*/
/* =========================================================
   HERO HEADING (consolidado)
   ========================================================= */

/* Layout container */
.hero-heading-content{
  margin-inline: auto;
  width: 980px;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 35px;

  /* baja ambos bloques (headline + ctas) a la base */
  align-items: flex-end;
}

@media (min-width: 1441px){
  .hero-heading-content{
    margin-inline: auto;
    width: 980px;
  }
}

/* Left block */
.hero-heading-headline-container{
  flex-grow: 1;
	
}

/* Top row: icon button + “Programación” */
.hero-heading-headline-top{
  display: flex;
  align-items: center;  /* centra verticalmente */
  gap: 12px;
  margin-bottom: 10px;
}

.hero-heading-headline-top h2{
  margin: 0;
  position: static;
  display: inline;
}

/* Typography */
.typography-heading-headline{
  font-size: 17px;
  line-height: 1.1764805882;
  font-weight: 600;
  letter-spacing: -0.037em;
  color: var(--ma-ink);
}

.hero-heading-headline-bottom{
  margin-bottom: 0;
}

.typography-heading-subheadline{
  margin: 0;
  font-size: 40px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0;
  color: var(--ma-ink);
}

/* Responsive BR toggles (tal cual) */
br.large{ display: block; }
br.medium{ display: none; }
br.small{ display: none; }

/* =========================================================
   CTA block (right)
   ========================================================= */

.hero-heading-cta-container{
    margin-top: 20px;
}
@media (min-width: 1069px){
  .hero-heading-cta-container{
   /* padding-bottom: 7px;*/
    margin-top: 20px;
  }

  .hero-heading-cta-container a.button,
  .hero-heading-cta-container button{
    font-size: 17px;
    line-height: 1.1764805882;
    font-weight: 500;
    letter-spacing: -0.022em;
    font-family: SF Pro Text, SF Pro Icons, Helvetica Neue, Helvetica, Arial, sans-serif;
    min-width: 26px;
    padding: 12px 22px;
  }
}

@media only screen and (max-width: 1068px) {
    .hero-heading-content {
        display: block;
    }
}
@media only screen and (max-width: 734px) {
    .hero-heading-content {
        margin-bottom: 13px;
    }
}
@media only screen and (max-width: 1068px) {
    .hero-heading-content {
        margin-bottom: 23px;
    }
}
@media only screen and (max-width: 734px) {
    .hero-heading-content {
        margin-left: auto;
        margin-right: auto;
        width: 87.5%;
    }
}
@media only screen and (max-width: 1068px) {
    .hero-heading-content {
        margin-left: auto;
        margin-right: auto;
        width: 100%;
	    padding-inline: var(--pad);
    }
}


@media only screen and (max-width: 734px) {
    .typography-heading-subheadline {
        font-size: 24px;
        line-height: 1.16667;
        font-weight: 700;
        letter-spacing: 0.022em;
        font-family: "SF Pro Display", "SF Pro Icons", "Helvetica Neue", Helvetica, Arial, sans-serif;
    }
}

@media only screen and (max-width: 1068px) {
    .typography-heading-subheadline {
        font-size: 30px;
        line-height: 1;
        font-weight: 700;
        letter-spacing: 0em;
        font-family: "SF Pro Display", "SF Pro Icons", "Helvetica Neue", Helvetica, Arial, sans-serif;
    }
}

.hero-heading-cta-container a.button:first-of-type,
.hero-heading-cta-container button:first-of-type{
  margin-right: 10px;
}

.hero-heading-cta-container a.button,
.hero-heading-cta-container button{
  font-weight: 500;
}

/* Link base */
a:link,
a:visited{
  text-decoration: none;
}

/* Buttons */
.button{
  cursor: pointer;
  display: inline-block;
  text-align: center;
  white-space: nowrap;
  font-size: 17px;
  line-height: 1.1764805882;
  font-weight: 400;
  letter-spacing: -0.022em;
  font-family: SF Pro Text, SF Pro Icons, Helvetica Neue, Helvetica, Arial, sans-serif;
  min-width: 28px;
  padding: 8px 16px;
  border-radius: 980px;
  background: #0071e3;
  color: #fff;
}

.button-neutral{
  background: #1d1d1f;
  color: #fff;
}

/* Secondary CTA link */
.hero-heading-cta-container a.icon-wrapper{
  color: var(--ma-ink);
  text-decoration: none;
}

.hero-heading-cta-container .hero-heading-cta-link{
  font-weight: 500;
  margin-left: 17px;
}

.scalehover{
transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.scalehover:hover{
  transform: translateY(-20px);
  transform: scale(1.15);
  transform-origin: center center;
  border-color: rgba(var(--ma-aqua-rgb),.6);
  box-shadow: var(--shadow-2);
  z-index: 1;
}

.scalehover.minizoom:hover{
  transform: translateY(-20px);
  transform: scale(1.03);
  transform-origin: center center;
  border-color: rgba(var(--ma-aqua-rgb),.6);
  box-shadow: var(--shadow-1);
  z-index: 1;
}


/* =========================================================
   Scroll Cue — bottom del contenedor padre El contenedor donde lo metas (ej: hero) debe tener: position: relative;
   ========================================================= */

.scroll-cue-wrapper{
  display: flex;
  justify-content: center;
  margin-top: 50px;
  z-index: 10;
}

.scroll-cue-wrapper a{
  display: inline-flex;
  text-decoration: none;
}
/* Contenido */
.scroll-cue{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;

  color: rgba(234,240,255,.88);
  text-align: center;

  user-select: none;
  -webkit-user-select: none;
}

/* SVG */
.scroll-cue__svg{
  display: block;
  width: 44px;
  height: 64px;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.25));
}

/* Texto */
.scroll-cue__label{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .85;
}

@media (prefers-reduced-motion: reduce){
  .scroll-cue__svg animate{
    display: none;
  }
}

/*************************************
/* Click Zoom (modal imagen) */
/*************************************/
.cz { position: fixed; inset: 0; z-index: 9999; display: none; }
.cz.is-open { display: block; }

.cz__backdrop{
  position: absolute; inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
}

.cz__panel{
  position: absolute; inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  outline: none;
}

.cz__img{
  max-height: 70vh;
  max-width: 92vw;
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
  background: rgba(255,255,255,.04);
}

.cz__close{
  position: absolute;
  top: 14px; right: 14px;
  width: 42px; height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.cz__caption{
  margin-top: 10px;
  max-width: min(92vw, 900px);
  color: rgba(255,255,255,.85);
  font-size: 14px;
  text-align: center;
}

/* lock scroll */
.cz-lock { overflow: hidden; }

/* Forzar cursor tipo “manita” en elementos con zoom */
.click-zoom,
img.click-zoom,
.click-zoom img {
  cursor: pointer;
}

/* Opcional: efecto visual sutil al hover */
.click-zoom img,
img.click-zoom {
  transition: transform .2s ease, filter .2s ease;
}

.click-zoom:hover img,
img.click-zoom:hover {
  transform: scale(1.02);
  filter: brightness(1.05);
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .cz__backdrop{ backdrop-filter: none; }
}


/* =========================================================
   HOME — alturas fijas (main/strip/ticker) sin crecer por contenido
   ========================================================= */

.page-split { gap: 0; }

/* Base: que el hero NO crezca por contenido */
.page-hero--main,
.page-hero--strip,
.page-hero--ticker{
  overflow: hidden;      /* clave */
}

/* Alturas fijas */
.page-hero--main{
  height: calc(75vh - var(--header-h, 0px));
  min-height: 0 !important;
  max-height: none !important;
}
@supports (height: 1svh){
  .page-hero--main{
    height: calc(75svh - var(--header-h, 0px));
  }
}

.page-hero--strip{
  height: 20vh;
  min-height: 0 !important;
  max-height: none !important;
}
@supports (height: 1svh){
  .page-hero--strip{ height: 20svh; }
}

.page-hero--ticker{
  height: 5vh;
  min-height: 0 !important;
  max-height: none !important;
}
@supports (height: 1svh){
  .page-hero--ticker{ height: 5svh; }
}

/* Importante: el inner y el contenido deben ocupar el alto disponible */
.page-hero__inner{ height: 100%; }
.page-hero--main .ParallaxBlock__content{ height: 100%; }
.page-hero--main .page-hero__inner{ height: 100%; }
.page-hero--main .hero-slider,
.page-hero--main .hero-slider__viewport,
.page-hero--main .hero-slider__track,
.page-hero--main .hero-slide{
  height: 100%;
}

/* El grid del hero que estire a alto completo */
.page-hero--main .hero{
  height: 100%;
  min-height: 0;
  align-items: center;
}

/* La columna derecha no debe forzar altura extra */
.page-hero--main .hero__right{
  min-height: 0;
  align-self: stretch;
  display: flex;
  justify-content: flex-end;
  align-items: center;
	padding: 25px 0 25px 0;
}

/* La tarjeta (poster) se limita al alto del hero */
.page-hero--main .hero__float{
  max-height: 100%;
}
.page-hero--main .hero__img{
  height: 100%;
  object-fit: cover; /* o contain si lo prefieres, pero cover suele encajar mejor con height:100% */
}


/***** MARQUE NEW*/
/* Ticker de noticias (solo texto) */
.marquee-news{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  white-space: nowrap;
}

.marquee-news__item{
  display: inline-block;
  text-decoration: none;
  font-weight: 650;
  letter-spacing: .2px;
  line-height: 1.2;

  /* hereda colores del contenedor; así lo controlas desde la sección */
  color: inherit;
  opacity: .95;
}

.marquee-news__item:hover{
  text-decoration: underline;
  opacity: 1;
}

.marquee-news__sep{
  opacity: .55;
}

.marquee-news__item.is-muted{
  opacity: .7;
}

/* Centrado vertical del ticker */
.page-hero--ticker .page-hero__inner{
  display: flex;
  align-items: center;
  height: 100%;
}


/* TEMP: fuerza dark aunque el SO esté en light */
:root{
  color-scheme: dark;
  --bg-base: #070A14;
  --text: rgba(234,240,255,.92);
  --muted: rgba(234,240,255,.70);
  --border: rgba(255,255,255,.12);
  --surface-2: rgba(255,255,255,.06);
  --ma-relleno-cristal: rgba(8,12,24,.45);
}