/* Base reveal class */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.5, 0, 0, 1);
    will-change: opacity, transform;
}

/* Modifiers */
.reveal.fade-left {
    transform: translateX(-30px);
}

.reveal.fade-right {
    transform: translateX(30px);
}

.reveal.scale-up {
    transform: scale(0.95);
}

.reveal.fade-in {
    transform: none; /* Just opacity change */
}

/* Visible state */
.reveal.is-visible {
    opacity: 1;
    transform: translate(0) scale(1);
}

/* Stagger delays managed via CSS variables or utility classes if needed, 
   but we'll use inline styles or specific classes for simplicity in WP */
.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }
.delay-400 { transition-delay: 400ms; }
.delay-500 { transition-delay: 500ms; }
