/* 
   IPSD5 - Estilos Premium
   Tema: Clean & Light (White & Royal Blue)
*/

:root {
    /* Paleta de Colores Personalizada (Clara) */
    --bs-primary: #3b82f6;
    /* Azul Real Vibrante (Más claro y energético) */
    --bs-primary-rgb: 59, 130, 246;

    --bs-secondary: #64748b;
    /* Gris Azulado (Slate) */

    --bs-accent: #f59e0b;
    /* Ámbar (Cálido y legible) */
    --bs-accent-rgb: 245, 158, 11;

    --bs-body-bg: #f8fafc;
    /* Gris muy pálido, casi blanco */
    --bs-body-color: #334155;
    /* Texto gris oscuro suave */
}

/* Tipografía */
body {
    font-family: 'Open Sans', system-ui, -apple-system, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
.navbar-brand {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    letter-spacing: -0.5px;
    color: #1e293b;
    /* Texto oscuro para títulos */
}

/* Clases de Utilidad de Texto para sobrescribir Bootstrap 'text-primary' si hace falta */
.text-primary {
    color: var(--bs-primary) !important;
}

/* Navbar Light Premium */
.navbar {
    background-color: #ffffff !important;
    background: #ffffff !important;
    /* Sobrescribimos el gradiente anterior */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.navbar-brand {
    font-size: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--bs-primary) !important;
    /* Logo en Azul */
}

.nav-link {
    font-weight: 600;
    font-size: 0.95rem;
    color: #475569 !important;
    /* Gris oscuro */
    transition: all 0.3s ease;
    margin: 0 5px;
    padding-bottom: 5px;
    border-bottom: 2px solid transparent;
}

.nav-link:hover,
.nav-link.active {
    color: var(--bs-primary) !important;
    /* Azul al pasar el mouse */
}

.nav-link.active {
    border-bottom: 2px solid var(--bs-primary);
}

/* Botones Personalizados */
.btn-primary {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    box-shadow: 0 4px 6px rgba(59, 130, 246, 0.25);
    /* Sombra de color match */
    padding: 0.6rem 1.5rem;
    font-weight: 600;
}

.btn-primary:hover {
    background-color: #2563eb;
    /* Un tono más oscuro */
    border-color: #2563eb;
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(59, 130, 246, 0.35);
}

/* Tarjetas (Cards) - Estilo Clean */
.card {
    border: 1px solid rgba(226, 232, 240, 0.8);
    border-radius: 16px;
    background-color: #ffffff;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.02);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.05);
    /* Sombra suave 'Apple style' */
}

.card-header {
    background-color: #ffffff;
    border-bottom: 1px solid rgba(226, 232, 240, 0.8);
    border-radius: 16px 16px 0 0 !important;
    padding: 1.5rem;
}

/* Headers de Sección */
/* Forzamos que los bg-primary (encabezados de página) tengan un degradado suave azul */
section.bg-primary {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
}

section.bg-primary h1,
section.bg-primary h2,
section.bg-primary h3,
section.bg-primary i {
    color: #ffffff !important;
}

/* Inputs y Formularios */
.form-control,
.form-select {
    border-radius: 10px;
    border: 1px solid #cbd5e1;
    background-color: #ffffff;
    padding: 0.8rem 1rem;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
    /* Ring azul suave */
}

/* Footer limpio */
.footer {
    background-color: #ffffff;
    border-top: 1px solid #e2e8f0 !important;
    color: #64748b;
    padding: 3rem 0;
}