/* css/style.css */

/* Suavização de transição entre abas */
.view-section {
    animation: fadeIn 0.4s ease-in-out;
}

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

/* Scrollbar personalizada (mais elegante que a padrão do navegador) */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: #f1f5f9; 
}

::-webkit-scrollbar-thumb {
    background: #cbd5e1; 
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #94a3b8; 
}

/* Loading Overlay (Spinner centralizado) */
.loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(2px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 50;
}

/* Classes utilitárias para o Status Badge */
.badge {
    @apply px-2 py-1 rounded text-xs font-bold border;
}
.badge-success { background-color: #dcfce7; color: #166534; border-color: #bbf7d0; } /* green */
.badge-warning { background-color: #fef9c3; color: #854d0e; border-color: #fde047; } /* yellow */
.badge-info    { background-color: #dbeafe; color: #1e40af; border-color: #bfdbfe; } /* blue */
.badge-error   { background-color: #fee2e2; color: #991b1b; border-color: #fecaca; } /* red */

/* Inputs com erro */
input.error, select.error {
    border-color: #ef4444;
    background-color: #fef2f2;
}