/* ============================================================================
   tema.css — Sistema de diseño del Sistema Educativo
   Inspirado en el look & feel de plantillas admin LMS (sidebar claro + topbar,
   cards con sombra suave, tipografía Poppins). Código original; no se copia
   CSS de plantillas de terceros.
   ============================================================================ */

:root {
    /* Paleta */
    --se-primario: #019ff8;
    --se-primario-oscuro: #0288d6;
    --se-primario-suave: #e6f5fe;
    --se-violeta: #733aeb;
    --se-violeta-suave: #efe9fd;
    --se-verde: #58baab;
    --se-verde-suave: #e7f5f3;
    --se-amarillo: #fec801;
    --se-amarillo-suave: #fff6da;
    --se-rosa: #f2426d;
    --se-rosa-suave: #fde7ed;

    /* Neutros */
    --se-texto: #191d33;
    --se-texto-tenue: #7a8194;
    --se-fondo: #f1f5f9;          /* gris con tinte azul: las tarjetas blancas "flotan" */
    --se-superficie: #ffffff;
    --se-borde: #e2e8f0;
    --se-marca: #3b4477;

    /* Sidebar oscuro elegante */
    --se-sidebar-bg: #0f172a;                    /* azul marino muy oscuro */
    --se-sidebar-borde: #1e293b;
    --se-sidebar-texto: #94a3b8;                 /* gris azulado, legible pero sutil */
    --se-sidebar-texto-hover: #ffffff;
    --se-sidebar-hover-bg: rgba(148, 163, 184, 0.12);
    --se-sidebar-seccion: #64748b;               /* etiquetas de sección */
    --se-sidebar-activo-bg: var(--se-primario);  /* tono del ítem activo (cambiá a #2563eb para indigo) */
    --se-sidebar-activo-texto: #ffffff;

    /* Formas */
    --se-radio: 6px;
    --se-radio-lg: 10px;
    --se-sombra: 0 0 35px rgba(154, 161, 171, 0.15);
    --se-sombra-fuerte: 0 4px 24px rgba(25, 29, 51, 0.12);

    /* Medidas del layout */
    --se-sidebar-ancho: 256px;
    --se-topbar-alto: 64px;

    /* Bootstrap: que sus componentes tomen nuestra paleta */
    --bs-primary: #019ff8;
    --bs-primary-rgb: 1, 159, 248;
    --bs-link-color: #019ff8;
    --bs-link-hover-color: #0288d6;
    --bs-body-font-family: "Poppins", system-ui, sans-serif;
    --bs-body-color: #191d33;
    --bs-body-bg: #f1f5f9;
    --bs-border-radius: 6px;
}

body {
    font-family: "Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;
    font-size: 14px;
    color: var(--se-texto);
    background-color: var(--se-fondo);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--se-texto);
    font-weight: 600;
}

a {
    color: var(--se-primario);
    text-decoration: none;
}

a:hover {
    color: var(--se-primario-oscuro);
}

/* ---- Botones ---------------------------------------------------------- */
.btn {
    border-radius: var(--se-radio);
    font-weight: 500;
    padding: 0.5rem 1.1rem;
}

.btn-primary {
    background-color: var(--se-primario);
    border-color: var(--se-primario);
    color: #fff;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--se-primario-oscuro) !important;
    border-color: var(--se-primario-oscuro) !important;
    color: #fff;
}

.btn-outline-primary {
    color: var(--se-primario);
    border-color: var(--se-primario);
}

.btn-outline-primary:hover {
    background-color: var(--se-primario);
    border-color: var(--se-primario);
    color: #fff;
}

.btn-link {
    color: var(--se-primario);
}

/* ---- Tarjetas --------------------------------------------------------- */
.card,
.se-tarjeta {
    background-color: var(--se-superficie);
    border: none;
    border-radius: var(--se-radio-lg);
    box-shadow: var(--se-sombra);
}

.card-header,
.se-tarjeta-cabecera {
    background-color: transparent;
    border-bottom: 1px solid var(--se-borde);
    padding: 1.1rem 1.35rem;
    font-weight: 600;
}

.card-body,
.se-tarjeta-cuerpo {
    padding: 1.35rem;
}

/* Título de sección reutilizable */
.se-titulo-seccion {
    font-size: 1.35rem;
    font-weight: 600;
    margin: 0;
}

.se-subtitulo {
    color: var(--se-texto-tenue);
    font-size: 0.9rem;
    margin: 0;
}

/* ---- Badges ----------------------------------------------------------- */
.badge {
    font-weight: 500;
    border-radius: 50rem;
    padding: 0.4em 0.75em;
}

