/* ============================================
   BORTLE CERO — ANIMACIONES (reveal on scroll)
   Sistema ligero: solo opacity + transform (GPU). El JS añade .vse-in
   cuando el elemento entra en viewport (IntersectionObserver, one-shot).
   Intensidad: sutil (desplazamiento 25px, 0.6s).
   Se carga solo si las animaciones están activas (Customizer).
   ============================================ */

.vse-reveal,
.vse-reveal-left,
.vse-reveal-right,
.vse-reveal-zoom {
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  will-change: opacity, transform;
}
.vse-reveal      { transform: translateY(25px); }
.vse-reveal-left { transform: translateX(-25px); }
.vse-reveal-right{ transform: translateX(25px); }
.vse-reveal-zoom { transform: scale(0.96); }

.vse-reveal.vse-in,
.vse-reveal-left.vse-in,
.vse-reveal-right.vse-in,
.vse-reveal-zoom.vse-in {
  opacity: 1;
  transform: none;
}

/* Cascada: los hijos directos aparecen uno tras otro */
.vse-stagger > * {
  opacity: 0;
  transform: translateY(25px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.vse-stagger.vse-in > * {
  opacity: 1;
  transform: none;
}
.vse-stagger.vse-in > *:nth-child(1) { transition-delay: 0.05s; }
.vse-stagger.vse-in > *:nth-child(2) { transition-delay: 0.13s; }
.vse-stagger.vse-in > *:nth-child(3) { transition-delay: 0.21s; }
.vse-stagger.vse-in > *:nth-child(4) { transition-delay: 0.29s; }
.vse-stagger.vse-in > *:nth-child(5) { transition-delay: 0.37s; }
.vse-stagger.vse-in > *:nth-child(6) { transition-delay: 0.45s; }
.vse-stagger.vse-in > *:nth-child(7) { transition-delay: 0.53s; }
.vse-stagger.vse-in > *:nth-child(8) { transition-delay: 0.61s; }
/* a partir del 9º sin retraso extra para no demorar demasiado */

/* Accesibilidad: si el usuario pidió menos movimiento, todo visible sin animar */
@media (prefers-reduced-motion: reduce) {
  .vse-reveal,
  .vse-reveal-left,
  .vse-reveal-right,
  .vse-reveal-zoom,
  .vse-stagger > * {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
