/* Animations and Keyframes */

/* Keyframes */
@keyframes fade-in-out {
    0% {
        opacity: 0;
        transform: translateY(-20px);
    }

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

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

    100% {
        opacity: 0;
        transform: translateY(-20px);
    }
}

@keyframes fade-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slide-in {
    from {
        transform: translateX(-100%);
    }

    to {
        transform: translateX(0);
    }
}

@keyframes pulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes pulse-shadow {
    0% {
        box-shadow: 0 0 0 0 color-mix(in srgb, var(--sys-color-primary-default) 70%, transparent);
    }

    70% {
        box-shadow: 0 0 0 10px color-mix(in srgb, var(--sys-color-primary-default) 0%, transparent);
    }

    100% {
        box-shadow: 0 0 0 0 color-mix(in srgb, var(--sys-color-primary-default) 0%, transparent);
    }
}

@keyframes bounce {
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

/* Animation Utilities */
.animate-fade-in {
    animation: fade-in var(--transition-speed-normal) var(--transition-ease-out);
}

.animate-fade-in-out {
    animation: fade-in-out 3s var(--transition-easing);
}

.animate-slide-in {
    animation: slide-in var(--transition-speed-normal) var(--transition-ease-out);
}

.animate-pulse {
    animation: pulse 2s var(--transition-easing) infinite;
}

.animate-pulse-shadow {
    animation: pulse-shadow 2s var(--transition-easing) infinite;
}

.animate-bounce {
    animation: bounce 1s var(--transition-easing) infinite;
}

.animate-spin {
    animation: spin 1s linear infinite;
}

/* Transition Utilities */
.transition-all {
    transition: all var(--transition-speed-normal) var(--transition-easing);
}

.transition-colors {
    transition: color var(--transition-speed-fast) var(--transition-easing),
                background-color var(--transition-speed-fast) var(--transition-easing),
                border-color var(--transition-speed-fast) var(--transition-easing);
}

.transition-transform {
    transition: transform var(--transition-speed-fast) var(--transition-easing);
}

.transition-opacity {
    transition: opacity var(--transition-speed-fast) var(--transition-easing);
}

/* Performance optimizations */
.will-change-transform {
    will-change: transform;
}

.will-change-opacity {
    will-change: opacity;
}

.will-change-auto {
    will-change: auto;
}