/* Estado inicial: Invisible */
body {
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: opacity;
}

/* Estado visible: Se añade esta clase con JS al cargar */
body.fade-in {
  opacity: 1;
}

/* --- SCROLL REVEAL ANIMATIONS --- */

/* 1. Elementos que queremos animar (ocultos inicialmente) */
.reveal-up {
  opacity: 0;
  transform: translateY(40px); /* Empiezan 40px más abajo */
  transition: opacity 0.8s cubic-bezier(0.215, 0.61, 0.355, 1), 
              transform 0.8s cubic-bezier(0.215, 0.61, 0.355, 1);
  will-change: opacity, transform;
}

/* 2. Clase que añade JS cuando el elemento es visible */
.reveal-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 3. Retardos para efecto cascada (Stagger) */
.delay-100 { transition-delay: 0.1s; }
.delay-200 { transition-delay: 0.2s; }
.delay-300 { transition-delay: 0.3s; }