.se-badge-primario { background-color: var(--se-primario-suave); color: var(--se-primario-oscuro); }
.se-badge-verde    { background-color: var(--se-verde-suave);    color: #2f8576; }
.se-badge-amarillo { background-color: var(--se-amarillo-suave); color: #b08a00; }
.se-badge-rosa     { background-color: var(--se-rosa-suave);     color: #c52a51; }
.se-badge-violeta  { background-color: var(--se-violeta-suave);  color: #5b2cc4; }

/* ---- Carrera no seleccionada en la lista de la sede ------------------- */
.se-carrera-inactiva { background-color: var(--bs-light, #f8f9fa); }
.se-carrera-inactiva .form-check-label { color: var(--se-tenue, #64748b); }

/* ---- Cinta de contexto (editor de establecimiento) -------------------- */
.se-contexto-sede {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem 0.85rem;
    padding: 0.6rem 1rem;
    border-radius: var(--se-radio);
    background-color: var(--se-primario-suave);
    color: var(--se-primario-oscuro);
    border-left: 4px solid var(--se-primario);
}

.se-contexto-sede > .bi-building { font-size: 1.1rem; }

.se-contexto-cue {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    padding: 0.15em 0.6em;
    border-radius: 50rem;
    background-color: #fff;
    color: var(--se-primario-oscuro);
}

.se-contexto-nombre { font-weight: 600; font-size: 1.05rem; }

.se-contexto-prov {
    font-size: 0.875rem;
    opacity: 0.85;
    margin-left: auto;
}

/* ---- Ícono en pastilla (para cards / encabezados) --------------------- */
.se-icono-pastilla {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: var(--se-radio);
    font-size: 1.4rem;
    flex-shrink: 0;
}

.se-icono-primario { background-color: var(--se-primario-suave); color: var(--se-primario); }
.se-icono-verde    { background-color: var(--se-verde-suave);    color: var(--se-verde); }
.se-icono-amarillo { background-color: var(--se-amarillo-suave); color: #d9a800; }
.se-icono-rosa     { background-color: var(--se-rosa-suave);     color: var(--se-rosa); }
.se-icono-violeta  { background-color: var(--se-violeta-suave);  color: var(--se-violeta); }

/* ---- Formularios ------------------------------------------------------ */
.form-control,
.form-select {
    border-radius: var(--se-radio);
    border-color: var(--se-borde);
    padding: 0.55rem 0.9rem;
    font-size: 0.92rem;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--se-primario);
    box-shadow: 0 0 0 0.18rem rgba(1, 159, 248, 0.18);
}

.form-label {
    font-weight: 500;
    font-size: 0.88rem;
    margin-bottom: 0.35rem;
}

/* ---- Tablas ----------------------------------------------------------- */
.table {
    --bs-table-color: var(--se-texto);
    margin: 0;
}

.table thead th {
    background-color: var(--se-fondo);
    color: var(--se-texto-tenue);
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: none;
    padding: 0.8rem 1rem;
    white-space: nowrap;
}

.table tbody td {
    padding: 0.85rem 1rem;
    vertical-align: middle;
    border-color: var(--se-borde);
}

.table tbody tr:hover {
    background-color: var(--se-primario-suave);
}

/* ---- Avatar con iniciales -------------------------------------------- */
.se-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--se-primario-suave);
    color: var(--se-primario-oscuro);
    font-weight: 600;
    font-size: 0.85rem;
    flex-shrink: 0;
}

/* ---- Buscador dentro de una tarjeta/tabla ----------------------------- */
.se-buscador-tabla {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background-color: var(--se-fondo);
    border-radius: var(--se-radio);
    padding: 0.45rem 0.9rem;
    min-width: 260px;
    color: var(--se-texto-tenue);
}

.se-buscador-tabla input {
    border: none;
    background: none;
    outline: none;
    width: 100%;
    font-size: 0.9rem;
    color: var(--se-texto);
}

/* ---- Sección de formulario (subtítulo azul + línea) ------------------- */
.se-form-seccion {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--se-primario);
    font-weight: 600;
    font-size: 0.95rem;
    margin: 1.4rem 0 0.85rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--se-borde);
}

.se-form-seccion:first-child {
    margin-top: 0;
}

/* ---- Pie de tarjeta --------------------------------------------------- */
.card-footer {
    background-color: transparent;
    border-top: 1px solid var(--se-borde);
    padding: 0.9rem 1.35rem;
}

/* ---- Texto utilitario ------------------------------------------------- */
.text-primary { color: var(--se-primario) !important; }
.text-tenue { color: var(--se-texto-tenue) !important; }

/* ---- Toasts (avisos de resultado) ------------------------------------- */
.se-toasts {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 1080;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: min(360px, calc(100vw - 2rem));
}

.se-toast {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    padding: 0.7rem 0.85rem;
    border-radius: var(--se-radio-lg);
    background-color: var(--se-superficie);
    box-shadow: var(--se-sombra-fuerte);
    border-left: 4px solid var(--se-primario);
    animation: se-toast-entra 0.18s ease-out;
}

.se-toast-icono { font-size: 1.1rem; line-height: 1.4; }
.se-toast-msg { flex: 1; font-size: 0.9rem; color: var(--se-texto); line-height: 1.4; }
.se-toast-cerrar {
    border: 0;
    background: transparent;
    cursor: pointer;
    color: var(--se-texto-tenue);
    padding: 0;
    line-height: 1;
    font-size: 0.8rem;
}
.se-toast-cerrar:hover { color: var(--se-texto); }

.se-toast-exito { border-left-color: var(--se-verde); }
.se-toast-exito .se-toast-icono { color: var(--se-verde); }
.se-toast-error { border-left-color: var(--se-rosa); }
.se-toast-error .se-toast-icono { color: var(--se-rosa); }
.se-toast-info { border-left-color: var(--se-primario); }
.se-toast-info .se-toast-icono { color: var(--se-primario); }

@keyframes se-toast-entra {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
