/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInLeft {
    from {
        opacity: 0;
        transform: translateX(-50px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(50px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes zoomIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Animation Utility Classes */
.animate {
    opacity: 0;
    /* Initially hidden */
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
    will-change: opacity, transform;
}

.animate.visible {
    opacity: 1;
}

.animate.fade-up {
    transform: translateY(30px);
}

.animate.fade-up.visible {
    transform: translateY(0);
}

.animate.fade-left {
    transform: translateX(-50px);
}

.animate.fade-left.visible {
    transform: translateX(0);
}

.animate.fade-right {
    transform: translateX(50px);
}

.animate.fade-right.visible {
    transform: translateX(0);
}

.animate.zoom-in {
    transform: scale(0.9);
}

.animate.zoom-in.visible {
    transform: scale(1);
}

/* Staggered delays */
.delay-100 {
    transition-delay: 0.1s;
}

.delay-200 {
    transition-delay: 0.2s;
}

.delay-300 {
    transition-delay: 0.3s;
}

.delay-400 {
    transition-delay: 0.4s;
}

.delay-500 {
    transition-delay: 0.5s;
}