/* Initial states for reveal */
.reveal {
    opacity: 0;
    will-change: transform, opacity;
}

/* Slide Up */
.fade-up {
    transform: translateY(40px);
}
.fade-up.active {
    animation: fadeUpAnim 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Slide Left */
.fade-left {
    transform: translateX(40px);
}
.fade-left.active {
    animation: fadeLeftAnim 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Delays */
.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }

/* Keyframes */
@keyframes fadeUpAnim {
    0% {
        opacity: 0;
        transform: translateY(40px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeLeftAnim {
    0% {
        opacity: 0;
        transform: translateX(40px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Basic Hero content animate on load */
.hero-content {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUpAnim 1s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards;
}
