.elementor-16253 .elementor-element.elementor-element-62a3f4b{--display:flex;--min-height:100vh;--justify-content:space-evenly;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16253 .elementor-element.elementor-element-71c5d98{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-71c5d98 */@font-face {
  src: url("https://fonts.cdnfonts.com/css/pp-neue-montreal") format("woff2");
  font-family: "PP Neue Montreal", sans-serif;
  font-weight: 400;
}

*,
*:before,
*:after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}



/* ===== Base global responsive ===== */
:root{
  /* Ajusta el tamaño base de todo el sitio de forma fluida */
  --fs-base: clamp(0.95rem, 0.6vi + 0.85rem, 1.125rem);
  --gap-1: clamp(6px, 1vi, 12px);
  --gap-2: clamp(10px, 1.5vi, 20px);
  --pad-hero: clamp(12px, 6vi, 32px);
  --header-bg: transparent;
  --noise-opacity: 0.6;
}

html{ font-size: 100%; }

body{
  /* Tipografía y legibilidad */
  font-family: "PP Neue Montreal", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 700;
  font-size: var(--fs-base);
  letter-spacing: -0.02em;
  text-transform: uppercase;
  line-height: 1.2;

  /* Render */
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

  /* Layout */
  position: relative;
  min-height: 100svh;
  background: #000;
  color: #fff;
  overflow-x: hidden; /* si tu preloader bloquea el scroll; quítalo si necesitas scroll */
}

/* ===== Background noise effect (optimizado + accesible) ===== */
body::before{
  content: "";
  position: fixed;
  inset: -50%;
  width: 200%;
  height: 200%;
  z-index: 100;
  pointer-events: none;
  opacity: var(--noise-opacity);

  /* Usa image-set para mejores formatos cuando existan */
  background:
    transparent
    image-set(
      url("https://assets.iceable.com/img/noise-transparent.png") type("image/png"),
      url("https://assets.iceable.com/img/noise-transparent.png") 1x
    ) repeat 0 0;
  background-size: 300px 300px;

  animation: noise-animation 0.3s steps(5) infinite;
  will-change: transform;
}

@keyframes noise-animation{
  0%   { transform: translate(0, 0); }
  10%  { transform: translate(-2%, -3%); }
  20%  { transform: translate(-4%, 2%); }
  30%  { transform: translate(2%, -4%); }
  40%  { transform: translate(-2%, 5%); }
  50%  { transform: translate(-4%, 2%); }
  60%  { transform: translate(3%, 0); }
  70%  { transform: translate(0, 3%); }
  80%  { transform: translate(-3%, 0); }
  90%  { transform: translate(2%, 2%); }
  100% { transform: translate(1%, 0); }
}

/* Respeta preferencias de usuario */
@media (prefers-reduced-motion: reduce){
  body::before{ animation: none !important; }
}
@media (prefers-reduced-transparency: reduce){
  :root{ --noise-opacity: 0.25; }
}

/* ===== Header Navigation responsive ===== */
.header{
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;

  /* Safe areas + padding fluido */
  padding-inline: max(env(safe-area-inset-left, 0px), var(--pad-hero))
                  max(env(safe-area-inset-right, 0px), var(--pad-hero));
  padding-block: clamp(8px, 2vi, 20px);

  display: grid;
  grid-template-columns: 1fr auto; /* logo | acciones */
  align-items: start;
  gap: var(--gap-2);

  background: var(--header-bg); /* deja transparente o aplica blur si quieres */
  z-index: 10003;
  opacity: 0; /* si lo animas con GSAP */
  container-type: inline-size; /* habilita container queries locales */
}

/* Logo */
.logo-left{
  color: #fff;
  font-size: clamp(1.125rem, 1.2vi + 1rem, 1.8rem);
  position: relative;
  display: inline-block;
  line-height: 1;
  padding-bottom: 30px;
}

/* Navegación central: en móvil se apila, en desktop va en fila */
.nav-center{
  grid-column: 1 / -1;                 /* ocupa todo el ancho bajo el logo en móvil */
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--gap-1);
  font-size: clamp(1rem, 1vi + 0.9rem, 1.4rem);
  line-height: 1.1;
}

.nav-center ul{
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: clamp(2px, 0.5vi, 6px);
  padding: 0;
  margin: 0;
  align-items: flex-start;
}

.nav-center li{
  font-size: clamp(1rem, 1.2vi + 0.8rem, 1.6rem);
  position: relative;
  cursor: pointer;
  color: #fff;
  padding: 0.1em 0.15em;               /* zona táctil mínima */
  display: inline-block;
  z-index: 1;
  opacity: 0;                           /* si animas entrada */
  transform: translateY(10px);          /* si animas entrada */
  touch-action: manipulation;
}

