/* Animações e transições para o sistema */

/* Transição de página */
.page-transition {
    opacity: 1;
    transition: opacity 0.3s ease;
}

/* Animação de fade-in para conteúdo */
.fade-in {
    animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

/* Animação de slide para elementos */
.slide-in {
    animation: slideIn 0.3s ease-in-out;
}

@keyframes slideIn {
    0% { transform: translateY(20px); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}

/* Animação para loading */
.loading-spinner {
    animation: rotate 1s linear infinite;
}

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

/* Animação para pulsar */
.pulse {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.7; transform: scale(1.05); }
    100% { opacity: 1; transform: scale(1); }
}

/* Animação para alertas e notificações */
.alert-animation {
    animation: alertSlide 0.5s ease-in-out;
}

@keyframes alertSlide {
    0% { transform: translateY(-20px); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}

/* Animação para botões */
.btn-hover-effect {
    transition: all 0.2s ease;
}

.btn-hover-effect:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

/* Animação para cards */
.card-hover {
    transition: all 0.3s ease;
}

.card-hover:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

/* Animação para destaque de cards no Kanban */
@keyframes highlight {
    0% { box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.2); }
    50% { box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.4); }
    100% { box-shadow: 0 0 0 2px rgba(13, 110, 253, 0); }
}

/* Animação para sidebar */
.sidebar-animation {
    transition: width 0.3s ease, margin-left 0.3s ease;
}

/* Animação para dropdown menus */
.dropdown-menu {
    animation: growDown 0.2s ease-in-out;
    transform-origin: top center;
}

@keyframes growDown {
    0% { transform: scaleY(0); }
    80% { transform: scaleY(1.1); }
    100% { transform: scaleY(1); }
}

/* Animações específicas para o Kanban */
.kanban-container-transition {
    transition: all 0.3s ease-in-out;
}

/* Efeito de transição suave para as setas de navegação */
.kanban-scroll-arrow {
    transition: opacity 0.2s ease, transform 0.2s ease, background-color 0.2s ease;
}

/* Efeito de aparecimento suave das colunas */
.kanban-column-wrapper {
    animation: fadeInScale 0.3s ease-out;
    animation-fill-mode: both;
}

@keyframes fadeInScale {
    0% { opacity: 0; transform: scale(0.95); }
    100% { opacity: 1; transform: scale(1); }
}

/* Animação para quando um cartão é movido entre colunas */
.kanban-card-moving {
    animation: moveHighlight 0.6s ease-in-out;
}

@keyframes moveHighlight {
    0% { transform: scale(0.95); opacity: 0.7; }
    50% { transform: scale(1.02); opacity: 0.9; }
    100% { transform: scale(1); opacity: 1; }
}