/* 밥FULL - 페이지 전환 애니메이션 */

/* 페이드 전환 */
.page-enter {
    animation: fadeIn 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.page-exit {
    animation: fadeOut 0.2s ease forwards;
}

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

@keyframes fadeOut {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-6px);
    }
}

/* 요소 등장 애니메이션 (Intersection Observer) */
.fade-up {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

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

/* 스태거 딜레이 */
.fade-up:nth-child(1) { transition-delay: 0.03s; }
.fade-up:nth-child(2) { transition-delay: 0.06s; }
.fade-up:nth-child(3) { transition-delay: 0.09s; }
.fade-up:nth-child(4) { transition-delay: 0.12s; }
.fade-up:nth-child(5) { transition-delay: 0.15s; }
.fade-up:nth-child(6) { transition-delay: 0.18s; }
.fade-up:nth-child(7) { transition-delay: 0.21s; }
.fade-up:nth-child(8) { transition-delay: 0.24s; }
.fade-up:nth-child(9) { transition-delay: 0.27s; }

/* 스케일 인 */
.scale-in {
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.scale-in.visible {
    opacity: 1;
    transform: scale(1);
}
