/* ============================================
   AeroWealth - Keyframe Animations
   ============================================ */

/* ============ Core Animations ============ */
@keyframes pulse-glow {
    0%, 100% { opacity: 1; text-shadow: 0 0 20px var(--glow-pulse, rgba(0, 243, 255, 0.5)); }
    50% { opacity: 0.8; text-shadow: 0 0 40px var(--glow-pulse, rgba(0, 243, 255, 0.8)), 0 0 80px var(--glow-pulse-outer, rgba(0, 243, 255, 0.3)); }
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

@keyframes float-slow {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    33% { transform: translateY(-8px) rotate(1deg); }
    66% { transform: translateY(4px) rotate(-1deg); }
}

@keyframes rotate-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes rotate-reverse {
    from { transform: rotate(360deg); }
    to { transform: rotate(0deg); }
}

@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-5px); }
    40% { transform: translateX(5px); }
    60% { transform: translateX(-3px); }
    80% { transform: translateX(3px); }
}

@keyframes bounce-in {
    0% { opacity: 0; transform: scale(0.3); }
    50% { opacity: 1; transform: scale(1.05); }
    70% { transform: scale(0.95); }
    100% { transform: scale(1); }
}

@keyframes slide-in-left {
    from { opacity: 0; transform: translateX(-60px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes slide-in-right {
    from { opacity: 0; transform: translateX(60px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes slide-in-up {
    from { opacity: 0; transform: translateY(40px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slide-in-down {
    from { opacity: 0; transform: translateY(-40px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes scale-in {
    from { opacity: 0; transform: scale(0.8); }
    to { opacity: 1; transform: scale(1); }
}

@keyframes flip-in-x {
    from { opacity: 0; transform: perspective(400px) rotateX(90deg); }
    40% { transform: perspective(400px) rotateX(-10deg); }
    70% { transform: perspective(400px) rotateX(10deg); }
    to { opacity: 1; transform: perspective(400px) rotateX(0deg); }
}

/* ============ Neon / Glow Effects ============ */
@keyframes neon-pulse {
    0%, 100% { box-shadow: 0 0 5px rgba(0, 243, 255, 0.2), 0 0 10px rgba(0, 243, 255, 0.1); }
    50% { box-shadow: 0 0 20px rgba(0, 243, 255, 0.4), 0 0 40px rgba(0, 243, 255, 0.2); }
}

@keyframes border-glow {
    0%, 100% { border-color: rgba(0, 243, 255, 0.3); }
    50% { border-color: rgba(0, 243, 255, 0.8); }
}

@keyframes gradient-shift {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

@keyframes text-gradient-shift {
    0% { background-position: 0% center; }
    100% { background-position: 200% center; }
}

@keyframes glow-line {
    0% { left: -100%; }
    100% { left: 200%; }
}

/* ============ Loading ============ */
@keyframes load-progress {
    0% { width: 0%; }
    50% { width: 70%; }
    100% { width: 100%; }
}

@keyframes toast-timer {
    from { width: 100%; }
    to { width: 0%; }
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes orbit {
    from { transform: rotate(0deg) translateX(120px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(120px) rotate(-360deg); }
}

/* ============ Confetti ============ */
@keyframes confetti-fall {
    0% { transform: translateY(-100vh) rotate(0deg); opacity: 1; }
    100% { transform: translateY(100vh) rotate(720deg); opacity: 0; }
}

@keyframes confetti-sway {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(30px); }
    75% { transform: translateX(-30px); }
}

/* ============ Particle Burst ============ */
@keyframes particle-burst {
    0% { transform: scale(0); opacity: 1; }
    100% { transform: scale(1.5); opacity: 0; }
}

/* ============ Typing Cursor ============ */
@keyframes blink-cursor {
    0%, 100% { border-right-color: var(--accent-cyan); }
    50% { border-right-color: transparent; }
}

/* ============ Wave Animation ============ */
@keyframes wave-move {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ============ Orbit Cards ============ */
@keyframes orbit-1 {
    from { transform: rotate(0deg) translateX(160px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(160px) rotate(-360deg); }
}

@keyframes orbit-2 {
    from { transform: rotate(90deg) translateX(160px) rotate(-90deg); }
    to { transform: rotate(450deg) translateX(160px) rotate(-450deg); }
}

@keyframes orbit-3 {
    from { transform: rotate(180deg) translateX(160px) rotate(-180deg); }
    to { transform: rotate(540deg) translateX(160px) rotate(-540deg); }
}

@keyframes orbit-4 {
    from { transform: rotate(270deg) translateX(160px) rotate(-270deg); }
    to { transform: rotate(630deg) translateX(160px) rotate(-630deg); }
}

/* ============ Star Twinkle ============ */
@keyframes twinkle {
    0%, 100% { opacity: 0.3; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.3); }
}

@keyframes comet {
    0% { transform: translateX(-100px) translateY(-100px); opacity: 0; }
    20% { opacity: 1; }
    100% { transform: translateX(calc(100vw + 100px)) translateY(calc(100vh + 100px)); opacity: 0; }
}

/* ============ Gauge ============ */
@keyframes gauge-fill {
    from { transform: rotate(-90deg); }
    to { transform: rotate(var(--gauge-angle, 0deg)); }
}

/* ============ Counter ============ */
@keyframes counter-tick {
    0% { transform: translateY(0); }
    50% { transform: translateY(-100%); }
    50.01% { transform: translateY(100%); }
    100% { transform: translateY(0); }
}

/* ============ Digital Rain ============ */
@keyframes digital-rain {
    0% { transform: translateY(-100%); opacity: 1; }
    100% { transform: translateY(100vh); opacity: 0; }
}

/* ============ Achievement Badge ============ */
@keyframes badge-fly-in {
    0% { transform: translateX(100vw) rotate(180deg) scale(0); opacity: 0; }
    60% { transform: translateX(-10px) rotate(-10deg) scale(1.1); opacity: 1; }
    80% { transform: translateX(5px) rotate(5deg) scale(0.95); }
    100% { transform: translateX(0) rotate(0deg) scale(1); opacity: 1; }
}

/* ============ Fire Animation ============ */
@keyframes fire-flicker {
    0%, 100% { transform: scaleY(1); opacity: 1; }
    25% { transform: scaleY(1.1); opacity: 0.9; }
    50% { transform: scaleY(0.95); opacity: 1; }
    75% { transform: scaleY(1.05); opacity: 0.95; }
}

/* ============ Ripple ============ */
@keyframes ripple {
    0% { transform: scale(0); opacity: 0.5; }
    100% { transform: scale(4); opacity: 0; }
}

/* ============ Glitch ============ */
@keyframes glitch-1 {
    0%, 100% { clip-path: inset(40% 0 61% 0); transform: translate(2px, -2px); }
    20% { clip-path: inset(92% 0 1% 0); transform: translate(-2px, 2px); }
    40% { clip-path: inset(43% 0 1% 0); transform: translate(2px, 1px); }
    60% { clip-path: inset(25% 0 58% 0); transform: translate(-1px, -2px); }
    80% { clip-path: inset(54% 0 7% 0); transform: translate(1px, 2px); }
}

@keyframes glitch-2 {
    0%, 100% { clip-path: inset(50% 0 36% 0); transform: translate(-2px, 2px); }
    20% { clip-path: inset(15% 0 65% 0); transform: translate(2px, -1px); }
    40% { clip-path: inset(72% 0 1% 0); transform: translate(-1px, 2px); }
    60% { clip-path: inset(1% 0 80% 0); transform: translate(2px, -2px); }
    80% { clip-path: inset(36% 0 12% 0); transform: translate(-2px, 1px); }
}

/* ============ Stagger Helper Classes ============ */
.anim-delay-1 { animation-delay: 0.1s; }
.anim-delay-2 { animation-delay: 0.2s; }
.anim-delay-3 { animation-delay: 0.3s; }
.anim-delay-4 { animation-delay: 0.4s; }
.anim-delay-5 { animation-delay: 0.5s; }
.anim-delay-6 { animation-delay: 0.6s; }
.anim-delay-7 { animation-delay: 0.7s; }
.anim-delay-8 { animation-delay: 0.8s; }

/* Animation utility classes */
.animate-float { animation: float 3s ease-in-out infinite; }
.animate-pulse-glow { animation: pulse-glow 2s ease-in-out infinite; }
.animate-rotate { animation: rotate-slow 20s linear infinite; }
.animate-shimmer { animation: shimmer 2s ease-in-out infinite; }
.animate-bounce-in { animation: bounce-in 0.6s ease-out forwards; }
.animate-slide-up { animation: slide-in-up 0.6s ease-out forwards; }
.animate-slide-left { animation: slide-in-left 0.6s ease-out forwards; }
.animate-slide-right { animation: slide-in-right 0.6s ease-out forwards; }
.animate-fade-in { animation: fade-in 0.6s ease-out forwards; }
.animate-scale-in { animation: scale-in 0.5s ease-out forwards; }

/* Hidden initially for scroll animations */
.scroll-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}
