/* Scroll Reveal */
.scroll-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

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

/* Stagger children */
.scroll-reveal-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.scroll-reveal-stagger.visible > *:nth-child(1)  { transition-delay: 0.1s; }
.scroll-reveal-stagger.visible > *:nth-child(2)  { transition-delay: 0.2s; }
.scroll-reveal-stagger.visible > *:nth-child(3)  { transition-delay: 0.3s; }
.scroll-reveal-stagger.visible > *:nth-child(4)  { transition-delay: 0.4s; }
.scroll-reveal-stagger.visible > *:nth-child(5)  { transition-delay: 0.5s; }
.scroll-reveal-stagger.visible > *:nth-child(6)  { transition-delay: 0.6s; }
.scroll-reveal-stagger.visible > *:nth-child(7)  { transition-delay: 0.7s; }
.scroll-reveal-stagger.visible > *:nth-child(8)  { transition-delay: 0.8s; }
.scroll-reveal-stagger.visible > *:nth-child(9)  { transition-delay: 0.9s; }
.scroll-reveal-stagger.visible > *:nth-child(10) { transition-delay: 1.0s; }
.scroll-reveal-stagger.visible > *:nth-child(11) { transition-delay: 1.1s; }
.scroll-reveal-stagger.visible > *:nth-child(12) { transition-delay: 1.2s; }
.scroll-reveal-stagger.visible > *:nth-child(13) { transition-delay: 1.3s; }
.scroll-reveal-stagger.visible > *:nth-child(14) { transition-delay: 1.4s; }

.scroll-reveal-stagger.visible > * {
  opacity: 1;
  transform: translateY(0);
}

/* Prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  .scroll-reveal,
  .scroll-reveal-stagger > * {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
