/* ==========================================================================
   Canzoe Theme — animations.css
   Replaces motion/react whileInView animations with CSS + IntersectionObserver.
   ========================================================================== */

/* ── Fade-up (replaces motion initial/whileInView opacity+y pattern) ─────── */

.cz-fade-up {
    opacity: 0;
    transform: translateY(20px) blur(6px);
    transition:
        opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    /* filter separated for Safari compat */
    -webkit-filter: blur(6px);
    filter: blur(6px);
}

.cz-fade-up.is-visible {
    opacity: 1;
    transform: translateY(0) blur(0px);
    -webkit-filter: blur(0px);
    filter: blur(0px);
}

/* Stagger delays (applied by theme.js to .cz-stagger-parent children) */
.cz-delay-1 { transition-delay: 0.08s; }
.cz-delay-2 { transition-delay: 0.16s; }
.cz-delay-3 { transition-delay: 0.24s; }
.cz-delay-4 { transition-delay: 0.32s; }

/* ── Marquee ─────────────────────────────────────────────────────────────── */

@keyframes cz-marquee-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ── Respect reduced motion ──────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
    .cz-fade-up {
        opacity: 1;
        transform: none;
        filter: none;
        -webkit-filter: none;
        transition: none;
    }

    .cz-marquee {
        animation-play-state: paused;
    }
}
