/* 
 * CSS para animações dinâmicas
 * Versão simplificada e mais robusta
 */

/* Cards de serviços */
.servicos-card {
    opacity: 0;
    transform: translateY(30px);
    transition: none;
}

.servicos-card.animated {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Elementos com fade-in */
[fade-in] {
    opacity: 0;
    transform: translateY(30px);
    transition: none;
}

[fade-in].animated {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Seção de resultados */
.section-resultados .container-resultados.animated {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.section-resultados .home-resultados_text-wrapper {
    opacity: 0;
    transform: translateY(30px);
    transition: none;
}

.section-resultados .home-resultados_text-wrapper.animated {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Hover effects para arrows */
.lottie_arrow-2 {
    transition: transform 0.3s ease;
}

/* Otimizações para performance */
.servicos-card,
[fade-in],
.section-resultados .container-resultados,
.section-resultados .home-resultados_text-wrapper {
    will-change: opacity, transform;
}

.servicos-card.animated,
[fade-in].animated,
.section-resultados .container-resultados.animated,
.section-resultados .home-resultados_text-wrapper.animated {
    will-change: auto;
}

/* Fallback para navegadores sem suporte */
.no-intersection-observer .servicos-card,
.no-intersection-observer [fade-in],
.no-intersection-observer .section-resultados .container-resultados,
.no-intersection-observer .section-resultados .home-resultados_text-wrapper {
    opacity: 1;
    transform: translateY(0);
}

/* Media queries para dispositivos móveis */
@media (max-width: 768px) {
    .servicos-card,
    [fade-in],
    .section-resultados .container-resultados,
    .section-resultados .home-resultados_text-wrapper {
        transform: translateY(20px);
    }
}

/* Respeitar preferências de movimento reduzido */
@media (prefers-reduced-motion: reduce) {
    .servicos-card,
    [fade-in],
    .section-resultados .container-resultados,
    .section-resultados .home-resultados_text-wrapper {
        opacity: 1;
        transform: translateY(0);
        transition: none;
    }
}