/* =====================================================================
   Administrador de Flujos — Universidad Maimónides
   Paleta institucional: azul marino + celeste institucional
   ===================================================================== */

:root {
    --azul: #1c2e5c;
    --azul-oscuro: #111d3c;
    --azul-medio: #2a5fa0;
    --celeste: #3ab4e5;
    --celeste-oscuro: #1e97cb;
    --fondo: #f2f5f9;
    --texto: #24323f;
    --gris: #6b7a89;
    --borde: #d8e0e8;
    --blanco: #ffffff;
    --rojo: #c0392b;
    --verde: #1e8449;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: "Segoe UI", "Trebuchet MS", Arial, sans-serif;
    background: var(--fondo);
    color: var(--texto);
    font-size: 15px;
}

a { color: var(--azul-medio); }

/* ------------------------------------------------------------------ */
/* Encabezado y navegación                                             */
/* ------------------------------------------------------------------ */
.encabezado {
    background: linear-gradient(135deg, var(--azul-oscuro) 0%, var(--azul) 70%);
    color: var(--blanco);
    border-bottom: 4px solid var(--celeste);
    padding: 0 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.marca {
    padding: 10px 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.marca-logo-link { display: inline-block; line-height: 0; }

.marca-logo {
    height: 38px;
    width: auto;
    display: block;
    /* Sobre fondo oscuro: logo con transparencia → invertir a blanco puro */
    filter: brightness(0) invert(1);
}

.marca-sub {
    display: block;
    font-size: 12px;
    color: #bcd2e6;
    padding-left: 2px;
    margin-top: 5px;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    margin-top: 2px;
}

.navegacion {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}

.navegacion a {
    color: #dce8f3;
    text-decoration: none;
    padding: 10px 14px;
    border-radius: 6px;
    font-size: 14px;
}

.navegacion a:hover { background: rgba(255, 255, 255, .12); color: var(--blanco); }

.nav-usuario {
    color: #bcd2e6;
    font-size: 13.5px;
    margin: 0 10px 0 18px;
    padding-left: 18px;
    border-left: 1px solid rgba(255, 255, 255, .25);
}

.nav-salir {
    background: rgba(41, 171, 226, .85);
    color: var(--blanco) !important;
    font-weight: 600;
}

.nav-salir:hover { background: var(--celeste-oscuro); }

/* ------------------------------------------------------------------ */
/* Estructura                                                          */
/* ------------------------------------------------------------------ */
.contenido {
    max-width: 1080px;
    margin: 28px auto;
    padding: 0 20px;
}

.pie {
    text-align: center;
    color: var(--gris);
    font-size: 12.5px;
    padding: 26px 0 34px;
}

.titulo-pagina {
    color: var(--azul);
    font-size: 24px;
    font-weight: 600;
    margin: 0 0 4px;
}

.subtitulo-pagina {
    color: var(--gris);
    margin: 0 0 22px;
    font-size: 14px;
}

.tarjeta {
    background: var(--blanco);
    border: 1px solid var(--borde);
    border-radius: 10px;
    padding: 22px 26px;
    margin-bottom: 22px;
    box-shadow: 0 1px 3px rgba(0, 35, 70, .06);
}

.tarjeta h2 {
    color: var(--azul);
    font-size: 17px;
    margin: 0 0 14px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--celeste);
    display: inline-block;
}

/* ------------------------------------------------------------------ */
/* Formularios                                                         */
/* ------------------------------------------------------------------ */
.campo-grupo { margin-bottom: 16px; }

.campo-etiqueta {
    display: block;
    font-weight: 600;
    color: var(--azul);
    margin-bottom: 5px;
    font-size: 14px;
}

.campo-requerido { color: var(--rojo); }

.campo-ayuda {
    display: block;
    color: var(--gris);
    font-size: 12.5px;
    margin-top: 4px;
}

.entrada,
input[type="text"], input[type="password"], input[type="email"],
input[type="date"], textarea, select {
    width: 100%;
    max-width: 620px;
    padding: 9px 11px;
    border: 1px solid var(--borde);
    border-radius: 6px;
    font: inherit;
    color: var(--texto);
    background: var(--blanco);
}

.entrada:focus,
input:focus, textarea:focus, select:focus {
    outline: 2px solid rgba(14, 110, 184, .35);
    border-color: var(--azul-medio);
}

.entrada-corta { max-width: 240px; }

.lista-opciones { list-style: none; margin: 4px 0 0; padding: 0; }
.lista-opciones td, .lista-opciones label { padding: 2px 6px 2px 4px; }
.opcion-otro-texto { margin: 4px 0 0 24px; max-width: 420px; }

/* ------------------------------------------------------------------ */
/* Botones                                                             */
/* ------------------------------------------------------------------ */
.btn {
    display: inline-block;
    border: none;
    border-radius: 6px;
    padding: 10px 22px;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    margin-right: 8px;
}

.btn-primario { background: var(--azul); color: var(--blanco); }
.btn-primario:hover { background: var(--azul-medio); }

.btn-acento { background: var(--celeste); color: var(--blanco); }
.btn-acento:hover { background: var(--celeste-oscuro); }

.btn-peligro { background: var(--rojo); color: var(--blanco); }
.btn-peligro:hover { background: #a93226; }

.btn-secundario { background: #e4eaf1; color: var(--azul); }
.btn-secundario:hover { background: #d3dde8; }

/* ------------------------------------------------------------------ */
/* Tablas / grillas                                                    */
/* ------------------------------------------------------------------ */
.grilla {
    width: 100%;
    border-collapse: collapse;
    background: var(--blanco);
}

.grilla th {
    background: var(--azul);
    color: var(--blanco);
    text-align: left;
    padding: 10px 12px;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .5px;
}

.grilla th a { color: var(--blanco); text-decoration: none; }

.grilla td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--borde);
    vertical-align: top;
}

.grilla tr:nth-child(even) td { background: #f7fafc; }
.grilla tr:hover td { background: #eef4fa; }

.sin-datos { color: var(--gris); font-style: italic; padding: 14px 4px; }

/* ------------------------------------------------------------------ */
/* Insignias de estado (los estados son datos: clase derivada del nombre) */
/* ------------------------------------------------------------------ */
.estado {
    display: inline-block;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 12.5px;
    font-weight: 600;
    background: #e4eaf1;
    color: var(--azul);
    white-space: nowrap;
}

.estado-solicitado { background: #e4eaf1; color: var(--azul); }
.estado-recibido { background: #fdf0e3; color: #b05c10; }
.estado-en-aprobacion { background: #efe6f7; color: #6b3fa0; }
.estado-aprobado { background: #e3f3e8; color: var(--verde); }
.estado-rechazado { background: #fae5e2; color: var(--rojo); }

/* ------------------------------------------------------------------ */
/* Mensajes                                                            */
/* ------------------------------------------------------------------ */
.mensaje-error {
    display: block;
    background: #fae5e2;
    border-left: 4px solid var(--rojo);
    color: var(--rojo);
    padding: 11px 14px;
    border-radius: 6px;
    margin: 0 0 16px;
    white-space: pre-line;
}

.mensaje-ok {
    display: block;
    background: #e3f3e8;
    border-left: 4px solid var(--verde);
    color: var(--verde);
    padding: 11px 14px;
    border-radius: 6px;
    margin: 0 0 16px;
}

.aviso {
    background: #fdf6ec;
    border: 1px solid #f0d9b6;
    border-left: 4px solid var(--celeste);
    border-radius: 6px;
    padding: 13px 16px;
    margin-bottom: 20px;
    font-size: 13.5px;
    color: #6e5028;
}

.aviso ul { margin: 6px 0 0; padding-left: 20px; }

/* ------------------------------------------------------------------ */
/* Detalle de pedido                                                   */
/* ------------------------------------------------------------------ */
.ficha { width: 100%; border-collapse: collapse; }

.ficha th {
    text-align: left;
    color: var(--azul);
    width: 280px;
    padding: 8px 10px 8px 0;
    vertical-align: top;
    font-size: 14px;
}

.ficha td {
    padding: 8px 0;
    white-space: pre-line;
    vertical-align: top;
}

.ficha tr { border-bottom: 1px solid #edf1f5; }

.comentario {
    border-left: 3px solid var(--azul-medio);
    background: #f7fafc;
    border-radius: 0 8px 8px 0;
    padding: 10px 14px;
    margin-bottom: 10px;
}

.comentario-meta { color: var(--gris); font-size: 12.5px; margin-bottom: 3px; }
.comentario-texto { white-space: pre-line; }

.cabecera-datos { display: flex; flex-wrap: wrap; gap: 26px; margin-bottom: 4px; }
.cabecera-datos .dato { font-size: 14px; }
.cabecera-datos .dato b { color: var(--azul); display: block; font-size: 12.5px; text-transform: uppercase; letter-spacing: .5px; }

/* ------------------------------------------------------------------ */
/* Tablero de inicio                                                   */
/* ------------------------------------------------------------------ */
.tablero { display: flex; flex-wrap: wrap; gap: 18px; }

.tablero a.opcion {
    flex: 1 1 230px;
    background: var(--blanco);
    border: 1px solid var(--borde);
    border-top: 4px solid var(--celeste);
    border-radius: 10px;
    padding: 20px 22px;
    text-decoration: none;
    color: var(--texto);
    box-shadow: 0 1px 3px rgba(0, 35, 70, .06);
}

.tablero a.opcion:hover { border-color: var(--azul-medio); box-shadow: 0 3px 10px rgba(0, 35, 70, .12); }
.tablero a.opcion b { display: block; color: var(--azul); font-size: 16px; margin-bottom: 6px; }
.tablero a.opcion span { color: var(--gris); font-size: 13.5px; }

/* ------------------------------------------------------------------ */
/* Kanban                                                              */
/* ------------------------------------------------------------------ */
.kb-flujo-titulo {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -.4px;
    color: var(--azul-oscuro);
    margin: 0 0 16px;
    padding-left: 14px;
    border-left: 4px solid var(--celeste);
    line-height: 1.15;
}

.kanban-barra {
    background: var(--blanco);
    border: 1px solid var(--borde);
    border-left: 4px solid var(--celeste);
    border-radius: 8px;
    padding: 10px 16px;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    box-shadow: 0 1px 4px rgba(0,35,70,.06);
}
.filtros-total { margin-left: auto; font-size: 13px; color: var(--gris); font-weight: 500; }

.kb-label-unico {
    font-size: 15px;
    font-weight: 600;
    color: var(--azul);
}

.kb-filtro-label {
    font-size: 12.5px;
    color: var(--gris);
    white-space: nowrap;
}

.kanban {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    min-width: max-content;
}

.kb-col {
    width: 258px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
}

.kb-col-cab {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    padding: 0 2px;
}

.kb-col-nombre {
    font-size: 12.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: var(--azul);
}

.kb-col-count {
    background: var(--azul);
    color: var(--blanco);
    font-size: 11px;
    font-weight: 700;
    border-radius: 10px;
    padding: 1px 7px;
    min-width: 22px;
    text-align: center;
}

.kb-col[data-final="true"]   .kb-col-nombre { color: var(--verde); }
.kb-col[data-final="true"]   .kb-col-count  { background: var(--verde); }
.kb-col[data-rechazo="true"] .kb-col-nombre { color: var(--rojo); }
.kb-col[data-rechazo="true"] .kb-col-count  { background: var(--rojo); }

.kb-col-cuerpo {
    background: rgba(0,0,0,.04);
    border-radius: 10px;
    padding: 8px;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.kb-tarjeta {
    background: var(--blanco);
    border: 1px solid var(--borde);
    border-radius: 8px;
    padding: 11px 13px;
    box-shadow: 0 1px 3px rgba(0,35,70,.06);
    transition: box-shadow .15s, transform .15s;
}
.kb-tarjeta:hover {
    box-shadow: 0 4px 12px rgba(0,35,70,.13);
    transform: translateY(-1px);
}

.kb-col[data-final="true"]   .kb-tarjeta                { border-left: 3px solid var(--verde); }
.kb-col[data-rechazo="true"] .kb-tarjeta               { border-left: 3px solid var(--rojo); opacity: .7; }
.kb-col[data-rechazo="true"] .kb-tarjeta:hover          { opacity: 1; }

.kb-tarjeta-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 5px;
}
.kb-num {
    font-size: 11.5px;
    font-weight: 700;
    color: var(--gris);
}
.kb-solicitante {
    font-size: 13.5px;
    font-weight: 600;
    margin-bottom: 3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kb-resumen {
    font-size: 12px;
    color: var(--gris);
    margin-bottom: 9px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.kb-pie {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.kb-fecha { font-size: 11.5px; color: var(--gris); }
.kb-accion {
    font-size: 12px;
    font-weight: 600;
    color: var(--azul-medio);
    text-decoration: none;
    border: 1px solid var(--borde);
    border-radius: 5px;
    padding: 3px 9px;
    background: var(--fondo);
    transition: background .12s;
}
.kb-accion:hover { background: var(--azul-medio); color: var(--blanco); border-color: var(--azul-medio); }
.kb-accion.kb-procesar { background: var(--celeste); color: var(--blanco); border-color: var(--celeste); }
.kb-accion.kb-procesar:hover { background: var(--celeste-oscuro); }

.kb-vacia {
    text-align: center;
    color: var(--gris);
    font-size: 12.5px;
    padding: 16px 0;
    font-style: italic;
}

/* ------------------------------------------------------------------ */
/* Modal                                                               */
/* ------------------------------------------------------------------ */
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 20, 50, .55);
    z-index: 1000;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.modal-overlay.activo { display: flex; }

.modal-cuerpo {
    background: var(--blanco);
    border-radius: 10px;
    border-top: 4px solid var(--celeste);
    box-shadow: 0 12px 40px rgba(0, 20, 50, .35);
    padding: 26px 30px 22px;
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
}

.modal-encabezado {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 18px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--celeste);
}

.modal-titulo {
    color: var(--azul);
    font-size: 17px;
    margin: 0;
}

.modal-cerrar {
    background: none;
    border: none;
    font-size: 18px;
    color: var(--gris);
    cursor: pointer;
    line-height: 1;
    padding: 2px 4px;
    flex-shrink: 0;
    margin-left: 12px;
}

.modal-cerrar:hover { color: var(--rojo); }

.modal-pie {
    margin-top: 22px;
    padding-top: 16px;
    border-top: 1px solid var(--borde);
    display: flex;
    gap: 8px;
}

.tarjeta-acciones {
    margin-bottom: 16px;
}

/* ------------------------------------------------------------------ */
/* Login                                                               */
/* ------------------------------------------------------------------ */
.login-fondo {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--azul-oscuro) 0%, var(--azul) 55%, var(--azul-medio) 130%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.login-tarjeta {
    background: var(--blanco);
    border-radius: 12px;
    border-top: 5px solid var(--celeste);
    box-shadow: 0 18px 50px rgba(0, 15, 35, .4);
    padding: 38px 42px;
    width: 100%;
    max-width: 410px;
}

.login-marca { text-align: center; margin-bottom: 26px; }
.login-marca .nombre { display: block; color: var(--azul); font-size: 22px; font-weight: 700; }
.login-marca .sub { display: block; color: var(--gris); font-size: 12.5px; text-transform: uppercase; letter-spacing: 1.4px; margin-top: 4px; }
.login-tarjeta .btn { width: 100%; margin: 6px 0 0; padding: 11px; }
.login-pie { text-align: center; color: var(--gris); font-size: 12px; margin-top: 22px; }