/* Subrayado de expansión (hover/teclado) */
.nav-center li::after{
  content: "";
  position: absolute;
  inset: 0 0 0 0;
  width: 0;
  height: 100%;
  background-color: #fff;
  z-index: -1;
  transition: width 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Estados de interacción accesibles */
@media (hover: hover){
  .nav-center li:hover::after{ width: 100%; }
  .nav-center li:hover{
    color: #000;
    mix-blend-mode: difference;
  }
}
.nav-center li:focus-visible{
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Acciones derecha */
.nav-right{
  justify-self: end;
  font-size: clamp(1rem, 1vi + 0.9rem, 1.4rem);
  opacity: 0; /* si animas entrada */
  position: relative;
  cursor: pointer;
  display: inline-block;
  z-index: 1;
  padding: 0.1em 0.2em;
}

.nav-right::after{
  content: "";
  position: absolute;
  inset: 0;
  width: 0;
  height: 100%;
  background-color: #fff;
  z-index: -1;
  transition: width 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@media (hover: hover){
  .nav-right:hover::after{ width: 100%; }
  .nav-right:hover{
    color: #000;
    mix-blend-mode: difference;
  }
}
.nav-right:focus-visible{
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* ===== Layout en viewports medios/grandes ===== */
@container (min-width: 720px){
  .header{
    grid-template-columns: auto 1fr auto; /* logo | nav | derecha */
    align-items: center;
  }
  .nav-center{
    grid-column: 2 / 3;
    flex-direction: row;
    align-items: center;
  }
  .nav-center ul{
    flex-direction: row;
    align-items: center;
    gap: clamp(8px, 2vi, 20px);
  }
}

/* Ultra ancho: limita tracking y exageraciones */
@media (min-width: 1600px){
  .nav-center li{ letter-spacing: -0.015em; }
}

/* Safe areas para iOS/Android */
:root{
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
}
.header{
  padding-top: calc(var(--safe-top) + clamp(8px, 2vi, 20px));
  padding-left: max(var(--safe-left), var(--pad-hero));
  padding-right: max(var(--safe-right), var(--pad-hero));
}


/* === Preloader full-screen responsive === */
.preloader{
  position: fixed;
  inset: 0;                       /* top/right/bottom/left: 0 */
  z-index: 9999;
  background: #000;
  
  

  /* Centro con grid, bloquea interacción detrás */
  display: grid;
  place-items: center;
  pointer-events: all;

  /* Evita “salto” por barras de navegador móvil */
  height: 100svh;
}

@supports (height: 100dvh){
  .preloader{ height: 100dvh; }   /* preferible en navegadores modernos */
}

/* Contenido centrado y escalable */
.preloader-content{
  position: relative;
  inline-size: 100%;
  block-size: 100%;
  display: grid;
  place-items: center;
  padding: clamp(8px, 2vi, 24px);
}

/* === Imagen principal escalable === */
.image-container{
  position: relative;

  /* Mantén la proporción original 400x500 = 4/5 */
  aspect-ratio: 4 / 5;

  /* Escalado fluido con límites */
  inline-size: clamp(220px, 48vi, 520px);
  max-inline-size: 90vw;

  overflow: hidden;
  border-radius: clamp(8px, 1vi, 16px); /* opcional, quita si no quieres radios */
}

.image-wrapper{
  position: absolute;
  inset: 0;
  visibility: hidden;    
  /* se hace visible al cargar/animar */
}

#image-100{ z-index: 10; }        /* frame final por encima */

.image-wrapper img{
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  display: block;
}

/* === Porcentaje grande y accesible === */
.preloader-percentage{
  position: absolute;

  /* Safe areas (notch) + separación fluida */
  inset-block-end: max(env(safe-area-inset-bottom, 0px), clamp(12px, 3vi, 40px));
  inset-inline-start: max(env(safe-area-inset-left, 0px), clamp(12px, 3vi, 40px));

  /* Tamaño fluido: móvil → desktop */
  font-size: clamp(2.5rem, 12vw, 10rem);
  line-height: 1;
  color: #fff;

  /* Mejor alineación numérica */
  font-variant-numeric: tabular-nums lining-nums;
  letter-spacing: -0.02em;

  /* Evita reflow brusco en animaciones rápidas */
  will-change: transform, opacity;
}

/* === Alturas pequeñas (móvil apaisado/split view) === */
@media (max-height: 560px){
  .image-container{
    inline-size: clamp(200px, 36vi, 420px);
  }
  .preloader-percentage{
    font-size: clamp(2rem, 10vw, 6rem);
  }
}

/* === Viewports muy anchos: limita la caja para legibilidad === */
@media (min-width: 1600px){
  .image-container{ inline-size: 560px; } /* tope razonable */
}

/* === Reduce Motion === */
@media (prefers-reduced-motion: reduce){
  .preloader,
  .preloader-content,
  .image-wrapper,
  .preloader-percentage{
    transition: none !important;
    animation: none !important;
  }
}

/* === Tema por variables (opcional) === */
:root{
  --preloader-bg: #000;
}
.preloader{ background: var(--preloader-bg, #000); }


/* El wrapper debe ser relativo (ej: .hero, .preloader, etc.) */
.wrapper {
  position: relative;
  container-type: inline-size; /* habilita container queries modernas */
}

/* === Text Lines (Preloader & Final) – responsive === */
:is(.text-container, .text-container-final){
  position: absolute;

  /* Anclaje lateral derecho con safe-area */
  inset-inline-end: max(env(safe-area-inset-right, 016px), clamp(12px, 3vi, 40px));

  /* Centro vertical real con translate */
  inset-block-start: 50%;
  transform: translateY(-50%);

  z-index: 10001;

  /* Alineación según escritura (LTR→derecha, RTL→izq) */
  text-align: end;

  /* Ancho máximo fluido que nunca rompe */
  max-inline-size: clamp(260px, 38vi, 520px);

  /* Evita cortes raros */
  text-wrap: balance;
  overflow-wrap: anywhere;
  hyphens: auto;

  /* Opcional: separación del borde en pantallas ultra estrechas */
  padding-inline: 0;
}

/* Línea de texto reutilizable (preloader + final) */
:is(.text-line, .text-line-final){
  opacity: 0;                    /* ideal si animas con GSAP */
  padding-block: 0.3em;
  color: #4f4f4f;

  /* Tipografía: usa tu font, con fallback seguro */
  font-family: "PP Neue Montreal", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;

  /* Tamaño fluido: móvil → desktop */
  font-size: clamp(0.95rem, 1.2vi + 0.5rem, 1.6rem);
  line-height: 1.25;

  text-transform: uppercase;
  letter-spacing: -0.02em;
}

/* Alturas pequeñas (móvil en landscape, split view, etc.) */
@media (max-height: 560px){
  :is(.text-container, .text-container-final){
    inset-inline-end: max(env(safe-area-inset-right, 40px), clamp(8px, 2vi, 20px));
  }
  :is(.text-line, .text-line-final){
    font-size: clamp(0.9rem, 1vi + 0.45rem, 1.3rem);
  }
}

/* Viewports muy anchos: limita ancho para legibilidad */
@media (min-width: 1600px){
  :is(.text-container, .text-container-final){
    max-inline-size: 44ch;
  }
}

/* Fallback para navegadores sin container queries (muy antiguos) */
@media (max-width: 480px){
  :is(.text-container, .text-container-final){
    max-inline-size: min(88vw, 480px);
    inset-inline-end: max(env(safe-area-inset-right, 0px), 16px);
  }
}

/* Respeto a usuarios con reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  :is(.text-line, .text-line-final){
    opacity: 1 !important;
    transform: none !important;
  }
}

/* Soporte adicional para notch en iOS/Android (opcional) */
:root{
  --safe-right: env(safe-area-inset-right, 0px);
}


/* Asegúrate de que el contenedor del hero tenga position: relative */
.hero {
  position: relative;
  container-type: inline-size; /* habilita container queries modernas */
}

/* === Big Title responsive === */
.big-title{
  position: absolute;

  /* Anclajes responsivos con unidades lógicas y safe-areas */
  inset-block-end: clamp(12px, 3vi, 40px);       /* bottom */
  inset-inline-start: clamp(12px, 3vi, 40px);    /* left */

  z-index: 10001;
  opacity: 0; /* si lo animas con GSAP */
  text-align: start;

  /* Tipografía fluida */
  font-size: clamp(2.2rem, 8vw + 0.25rem, 14rem);
  line-height: 0.9;

  /* Legibilidad y control de corte */
  max-width: min(22ch, 100% - clamp(24px, 6vi, 80px));
  text-wrap: balance;
  overflow-wrap: anywhere;

  /* Tema por variable (opcional) con fallback */
  color: var(--hero-title-color, #e11d48); /* rojo tailwind-like */
}

/* Estructura de líneas animables */
.big-title .title-line{
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.big-title .title-line span{
  display: block;
  transform: translateY(100%);
  opacity: 0;
}

/* --- Fallback si no hay container queries --- */
@media (max-width: 480px) {
  .big-title{
    font-size: clamp(1.8rem, 8.5vw, 3rem);
    max-width: 90%;
  }
}

/* Alturas muy pequeñas (p.ej. móviles landscape) */
@media (max-height: 560px) {
  .big-title{
    font-size: clamp(1.6rem, 6.5vw, 2.6rem);
    inset-block-end: clamp(8px, 2vi, 20px);
  }
}

/* Pantallas XXL: evita desbordar */
@media (min-width: 1600px) {
  .big-title{
    max-width: 24ch;
  }
}

/* Respeto a usuarios con reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  .big-title .title-line span{
    transform: none !important;
    opacity: 1 !important;
  }
  .big-title{ opacity: 1 !important; }
}

/* Soporte para notch (iOS/Android) */
:root{
  --safe-left: env(safe-area-inset-left, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}
.big-title{
  inset-inline-start: max(var(--safe-left), clamp(12px, 3vi, 40px));
  inset-block-end:  max(var(--safe-bottom), clamp(12px, 3vi, 40px));
}


/* ===== Restart Button — responsive & accesible ===== */
.restart-btn{
  /* Dimensiones fluidas con mínimo táctil (44px) */
  --btn-size: clamp(44px, 8vi, 72px);
  --dot-size: clamp(4px, 0.9vi, 8px);
  --inset: max(env(safe-area-inset-bottom, 0px), clamp(10px, 3vi, 24px));
  --inset-x: max(env(safe-area-inset-right, 0px), clamp(10px, 3vi, 24px));

  position: fixed;
  inset-block-end: var(--inset);
  inset-inline-end: var(--inset-x);

  inline-size: var(--btn-size);
  block-size: var(--btn-size);
  aspect-ratio: 1;

  display: grid;
  place-items: center;

  border: none;
  background: color-mix(in oklab, #ffffff 6%, transparent);
  backdrop-filter: blur(6px);
  border-radius: 9999px;
  cursor: pointer;
  z-index: 10002;
  padding: 0;
  opacity: 0;                 /* si lo animas con GSAP */
  touch-action: manipulation;

  /* Estados accesibles */
  outline: none;
}
.restart-btn:focus-visible{
  box-shadow: 0 0 0 3px #fff, 0 0 0 6px #000;
}

/* Mejora hover solo en dispositivos con puntero fino (evita “pegajosidad” en móvil) */
@media (hover: hover){
  .restart-btn:hover{
    background: color-mix(in oklab, #ffffff 12%, transparent);
  }
}

/* Contenedor interno para posicionar los dots */
.dot-container{
  position: relative;
  inline-size: 100%;
  block-size: 100%;
}

/* Dots escalables */
.dot{
  position: absolute;
  inline-size: var(--dot-size);
  block-size: var(--dot-size);
  border-radius: 50%;
  background: #fff;
}

/* Anclajes relativos al borde con separación fluida */
:root{
  --dot-gap: clamp(8px, 1.6vi, 14px);   /* separación a borde */
}

/* 4 dots cardinales */
.dot:nth-child(1){ /* top-center */
  inset-block-start: var(--dot-gap);
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
.dot:nth-child(2){ /* middle-right */
  inset-block-start: 50%;
  inset-inline-end: var(--dot-gap);
  transform: translateY(-50%);
}
.dot:nth-child(3){ /* bottom-center */
  inset-block-end: var(--dot-gap);
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
.dot:nth-child(4){ /* middle-left */
  inset-block-start: 50%;
  inset-inline-start: var(--dot-gap);
  transform: translateY(-50%);
}

/* 4 dots diagonales (ocultos inicialmente si los animas) */
.dot:nth-child(5){
  inset-block-start: calc(var(--dot-gap) + 2px);
  inset-inline-end:  calc(var(--dot-gap) + 2px);
  opacity: 0;
}
.dot:nth-child(6){
  inset-block-end:  calc(var(--dot-gap) + 2px);
  inset-inline-end:  calc(var(--dot-gap) + 2px);
  opacity: 0;
}
.dot:nth-child(7){
  inset-block-end:  calc(var(--dot-gap) + 2px);
  inset-inline-start: calc(var(--dot-gap) + 2px);
  opacity: 0;
}
.dot:nth-child(8){
  inset-block-start: calc(var(--dot-gap) + 2px);
  inset-inline-start: calc(var(--dot-gap) + 2px);
  opacity: 0;
}

/* Dot central (oculto inicialmente si lo animas) */
.center-dot{
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  transform: translate(-50%, -50%) scale(0);
  inline-size: calc(var(--dot-size) + 2px);
  block-size: calc(var(--dot-size) + 2px);
  border-radius: 50%;
  background: #fff;
  opacity: 0;
}

/* Pequeñas alturas (móvil apaisado / split screen) */
@media (max-height: 560px){
  .restart-btn{
    --btn-size: clamp(40px, 10vi, 60px);
    --dot-size: clamp(3px, 0.8vi, 7px);
  }
}

/* Alto contraste del sistema */
@media (prefers-contrast: more){
  .restart-btn{ background: rgba(255,255,255,0.16); }
}

/* Reduce motion: evita escalas/animaciones si las añades con CSS */
@media (prefers-reduced-motion: reduce){
  .center-dot{ transform: translate(-50%, -50%) scale(1); opacity: 1; }
}/* End custom CSS */