/* reveal.css — animaciones de aparición al scrollear
   Cualquier elemento con [data-reveal] arranca oculto y entra al añadirsele
   la clase .is-revealed (lo hace el IntersectionObserver de js/main.js). */

[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.85s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.85s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

[data-reveal].is-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger automático cuando varios items hermanos están en una rejilla:
   el segundo entra 80ms después, el tercero a 160ms, etc. Se aplica solo
   cuando .is-revealed está presente, así no afecta el estado oculto. */
.grid > [data-reveal]:nth-child(1).is-revealed { transition-delay: 0s; }
.grid > [data-reveal]:nth-child(2).is-revealed { transition-delay: 0.08s; }
.grid > [data-reveal]:nth-child(3).is-revealed { transition-delay: 0.16s; }
.grid > [data-reveal]:nth-child(4).is-revealed { transition-delay: 0.24s; }
.grid > [data-reveal]:nth-child(5).is-revealed { transition-delay: 0.32s; }
.grid > [data-reveal]:nth-child(6).is-revealed { transition-delay: 0.40s; }

/* Variante: reveal con desplazamiento lateral (data-reveal="left|right") */
[data-reveal="left"] { transform: translate(-32px, 0); }
[data-reveal="right"] { transform: translate(32px, 0); }
[data-reveal="left"].is-revealed,
[data-reveal="right"].is-revealed { transform: translate(0, 0); }

@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-reveal].is-revealed {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
