/* Estilos para o Modal de Seleção de Profissionais */

#modalSelecaoProfissional {
    backdrop-filter: blur(4px);
    animation: fadeIn 0.3s ease-out;
}

#modalSelecaoProfissional .bg-white {
    animation: slideUp 0.3s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes slideUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Estilos para a lista de profissionais */
#lista-profissionais .hover\:bg-gray-50:hover {
    background-color: #f8fafc;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#lista-profissionais .hover\:border-blue-400:hover {
    border-color: #60a5fa;
    box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1);
}

/* Animação para os itens da lista */
#lista-profissionais > div {
    animation: slideInLeft 0.3s ease-out;
    animation-fill-mode: both;
}

#lista-profissionais > div:nth-child(1) { animation-delay: 0.1s; }
#lista-profissionais > div:nth-child(2) { animation-delay: 0.2s; }
#lista-profissionais > div:nth-child(3) { animation-delay: 0.3s; }
#lista-profissionais > div:nth-child(4) { animation-delay: 0.4s; }
#lista-profissionais > div:nth-child(5) { animation-delay: 0.5s; }

@keyframes slideInLeft {
    from {
        transform: translateX(-20px);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Estilos para as imagens dos profissionais */
#lista-profissionais img {
    transition: transform 0.2s ease-in-out;
}

#lista-profissionais .hover\:bg-gray-50:hover img {
    transform: scale(1.05);
}

/* Estilos responsivos */
@media (max-width: 640px) {
    #modalSelecaoProfissional .max-w-md {
        max-width: 95vw;
        margin: 1rem;
    }
    
    #lista-profissionais > div {
        padding: 0.75rem;
    }
    
    #lista-profissionais img {
        width: 2.5rem;
        height: 2.5rem;
    }
}

/* Estilos para o badge do pacote */
#servico-pacote-selecao {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.8;
    }
}

/* Estilos para melhorar a acessibilidade */
#lista-profissionais > div:focus {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Estilos para o estado de loading (se necessário) */
.loading-profissionais {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem;
}

.loading-profissionais::after {
    content: '';
    width: 2rem;
    height: 2rem;
    border: 2px solid #e5e7eb;
    border-top: 2px solid #3b82f6;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
} 