.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s ease, transform 1s ease;
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}


.hero-slide::before {
  background-image: var(--bg);
}

/* ================= PARALLAX TEXT ================= */
.hero-content {
  transform: translateY(40px);
  transition: transform 1.2s cubic-bezier(.25,.46,.45,.94);
}

.swiper-slide-active .hero-content {
  transform: translateY(0);
}

