/* static/css/animations.css */

/* High-End Reveal Transitions */
[class*="reveal-"] {
    opacity: 0;
    transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    will-change: transform, opacity;
}

.reveal-up { transform: translateY(40px); }
.reveal-down { transform: translateY(-40px); }
.reveal-left { transform: translateX(-40px); }
.reveal-right { transform: translateX(40px); }
.reveal-scale { transform: scale(0.95); }
.reveal-blur { filter: blur(10px); }

/* Trigger Class (Added by JS on Scroll) */
.visible {
    opacity: 1 !important;
    transform: translate(0, 0) scale(1) !important;
    filter: blur(0) !important;
}

/* Staggered Delays for Grid Matchups */
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }
.reveal-delay-6 { transition-delay: 0.6s; }
.reveal-delay-7 { transition-delay: 0.7s; }
.reveal-delay-8 { transition-delay: 0.8s; }

/* Clean Float Animation for Icons */
@keyframes soft-float {
    0% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
    100% { transform: translateY(0); }
}

.animate-float {
    animation: soft-float 4s ease-in-out infinite;
}

/* Subtle Zoom for Images */
.hover-zoom {
    transition: transform 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.hover-zoom:hover {
    transform: scale(1.08);
}
