.hero-reveal {
  opacity: 0;
  transform: translateY(24px);
  animation: hero-in 900ms var(--ease-organic) forwards;
}

.hero-reveal:nth-child(1) { animation-delay: 120ms; }
.hero-reveal:nth-child(2) { animation-delay: 200ms; }
.hero-reveal:nth-child(3) { animation-delay: 280ms; }
.hero-reveal:nth-child(4) { animation-delay: 360ms; }
.hero-reveal:nth-child(5) { animation-delay: 440ms; }

@keyframes hero-in {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms ease-out, transform 700ms var(--ease-organic);
}

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

[data-reveal-group] > * {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 650ms ease-out, transform 650ms var(--ease-organic);
}

[data-reveal-group].is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

[data-reveal-group].is-visible > *:nth-child(2) { transition-delay: 60ms; }
[data-reveal-group].is-visible > *:nth-child(3) { transition-delay: 120ms; }
[data-reveal-group].is-visible > *:nth-child(4) { transition-delay: 180ms; }
[data-reveal-group].is-visible > *:nth-child(5) { transition-delay: 240ms; }
[data-reveal-group].is-visible > *:nth-child(6) { transition-delay: 300ms; }

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  [data-reveal],
  [data-reveal-group] > *,
  .hero-reveal {
    opacity: 1;
    transform: none;
  }
}
