/* css/nexa-admin.css */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&display=swap');

:root {
    --bg-main: #1A1D24; /* Color grafito neutro (descanso visual) */
    --text-main: #F8FAFC; /* Blanco brillante para máxima legibilidad */
    --text-muted: #CBD5E1; /* Gris claro, perfectamente legible sobre fondo oscuro */
    --primary-accent: #3B82F6; /* Azul moderno pero suave */
    --secondary-accent: #0EA5E9; /* Cyan tenue */
    --glass-bg: #22262E; /* Tarjetas en gris oscuro, sin brillos fuertes */
    --glass-border: #333A47; /* Bordes neutros */
}

/* Forzar contraste en todo el texto, incluyendo tablas y selectores de Bootstrap */
body, table, td, th, .text-muted {
    color: var(--text-main) !important;
}

.text-muted {
    color: var(--text-muted) !important;
}

/* Colores de tablas Bootstrap */
.table {
    color: var(--text-main);
    border-color: var(--glass-border);
}
.table td, .table th {
    border-color: var(--glass-border);
    color: inherit;
}
.table-striped>tbody>tr:nth-of-type(odd)>* {
    color: var(--text-main);
}
.table-hover>tbody>tr:hover>* {
    color: #FFFFFF;
}

body {
    background-color: var(--bg-main);
    background-image: none; /* Quitamos radiantes para máxima limpieza visual */
    color: var(--text-main);
    font-family: 'Outfit', sans-serif;
    min-height: 100vh;
}

.glass-card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); /* Sombra muy sutil */
}

.btn-cyan {
    background: var(--primary-accent);
    color: #FFF;
    font-weight: 600;
    border: none;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.btn-cyan:hover {
    background: #4F46E5; /* Indigo suave */
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
    color: #FFF;
}

.btn-magenta {
    background: #8B5CF6; /* Violeta relajante */
    color: #FFF;
    font-weight: 600;
    border: none;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.btn-magenta:hover {
    background: #7C3AED;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
    color: #FFF;
}

.form-control-glass {
    background: #14171D; /* Input ligeramente más oscuro que el fondo para hundimiento */
    border: 1px solid var(--glass-border);
    color: #E2E8F0;
    border-radius: 8px;
}

.form-control-glass:focus {
    background: #1A1D24;
    border-color: var(--primary-accent);
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.25);
    color: #FFF;
}

.sidebar {
    width: 250px;
    height: 100vh;
    position: fixed;
    border-right: 1px solid var(--glass-border);
    background: #1E2129; /* Igual que el fondo pero muy levemente elevado */
    z-index: 100;
}

.main-content {
    margin-left: 250px;
    padding: 30px;
}

@media (max-width: 768px) {
    .sidebar { width: 100%; height: auto; position: relative; }
    .main-content { margin-left: 0; padding: 15px; }
}

.nav-link {
    color: var(--text-muted);
    margin: 5px 15px;
    border-radius: 8px;
    transition: all 0.2s;
    font-weight: 600;
}

.nav-link:hover, .nav-link.active {
    background: #2D333F; /* Hovers suaves */
    color: #F8FAFC; /* Texto brillante en selección */
}

.stat-card {
    border-left: 4px solid var(--primary-accent);
}

.text-gradient {
    color: var(--primary-accent);
    /* Quitamos el degradado en texto para evitar fatiga visual */
    font-weight: 800;
}
