@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Fade up — initial state */
.anim-fade-up {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.anim-fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children */
.anim-stagger > * {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.anim-stagger > *.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Hero entrance — fires on page load, no JS needed */
@keyframes heroIn {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero-content .badge,
.hero-content h1,
.hero-content .hero-sub,
.hero-content .hero-ctas {
  opacity: 0;
  animation: heroIn 0.7s ease-out forwards;
}
.hero-content .badge    { animation-delay: 0.15s; }
.hero-content h1        { animation-delay: 0.40s; }
.hero-content .hero-sub { animation-delay: 0.65s; }
.hero-content .hero-ctas{ animation-delay: 0.85s; }

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .anim-fade-up,
  .anim-stagger > * {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero-content .badge,
  .hero-content h1,
  .hero-content .hero-sub,
  .hero-content .hero-ctas {
    opacity: 1;
    animation: none;
  }
}
