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

/* ---- Scroll Reveal ---- */
.cb3-animate {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity var(--cb-duration-slower) var(--cb-ease),
                transform var(--cb-duration-slower) var(--cb-ease);
}
.cb3-animate.cb3-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ---- Stagger Children ---- */
.cb3-stagger > * {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity var(--cb-duration-slow) var(--cb-ease),
                transform var(--cb-duration-slow) var(--cb-ease);
}
.cb3-stagger.cb3-visible > * { opacity: 1; transform: translateY(0); }
.cb3-stagger.cb3-visible > *:nth-child(1) { transition-delay: 0ms; }
.cb3-stagger.cb3-visible > *:nth-child(2) { transition-delay: 60ms; }
.cb3-stagger.cb3-visible > *:nth-child(3) { transition-delay: 120ms; }
.cb3-stagger.cb3-visible > *:nth-child(4) { transition-delay: 180ms; }
.cb3-stagger.cb3-visible > *:nth-child(5) { transition-delay: 240ms; }
.cb3-stagger.cb3-visible > *:nth-child(6) { transition-delay: 300ms; }

/* ---- Shimmer Loading ---- */
@keyframes cb3-shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
.cb3-shimmer {
    background: linear-gradient(90deg, var(--cb-bg-card) 25%, var(--cb-bg-hover) 50%, var(--cb-bg-card) 75%);
    background-size: 200% 100%;
    animation: cb3-shimmer 1.5s infinite;
}

/* ---- Pulse ---- */
@keyframes cb3-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
.cb3-pulse { animation: cb3-pulse 2s ease-in-out infinite; }

/* ---- Glow ---- */
@keyframes cb3-glow {
    0%, 100% { box-shadow: 0 0 20px rgba(212,168,65,0.1); }
    50% { box-shadow: 0 0 40px rgba(212,168,65,0.3); }
}
.cb3-glow { animation: cb3-glow 3s ease-in-out infinite; }

/* ---- Fade In ---- */
@keyframes cb3-fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
.cb3-fade-in { animation: cb3-fadeIn var(--cb-duration-slow) var(--cb-ease); }

/* ---- Slide Up ---- */
@keyframes cb3-slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.cb3-slide-up { animation: cb3-slideUp var(--cb-duration-slow) var(--cb-ease); }

/* ---- Scale In ---- */
@keyframes cb3-scaleIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}
.cb3-scale-in { animation: cb3-scaleIn var(--cb-duration-slow) var(--cb-ease); }

/* ---- Floating ---- */
@keyframes cb3-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}
.cb3-float { animation: cb3-float 4s ease-in-out infinite; }

/* ---- Gradient Text Shimmer ---- */
@keyframes cb3-textShimmer {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
.cb3-text-shimmer {
    background: linear-gradient(90deg, var(--cb-gold), #fff, var(--cb-gold));
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: cb3-textShimmer 3s linear infinite;
}

/* ---- Reduce Motion ---- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .cb3-animate { opacity: 1; transform: none; }
    .cb3-stagger > * { opacity: 1; transform: none; }
}
