/* Custom animations and overrides for Tailwind */

/* Custom animation delays */
.animation-delay-200 {
    animation-delay: 200ms;
}
.animation-delay-500 {
    animation-delay: 500ms;
}
.animation-delay-1000 {
    animation-delay: 1000ms;
}
.animation-delay-2000 {
    animation-delay: 2000ms;
}
.animation-delay-3000 {
    animation-delay: 3000ms;
}

/* Smooth scroll behavior */
html {
    scroll-behavior: smooth;
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #8B5CF6, #10B981);
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #7C3AED, #059669);
}

/* Glass morphism effect */
.glass {
    background: rgba(255, 255, 255, 0.25);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.18);
}

/* Gradient text animation */
.gradient-animate {
    background: linear-gradient(
        270deg,
        #8B5CF6,
        #10B981,
        #F59E0B,
        #8B5CF6
    );
    background-size: 300% 100%;
    -webkit-animation: gradient 6s ease infinite;
    -moz-animation: gradient 6s ease infinite;
    animation: gradient 6s ease infinite;
}

@keyframes gradient {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

/* Reveal animations */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* 3D Card Effect */
.card-3d {
    transition: transform 0.3s;
    transform-style: preserve-3d;
}

.card-3d:hover {
    transform: rotateX(5deg) rotateY(5deg);
}

/* Particle effect for hero */
.particle {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--tw-gradient-stops));
    filter: blur(1px);
    animation: float 20s infinite;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0) translateX(0);
    }
    25% {
        transform: translateY(-20px) translateX(10px);
    }
    50% {
        transform: translateY(0) translateX(20px);
    }
    75% {
        transform: translateY(20px) translateX(10px);
    }
}