/**
 * Raayah Media Animations CSS
 */

/* Initial states for animated elements */
.raayah-animate-on-scroll {
	opacity: 0;
	transition: opacity 0.8s ease-out, transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	will-change: opacity, transform;
}

/* Fade Up */
.raayah-fade-up {
	transform: translateY(40px);
}

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

/* Fade In */
.raayah-fade-in {
	transform: scale(0.95);
}

.raayah-fade-in.raayah-animated {
	opacity: 1;
	transform: scale(1);
}

/* Slide In from Right */
.raayah-slide-right {
	transform: translateX(40px);
}

.raayah-slide-right.raayah-animated {
	opacity: 1;
	transform: translateX(0);
}

/* Slide In from Left */
.raayah-slide-left {
	transform: translateX(-40px);
}

.raayah-slide-left.raayah-animated {
	opacity: 1;
	transform: translateX(0);
}

/* Delay Utility Classes */
.raayah-delay-100 { transition-delay: 100ms; }
.raayah-delay-200 { transition-delay: 200ms; }
.raayah-delay-300 { transition-delay: 300ms; }
.raayah-delay-400 { transition-delay: 400ms; }
.raayah-delay-500 { transition-delay: 500ms; }

/* Micro-interactions (Hover effects) */
.raayah-hover-lift {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.raayah-hover-lift:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.raayah-hover-glow {
	transition: box-shadow 0.3s ease;
}

.raayah-hover-glow:hover {
	box-shadow: 0 0 15px rgba(14, 165, 233, 0.5); /* using a nice blue accent */
}

/* ==========================================================================
   Modonaty Premium Animations & Glowing Effects
   ========================================================================== */

/* Floating Orbs Ambient Movement */
@keyframes ambientGlow {
    0%, 100% {
        transform: translate(0, 0) scale(1) rotate(0deg);
    }
    33% {
        transform: translate(40px, -60px) scale(1.15) rotate(120deg);
    }
    66% {
        transform: translate(-30px, 40px) scale(0.9) rotate(240deg);
    }
}

.animate-ambient-glow {
    animation: ambientGlow 20s infinite alternate ease-in-out;
}

/* Neon Glow Pulsing */
@keyframes neonPulse {
    0%, 100% {
        box-shadow: 0 0 15px rgba(var(--primary-color-rgb), 0.2), 
                    0 0 5px rgba(var(--primary-color-rgb), 0.1),
                    inset 0 1px 0 rgba(255, 255, 255, 0.1);
        border-color: rgba(var(--primary-color-rgb), 0.25);
    }
    50% {
        box-shadow: 0 0 25px rgba(var(--primary-color-rgb), 0.45), 
                    0 0 10px rgba(var(--primary-color-rgb), 0.2),
                    inset 0 1px 0 rgba(255, 255, 255, 0.2);
        border-color: rgba(var(--primary-color-rgb), 0.5);
    }
}

.neon-pulse-element {
    animation: neonPulse 3s infinite ease-in-out;
}

/* Breathing Live Indicator */
@keyframes breathingPulse {
    0% {
        transform: scale(0.85);
        opacity: 0.5;
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7);
    }
    70% {
        transform: scale(1.15);
        opacity: 1;
        box-shadow: 0 0 0 8px rgba(16, 185, 129, 0);
    }
    100% {
        transform: scale(0.85);
        opacity: 0.5;
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0);
    }
}

.breathing-live-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    background-color: #10b981;
    border-radius: 50%;
    animation: breathingPulse 2s infinite ease-in-out;
}

/* Dashboard Mockup Chart Height Growing */
@keyframes chartBarGrow {
    from {
        height: 0%;
    }
}

.animate-chart-bar {
    animation: chartBarGrow 1.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Float Animation for Hero & Mockups */
@keyframes elementFloat {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

.animate-float {
    animation: elementFloat 6s infinite ease-in-out;
}

/* Pulse animation for important metrics */
@keyframes neonTextPulse {
    0%, 100% {
        text-shadow: 0 0 5px rgba(var(--primary-color-rgb), 0.2);
    }
    50% {
        text-shadow: 0 0 15px rgba(var(--primary-color-rgb), 0.6), 0 0 5px rgba(var(--primary-color-rgb), 0.3);
    }
}

.neon-text-pulsing {
    animation: neonTextPulse 4s infinite ease-in-out;
}

