/* ============================================
   AgileVizion 2 — Scroll Animations
   Intersection Observer driven
   ============================================ */

.animate-in {
    opacity: 0;
    transform: translateY(var(--space-6));
    transition: opacity var(--transition-enter), transform var(--transition-enter);
}

.animate-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Staggered delays for grid items */
.animate-in:nth-child(2) { transition-delay: var(--delay-nth-2); }
.animate-in:nth-child(3) { transition-delay: var(--delay-nth-3); }
.animate-in:nth-child(4) { transition-delay: var(--delay-nth-4); }
.animate-in:nth-child(5) { transition-delay: var(--delay-nth-5); }
.animate-in:nth-child(6) { transition-delay: var(--delay-nth-6); }
.animate-in:nth-child(7) { transition-delay: var(--delay-nth-7); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .animate-in {
        opacity: 1;
        transform: none;
        transition: none;
    }
}
