/* ==========================================================================
   SCROLL ANIMATIONS
   Elements below the fold fade up into view as the user scrolls.
   The JS (scroll-animations.js) adds .tv-animate-ready on init and
   .tv-animated when the element enters the viewport.
   ========================================================================== */

/* ---------- Pre-animation state (hidden, shifted down) ---------- */
.tv-animate-ready {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* ---------- Animated state (visible, in position) ---------- */
.tv-animate-ready.tv-animated {
    opacity: 1;
    transform: translateY(0);
}

/* ---------- Stagger delays (applied via JS per row) ---------- */
.tv-stagger-1 { transition-delay: 0ms; }
.tv-stagger-2 { transition-delay: 100ms; }
.tv-stagger-3 { transition-delay: 200ms; }
.tv-stagger-4 { transition-delay: 300ms; }
.tv-stagger-5 { transition-delay: 400ms; }
.tv-stagger-6 { transition-delay: 500ms; }

/* ---------- Respect reduced-motion preference ---------- */
@media (prefers-reduced-motion: reduce) {
    .tv-animate-ready {
        opacity: 1;
        transform: none;
        transition: none;
    }
}
