/* Reveal Animation Class used by JS */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: all 1s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

/* Animation Delays */
.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }

/* Mobile Menu Transitions */
#mobile-menu {
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Success Message Animation */
.fade-in {
    animation: fadeIn 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Specific pulse animation for hero image */
@keyframes pulseSlow {
    0% { transform: scale(1.05); }
    100% { transform: scale(1.15); }
}

.animate-pulse-slow {
    animation: pulseSlow 20s ease-in-out infinite alternate;
}