@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap');

:root {
    --primary-color: #1D1D1B; /* Zavant Black */
    --primary-color-hover: #333333; /* Darker Gray for hover */
    --accent-color: #FFB600; /* Zavant Gold */
    --secondary-color: #8C8C8C; /* Gray */
    --background-color: #F4F5F7; /* Fondo gris claro */
    --sidebar-background: #000000C4;
    --text-color: #1D1D1B; /* Main text color */
    --text-color-light: #FFFFFF; /* Text on dark backgrounds */
    --card-background: #FFFFFF;
    --border-color: #DFE1E6;
    --font-family: 'Inter', sans-serif;
}

body {
    font-family: var(--font-family);
    background-color: var(--background-color);
    color: var(--text-color);
}

/* --- Estilos de Componentes --- */

.primary-button {
    background-color: var(--primary-color);
    color: var(--text-color-light);
    font-weight: 600;
    padding: 0.65rem 1.25rem;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
    text-align: center;
    display: inline-block;
}

.primary-button:hover {
    background-color: var(--primary-color-hover);
}

.secondary-button {
    background-color: #F4F5F7;
    color: var(--text-color);
    font-weight: 600;
    padding: 0.5rem 1rem;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}

.secondary-button:hover {
    background-color: #EBECF0;
}

.form-input {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: #FAFBFC;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(0, 82, 204, 0.2);
}

.card {
    background-color: var(--card-background);
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 1px 3px 0 rgba(9, 30, 66, 0.2), 0 1px 2px 0 rgba(9, 30, 66, 0.15);
}

/* --- Sobrescritura de Layout --- */

#sidebar { background-color: var(--sidebar-background); color: var(--text-color-light); }
#sidebar h2 { color: rgba(255, 255, 255, 0.7); }
#sidebar a:hover, #sidebar a.active { background-color: rgba(255, 255, 255, 0.1); }
#login-view { background-color: var(--background-color); }

/* --- Estilos de Tabla --- */
.data-table { width: 100%; border-collapse: collapse; }
.data-table thead { background-color: #F4F5F7; }
.data-table th, .data-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border-color); }
.data-table th { font-size: 0.75rem; font-weight: 600; color: var(--secondary-color); text-transform: uppercase; letter-spacing: 0.5px; }

/* Insignia de Estado */
.status-badge { padding: 4px 10px; border-radius: 12px; font-size: 0.75rem; font-weight: 700; display: inline-block; line-height: 1.5; }
.status-badge.completed { background-color: #E3FCEF; color: #006644; }
.status-badge.pending { background-color: #FFFAE6; color: #974F0C; }

/* Bloque de Coherencia */
.p-4.rounded-lg { background-color: #FAFBFC; border: 1px solid #DFE1E6; }

@media print {
    body * {
        visibility: hidden;
    }
    #report-content, #report-content * {
        visibility: visible;
    }
    #report-content {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        padding: 20px;
    }
    .no-print {
        display: none !important;
    }
    canvas {
        max-width: 100% !important;
    }
}
