@keyframes fadeSubir {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeEntrar {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes scrollHint {
  0%, 100% { opacity: 0.3; transform: translateY(0); }
  50%       { opacity: 0.7; transform: translateY(6px); }
}

@keyframes pulsoDorado {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 1; }
}

.hero-titulo {
  animation: fadeSubir 0.9s var(--transicion) 0.3s both;
}

.hero-kicker {
  animation: fadeSubir 0.9s var(--transicion) 0.52s both;
}

.hero-subtitulo {
  animation: fadeSubir 0.9s var(--transicion) 0.68s both;
}

.hero-ctas {
  animation: fadeSubir 0.9s var(--transicion) 0.82s both;
}

.hero-stats {
  animation: fadeSubir 0.9s var(--transicion) 0.96s both;
}

.scroll-hint span {
  animation: scrollHint 2.2s ease-in-out infinite;
}

.scroll-hint::after {
  animation: scrollHint 2.2s ease-in-out 0.3s infinite;
}

.divisor {
  animation: pulsoDorado 3.5s ease-in-out infinite;
}

.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.75s var(--transicion), transform 0.75s var(--transicion);
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }
.reveal-delay-6 { transition-delay: 0.6s; }

.galeria-item {
  overflow: hidden;
  border-radius: 0;
  transition: box-shadow 0.4s var(--transicion);
}

.galeria-item:hover {
  box-shadow: inset 0 0 0 2px rgba(201, 160, 90, 0.3);
}

.tarjeta-caracteristica,
.tarjeta-tarifa,
.condicion-item,
.faq-item {
  transition: transform 0.35s var(--transicion), box-shadow 0.35s var(--transicion);
}

.nav-cta,
.btn-primario,
.btn-secundario,
.btn-consultar,
.btn-enviar {
  transition: all 0.35s var(--transicion);
}

nav {
  transition: background 0.45s var(--transicion),
              backdrop-filter 0.45s var(--transicion),
              box-shadow 0.45s var(--transicion);
}

.faq-respuesta {
  transition: max-height 0.42s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-icono {
  transition: transform 0.35s var(--transicion);
}

.faq-pregunta {
  transition: background 0.25s ease;
}

#toast {
  transition: transform 0.45s var(--transicion);
}

#scroll-progress {
  transition: width 0.12s linear;
}

.hamburger span {
  transition: all 0.32s var(--transicion);
}

.nav-mobile {
  transition: opacity 0.38s var(--transicion);
}

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero-kicker,
  .hero-titulo,
  .hero-subtitulo,
  .hero-ctas,
  .hero-stats {
    animation: none;
  }

  .scroll-hint span,
  .scroll-hint::after,
  .divisor {
    animation: none;
  }

  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
}
