/* Animações - Andreia Ribeiro Makeup */

/* Animações sutis para dar vida ao site sem distrair o usuário */

/* Fade In (para elementos que aparecem gradualmente) */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.fade-in {
    animation: fadeIn 1s ease forwards;
}

/* Slide Up (para elementos que surgem de baixo para cima) */
@keyframes slideUp {
    from { 
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.slide-up {
    animation: slideUp 0.8s ease forwards;
}

/* Animação para o título principal com uma leve transição */
@keyframes titleFocus {
    0% { 
        opacity: 0;
        transform: translateY(10px) scale(0.98);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.hero h2 {
    animation: titleFocus 1.2s ease-out forwards;
}

.hero p {
    opacity: 0;
    animation: fadeIn 1.2s ease-out forwards;
    animation-delay: 0.3s;
}

.hero .btn {
    opacity: 0;
    animation: fadeIn 1.2s ease-out forwards;
    animation-delay: 0.6s;
}

/* Animação para os cards de serviço quando a página carrega */
.service-card {
    opacity: 0;
    animation: slideUp 0.8s ease-out forwards;
}

.service-card:nth-child(1) { animation-delay: 0.1s; }
.service-card:nth-child(2) { animation-delay: 0.2s; }
.service-card:nth-child(3) { animation-delay: 0.3s; }
.service-card:nth-child(4) { animation-delay: 0.4s; }

/* Animação sutil para o hover em cards e botões */
@keyframes softPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.02); }
    100% { transform: scale(1); }
}

.btn:hover {
    animation: softPulse 1s infinite;
}

/* Animações para ícones de redes sociais */
@keyframes socialBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-3px); }
}

.social-icon:hover {
    animation: socialBounce 0.6s ease infinite;
}

/* Animação para links no menu de navegação */
@keyframes navLinkFade {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}

/* Animações de entrada para seções quando elas entram no viewport 
   (Estas serão utilizadas com JavaScript posteriormente) */
.reveal {
    opacity: 0;
    transition: opacity 1s ease, transform 1s ease;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

.reveal-left {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 1s ease, transform 1s ease;
}

.reveal-left.active {
    opacity: 1;
    transform: translateX(0);
}

.reveal-right {
    opacity: 0;
    transform: translateX(30px);
    transition: opacity 1s ease, transform 1s ease;
}

.reveal-right.active {
    opacity: 1;
    transform: translateX(0);
}

/* Transição suave para mudanças de página */
.page-transition {
    animation: fadeIn 0.5s ease-out;
} 