/* Animações personalizadas para complementar animate.css */

/* Animação personalizada para elementos que aparecem em sequência */
@keyframes customSlideInSequence {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Animação personalizada para zoom suave */
@keyframes customZoomInSubtle {
    0% {
        opacity: 0;
        transform: scale(0.8);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Animação personalizada para fade in lateral */
@keyframes customFadeInLeft {
    0% {
        opacity: 0;
        transform: translateX(-50px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Animação personalizada para fade in lateral direita */
@keyframes customFadeInRight {
    0% {
        opacity: 0;
        transform: translateX(50px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Classes para usar as animações personalizadas */
.animate-slide-in-sequence {
    animation: customSlideInSequence 0.6s ease-out;
}

.animate-zoom-in-subtle {
    animation: customZoomInSubtle 0.8s ease-out;
}

.animate-fade-in-left {
    animation: customFadeInLeft 0.7s ease-out;
}

.animate-fade-in-right {
    animation: customFadeInRight 0.7s ease-out;
}

/* Hover effects para elementos com animação */
.animate-on-scroll:hover {
    transform: translateY(-5px);
    transition: transform 0.3s ease;
}

.country-flag.animate-on-scroll:hover {
    transform: scale(1.1);
    transition: transform 0.3s ease;
}

.news-card-alt.animate-on-scroll:hover {
    transform: translateY(-10px);
    transition: transform 0.3s ease;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

/* Configurações de performance para animações */
.animate-on-scroll,
.animate-on-load {
    will-change: opacity, transform;
    backface-visibility: hidden;
}

/* Estilos para elementos ainda não animados */
.animate-on-scroll:not(.animated) {
    opacity: 0;
    transform: translateY(20px);
}

.animate-on-load:not(.animated) {
    opacity: 0;
}

/* Responsividade para animações */
@media (max-width: 768px) {
    .animate-on-scroll {
        --animate-duration: 0.8s;
    }
    
    .animate-on-scroll[data-delay] {
        --animate-delay: 0.3s;
    }
}

/* Redução de animações para usuários que preferem menos movimento */
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll,
    .animate-on-load,
    .animate__animated {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
