/* Base font */
body {
    font-family: 'Inter', sans-serif;
}

/* Fade-up animation */
@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in-up {
    animation: fadeInUp 1s ease forwards;
}

/* Gradient background animation */
@keyframes gradientBG {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

.animated-gradient {
    background: linear-gradient(-45deg, #22c55e, #3b82f6, #16a34a, #2563eb);
    background-size: 400% 400%;
    animation: gradientBG 12s ease infinite;
}

/* Zoom-in animation */
@keyframes zoom-in {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.animate-zoom-in {
    animation: zoom-in 0.6s ease-out forwards;
}

/* Mobile menu transition */
.mobile-menu-transition {
    transition: transform 0.3s ease-in-out;
    transform: translateX(-100%);
}

.mobile-menu-open {
    transform: translateX(0);
}

/* Button hover glow */
.hover-glow:hover {
    box-shadow: 0 0 15px rgba(34, 197, 94, 0.6);
}

/* Wave background */
.bg-wave {
    background: linear-gradient(to top, #d4f0ff 0%, #f8fcff 50%, #d4f0ff 100%);
    position: relative;
    overflow: hidden;
}

.bg-wave::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 150px;
    background: radial-gradient(circle at 50% 100%, #b3e5ff 25%, transparent 26%),
        radial-gradient(circle at 0% 100%, #b3e5ff 25%, transparent 26%),
        radial-gradient(circle at 100% 100%, #b3e5ff 25%, transparent 26%);
    background-size: 50% 100%;
    background-repeat: repeat-x;
    transform: translateY(50%);
}