/* ===================================
   ANIMATIONS
   =================================== */

.fade-in {
    opacity: 1;
}

.js .fade-in {
    opacity: 0;
    animation: fadeIn 1s ease forwards;
}

.fade-in:nth-child(1) {
    animation-delay: 0.2s;
}

.fade-in:nth-child(2) {
    animation-delay: 0.4s;
}

.fade-in:nth-child(3) {
    animation-delay: 0.6s;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.scroll-fade {
    opacity: 1;
    transform: translateY(0);
}

.js .scroll-fade {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.js .scroll-fade.visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    .js .fade-in,
    .js .scroll-fade {
        opacity: 1 !important;
        transform: none !important;
    }

    .js .fade-in,
    .js .scroll-fade,
    .menu-tab,
    .menu-tabs-shell::before,
    .menu-tabs-shell::after,
    .menu-item,
    .sticky-actions-shell,
    .nav-menu {
        animation: none !important;
        transition: none !important;
    }
}
