/* ====== DESIGN TOKENS ====== */
:root {
    /* Brand — navy + gold */
    --navy-900: #07101F;
    --navy-800: #0B1729;
    --navy-700: #0F1F3A;
    --navy-600: #16294A;
    --navy-500: #1E365E;
    --navy-400: #2F4A78;
    --paper: #F7F5EE;
    --paper-2: #EFECE2;
    --paper-3: #E6E1D2;
    --ink-900: #0B1729;
    --ink-700: #2A3144;
    --ink-500: #5B6478;
    --ink-400: #828BA0;
    --ink-300: #B5BBC9;
    /* Accents */
    --gold: #FBC42E;
    --gold-700: #E0A800;
    --gold-300: #FDE69B;
    --red: #D7344B;
    --green: #3F9D5C;
    --blue: #2F6BD8;
    --orange: #F08A2A;
    /* Derived */
    --gold-ink:     #5C4500;
    --gold-light:   #FFD54A;
    --sidebar-text: #E9E4D2;
    --cream:        #F2EEDF;
    /* Tweakable */
    --accent: var(--gold);
    --accent-ink: #0B1729;
    --radius: 12px;
    --radius-sm: 8px;
    --radius-lg: 18px;
    --row-pad-y: 12px;
    --row-pad-x: 14px;
    --gap: 16px;
    --font-sans: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
    --font-display: "Space Grotesk", "Plus Jakarta Sans", sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;
    /* Surfaces — light default */
    --bg: var(--paper);
    --bg-elev: #FFFFFF;
    --bg-soft: #FBF9F2;
    --bg-inset: #F1EEE3;
    --border: #E2DDCD;
    --border-strong: #CFC8B3;
    --text: var(--ink-900);
    --text-muted: var(--ink-500);
    --text-soft: var(--ink-400);
    --shadow-sm: 0 1px 2px rgba(11,23,41,.04), 0 1px 1px rgba(11,23,41,.03);
    --shadow: 0 6px 16px -8px rgba(11,23,41,.16), 0 2px 4px -2px rgba(11,23,41,.06);
    --shadow-lg: 0 24px 48px -24px rgba(11,23,41,.30), 0 8px 16px -8px rgba(11,23,41,.10);
    /* Legacy compat */
    --primary: var(--navy-800);
    --primary-hover: var(--navy-700);
    --primary-dark: var(--navy-900);
    --body-bg: var(--bg);
    --card-bg: var(--bg-elev);
    --text-dark: var(--text);
    --text-gray: var(--text-muted);
    --border-color: var(--border);
    --sidebar-bg: var(--navy-800);
    /* Bootstrap 5 overrides */
    --bs-body-font-family: var(--font-sans);
    --bs-body-color: var(--text);
    --bs-body-bg: var(--bg);
    --bs-border-color: var(--border);
    --bs-border-radius: var(--radius-sm);
    --bs-primary: var(--navy-800);
    --bs-primary-rgb: 11, 23, 41;
}

[data-theme="dark"] {
    --bg: var(--navy-900);
    --bg-elev: #0E1B33;
    --bg-soft: var(--navy-800);
    --bg-inset: #050B17;
    --border: #1B2A48;
    --border-strong: #2A3F66;
    --text: var(--cream);
    --text-muted: #9AA4B9;
    --text-soft: #6E7791;
    --paper: var(--navy-900);
    --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
    --shadow: 0 8px 24px -10px rgba(0,0,0,.6), 0 2px 6px -2px rgba(0,0,0,.4);
    --shadow-lg: 0 30px 60px -20px rgba(0,0,0,.7);
    --bs-body-color: var(--cream);
    --bs-body-bg: var(--navy-900);
}

/* ====== RESET ====== */
*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-feature-settings: "ss01","cv11";
    font-size: 14px;
    line-height: 1.5;
    height: 100%;
    overflow: hidden;
}

button {
    font-family: inherit;
    cursor: pointer;
}

input, select, textarea {
    font-family: inherit;
    color: inherit;
}

a {
    color: var(--text);
    text-decoration: none;
}

    a:hover {
        color: var(--text);
        text-decoration: none;
    }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--text);
    margin: 0 0 .5rem;
    line-height: 1.2;
}

    h1:focus {
        outline: none;
    }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; border: 2px solid var(--bg); }
::-webkit-scrollbar-track { background: transparent; }

/* ====== APP SHELL (CSS Grid) ====== */
.app {
    display: grid;
    grid-template-columns: 248px 1fr;
    grid-template-rows: 74px 1fr;
    grid-template-areas:
        "sidebar topbar"
        "sidebar main";
    height: 100vh;
    height: 100dvh;
    transition: grid-template-columns 0.22s ease;
}
/* Sidebar colapsado manualmente */
:root[data-sidebar-collapsed="true"] .app {
    grid-template-columns: 64px 1fr;
}

:root[data-sidebar-collapsed="true"] .sidebar .brand-text,
:root[data-sidebar-collapsed="true"] .sidebar .nav-label,
:root[data-sidebar-collapsed="true"] .sidebar .nav-item .lbl,
:root[data-sidebar-collapsed="true"] .sidebar a.nav-item .lbl,
:root[data-sidebar-collapsed="true"] .sidebar-foot .who {
    display: none;
}

:root[data-sidebar-collapsed="true"] .nav-item,
:root[data-sidebar-collapsed="true"] a.nav-item {
    justify-content: center;
    padding: 10px;
    overflow: visible;
}

:root[data-sidebar-collapsed="true"] .nav-scroll {
    padding-bottom: 72px; /* evita que el último icono solape el sidebar-foot */
}

:root[data-sidebar-collapsed="true"] .nav-item .count {
    position: absolute;
    top: 3px;
    right: 3px;
    font-size: 9px;
    padding: 0 4px;
    height: 15px;
    line-height: 15px;
    min-width: 15px;
    margin-left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

:root[data-sidebar-collapsed="true"] .brand {
    justify-content: center;
    padding: 18px 0 16px;
}

:root[data-sidebar-collapsed="true"] .sidebar-foot {
    justify-content: center;
    padding: 12px 0 18px;
    background: var(--navy-800); /* cubre cualquier icono que desborde */
    position: relative;          /* entra en la capa de posicionados */
    z-index: 1;                  /* se pinta por encima de los nav-item */
}

.sidebar {
    grid-area: sidebar;
    background: var(--navy-800);
    color: var(--sidebar-text);
    border-right: 1px solid var(--navy-700);
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.topbar {
    grid-area: topbar;
    background: var(--bg-elev);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    padding: 0 24px;
    gap: 16px;
    z-index: 5;
}

.main {
    grid-area: main;
    overflow: auto;
    padding: 24px 28px 60px;
}

/* ====== SIDEBAR ====== */
.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 18px 16px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    flex-shrink: 0;
}

.brand-logo {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--gold);
    display: grid;
    place-items: center;
    color: var(--navy-900);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 20px;
    letter-spacing: -0.02em;
    box-shadow: 0 6px 16px -8px rgba(251,196,46,.6);
    overflow: hidden;
    flex-shrink: 0;
}

    .brand-logo img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 10px;
    }

.brand-text {
    line-height: 1.1;
    overflow: hidden;
}

    .brand-text .t1 {
        font-family: var(--font-display);
        font-weight: 700;
        font-size: 15px;
        letter-spacing: -0.01em;
        color: #fff;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .brand-text .t2 {
        font-size: 11px;
        color: rgba(255,255,255,.55);
        letter-spacing: 0.04em;
        text-transform: uppercase;
        white-space: nowrap;
    }

.nav-scroll {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 14px 10px 10px;
}

.nav-group {
    margin-bottom: 6px;
}

/* Enlace fijo (Inicio): fuera del acordeón, anclado arriba */
.nav-pinned {
    margin-bottom: 6px;
}

.nav-label {
    font-size: 10.5px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    padding: 10px 12px 6px;
}

/* ── Acordeón del menú lateral ──────────────────────────────────────────────
   La cabecera de cada sección (.nav-label) es un <button>: al pulsarla se
   pliega/despliega su cuerpo (.nav-group__body). Solo aplica al menú con
   literales; en modo icono (compacto / responsive estrecho) se ignora y se
   muestran todos los items (ver overrides más abajo y en las media queries). */
.nav-group__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-family: inherit;   /* tamaño/espaciado/color los aporta .nav-label */
    text-align: left;
    transition: color .15s;
}

    .nav-group__header:hover {
        color: rgba(255,255,255,.6);
    }

.nav-group__chevron {
    font-size: 10px;
    opacity: .6;
    flex-shrink: 0;
    transition: transform .2s ease;
}

.nav-group.is-open .nav-group__chevron {
    transform: rotate(180deg);
}

/* Cuerpo plegable. Animación con grid-template-rows (0fr↔1fr): se desliza hasta
   la altura exacta del contenido, sin números mágicos ni recortes de contenido. */
.nav-group__body {
    display: grid;
    grid-template-rows: 1fr;
    transition: grid-template-rows .24s ease;
}

.nav-group:not(.is-open) > .nav-group__body {
    grid-template-rows: 0fr;
}

.nav-group__inner {
    overflow: hidden;
    min-height: 0;
    /* Gutter lateral: evita que overflow:hidden recorte la barra dorada del item
       activo (.nav-item.active::before, en left:-10px). El padding compensa el
       margin negativo para que los items conserven exactamente su posición. */
    margin: 0 -12px;
    padding: 0 12px;
}

/* Modo compacto manual (desktop): el acordeón se ignora, todo visible */
:root[data-sidebar-collapsed="true"] .nav-group__body {
    grid-template-rows: 1fr !important;
}

/* En modo icono no hay nombres de sección → separador (hr) entre grupos.
   Sin !important para que el drawer móvil (≤700px) pueda anularlo. */
:root[data-sidebar-collapsed="true"] .nav-group {
    border-top: 1px solid rgba(255,255,255,.08);
    margin-top: 8px;
    padding-top: 8px;
}

/* Respeta la preferencia de reducir movimiento */
@media (prefers-reduced-motion: reduce) {
    .nav-group__body { transition: none; }
    .nav-group__chevron { transition: none; }
}

/* Nav items — handle both <a> (NavLink) and <button> */
.nav-item, a.nav-item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 9px 12px;
    border-radius: 9px;
    color: rgba(255,255,255,.74);
    font-weight: 500;
    font-size: 13.5px;
    cursor: pointer;
    border: 0;
    background: transparent;
    width: 100%;
    text-align: left;
    position: relative;
    transition: background .15s, color .15s;
    white-space: nowrap;
    overflow: hidden;
    text-decoration: none;
}

    .nav-item:hover, a.nav-item:hover {
        background: rgba(255,255,255,.04);
        color: #fff;
        text-decoration: none;
    }

    .nav-item .icon, a.nav-item .fas, a.nav-item .far, a.nav-item .fab {
        width: 18px;
        height: 18px;
        opacity: 0.85;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 15px;
    }

    .nav-item.active, a.nav-item.active {
        background: rgba(251,196,46,.10);
        color: #fff;
    }

        .nav-item.active::before, a.nav-item.active::before {
            content: "";
            position: absolute;
            left: -10px;
            top: 8px;
            bottom: 8px;
            width: 3px;
            background: var(--gold);
            border-radius: 0 4px 4px 0;
        }

    .nav-item .count {
        margin-left: auto;
        font-size: 11px;
        font-family: var(--font-mono);
        background: var(--gold);
        color: var(--navy-900);
        padding: 1px 7px;
        border-radius: 999px;
    }

    .nav-item .lbl {
        flex: 1;
        overflow: hidden;
        text-overflow: ellipsis;
    }

/* ── Página de notificaciones ───────────────────────────────────────────── */
/* La tabla usa los estilos estándar (.tbl); la única señal de "no leída" es el
   punto rojo (y el título en negrita), para no romper el fondo de las celdas
   sticky ni desentonar en claro/oscuro. */
.noti-dot {
    display: inline-block;
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--red);
}

.sidebar-foot {
    padding: 12px 14px 18px;
    border-top: 1px solid rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

    .sidebar-foot .who {
        line-height: 1.2;
        flex: 1;
        min-width: 0;
        overflow: hidden;
    }

        .sidebar-foot .who .n {
            font-weight: 600;
            color: #fff;
            font-size: 13px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .sidebar-foot .who .r {
            font-size: 11px;
            color: rgba(255,255,255,.55);
            white-space: nowrap;
        }

/* ====== TOPBAR ====== */
.search {
    flex: 1;
    max-width: 520px;
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 12px;
    color: var(--text-muted);
}

    .search input {
        border: 0;
        background: transparent;
        outline: 0;
        flex: 1;
        font-size: 13.5px;
        color: var(--text);
    }

    .search kbd {
        font-family: var(--font-mono);
        font-size: 10.5px;
        background: var(--bg-elev);
        border: 1px solid var(--border);
        padding: 2px 6px;
        border-radius: 6px;
        color: var(--text-muted);
    }

.tb-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.icon-btn {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 10px;
    color: var(--text-muted);
    transition: all .15s;
    position: relative;
    cursor: pointer;
}

    .icon-btn:hover {
        color: var(--text);
        background: var(--bg-soft);
        border-color: var(--border-strong);
    }

    .icon-btn i { font-size: 14px; }

    .icon-btn .dot {
        position: absolute;
        top: 7px;
        right: 7px;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: var(--red);
        border: 2px solid var(--bg-elev);
    }

/* ====== TYPOGRAPHY ====== */
.h1 {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 28px;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0;
}

.h2 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    letter-spacing: -0.01em;
    margin: 0;
}

.h3 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 16px;
    letter-spacing: -0.01em;
    margin: 0;
}

.eyebrow {
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-soft);
    font-weight: 600;
}

.num {
    font-family: var(--font-display);
    font-feature-settings: "tnum";
    font-variant-numeric: tabular-nums;
}

.mono {
    font-family: var(--font-mono);
}

/* ====== PAGE HEADER ====== */
.page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
    flex-wrap: wrap;
}

    .page-head .crumb {
        color: var(--text-soft);
        font-size: 12.5px;
        margin-bottom: 6px;
    }

        .page-head .crumb b {
            color: var(--text);
            font-weight: 600;
        }

    .page-head h1, .page-head h2 {
        margin: 0;
    }

.page-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* Bootstrap-compatible page heading */
.page-header-compat {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
    flex-wrap: wrap;
}

    .page-header-compat h1, .page-header-compat h2 {
        margin: 0;
    }

/* ====== CARD ====== */
.card {
    background: var(--bg-elev) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--gap);
    overflow: visible;
}

/* Las tarjetas que contienen una tabla deben recortar su contenido para que la
   cabecera y las filas (con sus fondos rectangulares) no sobresalgan de las
   esquinas redondeadas. El scroll horizontal sigue funcionando porque vive en
   el .table-wrap interior. Los tooltips no se ven afectados (son position:fixed
   a nivel de body). */
.card:has(.table-wrap),
.card:has(.table-responsive) {
    overflow: hidden;
}

.card-pad {
    padding: 20px;
}

/* Fila expandida con el detalle de un envío (historial de comunicaciones).
   Usa variables de tema para adaptarse a modo claro/oscuro (bg-light de Bootstrap
   no se adapta y quedaba ilegible en oscuro). */
.detalle-envio {
    background: var(--bg-inset);
    color: var(--text);
}

/* Tarjeta de "Notificaciones de clase" en el panel (botón activar push). */
.push-card {
    margin-bottom: var(--gap);
}

.push-card-pad {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    gap: 12px;
}

    .card-head .h3 + .sub {
        color: var(--text-muted);
        font-size: 12.5px;
        margin-top: 2px;
    }

.card-header {
    background: var(--bg-soft) !important;
    border-bottom: 1px solid var(--border) !important;
    padding: 16px 20px;
    font-weight: 600;
    color: var(--text);
    border-radius: calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px) 0 0 !important;
}

.card-body {
    padding: 20px;
}

.card-footer {
    background: var(--bg-soft) !important;
    border-top: 1px solid var(--border) !important;
    padding: 14px 20px;
    border-radius: 0 0 calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px) !important;
}

    .card-footer a {
        color: var(--text-muted);
        font-size: 13px;
    }

        .card-footer a:hover {
            color: var(--text);
        }

/* KPI card */
.kpi {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: relative;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
    margin-bottom: 0;
}

    .kpi:hover {
        transform: translateY(-2px);
        box-shadow: var(--shadow);
    }

    .kpi .label {
        font-size: 12px;
        color: var(--text-muted);
        font-weight: 500;
    }

    .kpi .val {
        font-family: var(--font-display);
        font-weight: 700;
        font-size: 32px;
        letter-spacing: -0.02em;
        line-height: 1;
    }

    .kpi .delta {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        font-size: 12px;
        font-weight: 600;
    }

        .kpi .delta.up {
            color: var(--green);
        }

        .kpi .delta.dn {
            color: var(--red);
        }

    .kpi .spark {
        position: absolute;
        right: 16px;
        bottom: 14px;
        width: 110px;
        height: 40px;
        opacity: .95;
    }

    .kpi.featured {
        background: linear-gradient(135deg, var(--navy-800) 0%, var(--navy-700) 100%);
        color: var(--cream);
        border: 0;
    }

        .kpi.featured::after {
            content: "";
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 4px;
            background: var(--gold);
        }

        .kpi.featured .label {
            color: color-mix(in srgb, var(--cream) 65%, transparent);
        }

/* KPI grid helper */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--gap);
    margin-bottom: 22px;
}

.kpi-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gap);
    margin-bottom: 22px;
}

/* Dashboard layout helpers */
.dash-grid-2 {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--gap);
    margin-bottom: var(--gap);
}

.dash-col {
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    min-width: 0;
}

/* ====== BUTTON ====== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 13.5px;
    font-weight: 600;
    border: 1px solid transparent;
    transition: all .15s;
    white-space: nowrap;
    line-height: 1.5;
    cursor: pointer;
}
/* Primary — navy */
.btn-primary {
    background: var(--navy-800);
    color: #fff;
    border-color: var(--navy-800);
}

    .btn-primary:hover, .btn-primary:focus-visible {
        background: var(--navy-700);
        border-color: var(--navy-700);
        color: #fff;
    }

[data-theme="dark"] .btn-primary {
    background: var(--gold);
    color: var(--navy-900);
    border-color: var(--gold);
}

    [data-theme="dark"] .btn-primary:hover {
        background: var(--gold-light);
        border-color: var(--gold-light);
        color: var(--navy-900);
    }
/* Accent */
.btn-accent {
    background: var(--accent);
    color: var(--accent-ink);
    border-color: var(--accent);
}

    .btn-accent:hover {
        background: #EAAF20;
        border-color: #EAAF20;
        box-shadow: 0 6px 16px -8px rgba(251,196,46,.5);
        color: var(--accent-ink);
    }

[data-theme="dark"] .btn-accent:hover {
    background: var(--gold-light);
    border-color: var(--gold-light);
    box-shadow: 0 6px 16px -8px rgba(251,196,46,.4);
    color: var(--accent-ink);
}

/* Badge con el color de acento (mismo criterio visual que btn-accent) */
.badge-accent {
    background: var(--accent);
    color: var(--accent-ink);
}

/* ====== Editor visual Quill (cuerpo de comunicaciones) ======================
   Re-tematizado para casar con la plataforma: bordes, radios, superficies y
   color de acento de los tokens; la barra hereda el tema oscuro. La superficie
   editable se mantiene clara a propósito (es el WYSIWYG del correo, que se
   envía en claro). */
.ql-toolbar.ql-snow,
.ql-container.ql-snow {
    border-color: var(--border);
}
.ql-toolbar.ql-snow {
    background: var(--bg-soft);
    border-bottom: 0;
    border-top-left-radius: var(--radius-sm);
    border-top-right-radius: var(--radius-sm);
}
.ql-container.ql-snow {
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
    font-family: var(--font-sans);
}

/* Superficie editable: clara en ambos temas (igual que se verá el correo). */
.quill-editor { background: #fff; }
.ql-editor {
    min-height: 200px;
    color: #222;
    font-size: 14px;
}
.ql-editor.ql-blank::before {
    color: var(--text-muted);
    font-style: normal;
}

/* Iconos/labels de la barra: gris por defecto, acento al pasar el ratón o activo. */
.ql-snow .ql-stroke { stroke: var(--text-muted); }
.ql-snow .ql-fill   { fill: var(--text-muted); }
.ql-snow .ql-picker { color: var(--text-muted); }

.ql-toolbar.ql-snow button:hover .ql-stroke,
.ql-toolbar.ql-snow button.ql-active .ql-stroke,
.ql-toolbar.ql-snow .ql-picker-label:hover .ql-stroke,
.ql-toolbar.ql-snow .ql-picker-label.ql-active .ql-stroke {
    stroke: var(--accent);
}
.ql-toolbar.ql-snow button:hover .ql-fill,
.ql-toolbar.ql-snow button.ql-active .ql-fill {
    fill: var(--accent);
}
.ql-toolbar.ql-snow button:hover,
.ql-toolbar.ql-snow button.ql-active,
.ql-toolbar.ql-snow .ql-picker-label:hover,
.ql-toolbar.ql-snow .ql-picker-label.ql-active,
.ql-toolbar.ql-snow .ql-picker-item:hover,
.ql-toolbar.ql-snow .ql-picker-item.ql-selected {
    color: var(--accent);
}

/* Desplegables de la barra (p. ej. encabezados) y tooltip de enlace. */
.ql-snow .ql-picker-options,
.ql-snow .ql-tooltip {
    background: var(--bg-elev);
    color: var(--text);
    border-color: var(--border) !important;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow);
}
.ql-snow .ql-tooltip input[type=text] {
    background: var(--bg-elev);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}
.ql-snow .ql-tooltip a.ql-action,
.ql-snow .ql-tooltip a.ql-remove,
.ql-snow .ql-tooltip a.ql-preview {
    color: var(--accent);
}

/* Variante outline del botón de acento */
.btn-outline-accent {
    background: transparent;
    color: var(--accent);
    border-color: var(--accent);
}

    .btn-outline-accent:hover {
        background: var(--accent);
        border-color: var(--accent);
        color: var(--accent-ink);
    }
/* Ghost / outline */
.btn-ghost,
.btn-outline-secondary,
.btn-outline-primary,
.btn-secondary {
    background: transparent;
    color: var(--text);
    border-color: var(--border);
}

    .btn-ghost:hover,
    .btn-outline-secondary:hover,
    .btn-outline-primary:hover,
    .btn-secondary:hover {
        background: var(--bg-soft);
        border-color: var(--border-strong);
        color: var(--text);
    }
/* Icon action buttons: gold hover */
.btn-icon.btn-outline-primary:hover,
.btn-icon.btn-outline-secondary:hover,
.btn-icon.btn-outline-success:hover,
.btn-icon.btn-outline-warning:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-ink);
}

.btn-icon.btn-outline-danger:hover {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
}
/* Warning — usa el dorado de la app en lugar del amarillo Bootstrap */
.btn-outline-warning {
    color: var(--gold-700);
    border-color: var(--gold-700);
    background: transparent;
}
/* Danger */
.btn-danger {
    background: transparent;
    color: var(--red);
    border-color: var(--red);
}

    .btn-danger:hover {
        background: rgba(215,52,75,.08);
    }
/* Sizes */
.btn-sm {
    padding: 6px 10px;
    font-size: 12.5px;
}


.btn-lg {
    padding: 12px 18px;
    font-size: 14px;
}

.btn-icon {
    width: 36px;
    height: 36px;
    padding: 0;
}

.btn:disabled, .btn[disabled] {
    opacity: .5;
    cursor: not-allowed;
}
/* Bootstrap focus ring */
.btn:focus, .btn:active:focus {
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent);
    outline: none;
}

/* ====== INPUTS ====== */
.field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 0;
}

.field-label, .form-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}

.field-hint {
    font-size: 11.5px;
    color: var(--text-muted);
}

/* Texto de ayuda bajo los controles (Bootstrap usa un gris fijo que no
   contrasta en modo oscuro; lo ligamos a la variable del tema). */
.form-text {
    color: var(--text-muted);
}

.field-error {
    font-size: 11.5px;
    color: var(--red);
}

.text-danger {
    color: var(--red);
}

.input,
.form-control,
.form-select,
.select {
    background: var(--bg-elev) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 12px !important;
    font-size: 13.5px !important;
    color: var(--text) !important;
    outline: 0;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
}

    .input:hover, .form-control:hover, .form-select:hover {
        border-color: var(--border-strong) !important;
    }

    .input:focus, .form-control:focus, .form-select:focus {
        border-color: var(--accent) !important;
        box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent) !important;
        background: var(--bg-elev) !important;
        color: var(--text) !important;
    }

    .input.error, .form-control.is-invalid {
        border-color: var(--red) !important;
        box-shadow: 0 0 0 3px rgba(215,52,75,.12) !important;
    }

    .input::placeholder, .form-control::placeholder, .textarea::placeholder {
        color: var(--text-muted) !important;
        opacity: 1;
    }

textarea.form-control, .textarea {
    resize: vertical;
    min-height: 80px;
    line-height: 1.5;
}

/* File input: el botón interno (::file-selector-button) hereda el color del
   .form-control (var(--text)) y, sobre fondo claro del navegador, queda
   ilegible en modo oscuro. Le damos estilo propio coherente con el tema. */
input[type="file"].form-control {
    line-height: 1.5;   /* misma caja que un .form-control normal (padding 10px 12px) */
}

    /* El botón replica el padding vertical del control y usa márgenes negativos
       para "estirarse" hasta llenar toda la altura, igual que hace Bootstrap. Así
       el alto total del file input coincide exactamente con el de un input normal. */
    input[type="file"].form-control::file-selector-button {
        background: var(--bg-inset);
        color: var(--text);
        border: 0;
        border-right: 1px solid var(--border);
        border-radius: var(--radius-sm) 0 0 var(--radius-sm);
        padding: 10px 12px;
        margin: -10px 12px -10px -12px;
        cursor: pointer;
        font-size: 13px;
        transition: background .15s, color .15s, border-color .15s;
    }

        /* Bootstrap cambia el fondo del botón al pasar el ratón por TODO el control
           (.form-control:hover…::file-selector-button) con mayor especificidad, lo
           que en oscuro dejaba texto claro sobre fondo claro. Lo neutralizamos: al
           hacer hover en el control el botón mantiene su aspecto base… */
        input[type="file"].form-control:hover::file-selector-button {
            background: var(--bg-inset) !important;
            color: var(--text) !important;
            border-color: var(--border) !important;
        }

        /* …y al hacer hover directamente sobre el botón, pasa a acento (legible). */
        input[type="file"].form-control::file-selector-button:hover {
            background: var(--accent) !important;
            color: var(--accent-ink) !important;
            border-color: var(--accent) !important;
        }

[data-theme="dark"] input[type="time"] {
    color-scheme: dark;
}

.input-group {
    position: relative;
}

    .input-group .ig-icon {
        position: absolute;
        left: 11px;
        top: 50%;
        transform: translateY(-50%);
        color: var(--text-muted);
        z-index: 1;
    }

    .input-group .input, .input-group .form-control {
        padding-left: 36px !important;
    }

/* Input group addon */
.input-group-text {
    background-color: var(--bg-inset);
    border-color: var(--border);
    color: var(--text-muted);
}

/* Select custom arrow */
.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%23828BA0' stroke-width='1.8'><path d='M3 4.5l3 3 3-3'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding-right: 32px !important;
}

/* Checkbox & radio */
.form-check-input {
    appearance: none !important;
    width: 18px !important;
    height: 18px !important;
    border: 1.5px solid var(--border-strong) !important;
    background: var(--bg-elev) !important;
    display: grid;
    place-items: center;
    transition: all .15s;
    border-radius: 5px !important;
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 0 !important;
}

    .form-check-input:hover {
        border-color: var(--accent) !important;
    }

    .form-check-input:checked {
        background: var(--accent) !important;
        border-color: var(--accent) !important;
    }

        .form-check-input:checked::after {
            content: "";
            width: 10px;
            height: 10px;
            display: block;
            background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%230B1729' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='2,6.5 5,9.5 10,3'/></svg>") no-repeat center / contain;
        }

    .form-check-input[type="radio"] {
        border-radius: 50% !important;
    }

        .form-check-input[type="radio"]:checked {
            border-width: 5.5px !important;
            background: var(--bg-elev) !important;
            border-color: var(--accent) !important;
        }

            .form-check-input[type="radio"]:checked::after {
                display: none;
            }

.form-check-label {
    font-size: 13.5px;
    cursor: pointer;
}

.form-check-input:focus {
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent) !important;
}

/* ====== BADGE ====== */
.badge-curso { font-size: 11px !important; gap: 4px; }

.badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 9px;
    border-radius: 999px;
    font-size: 11.5px !important;
    font-weight: 600 !important;
    background: var(--bg-inset) !important;
    color: var(--text) !important;
    border: 1px solid var(--border);
    line-height: 1.4;
    white-space: nowrap;
}

    .badge.b-success, .badge.bg-success {
        background: rgba(63,157,92,.12) !important;
        color: var(--green) !important;
        border-color: rgba(63,157,92,.25) !important;
    }

    .badge.b-warn, .badge.bg-warning {
        background: rgba(240,138,42,.12) !important;
        color: var(--orange) !important;
        border-color: rgba(240,138,42,.25) !important;
    }

    .badge.b-danger, .badge.bg-danger {
        background: rgba(215,52,75,.12) !important;
        color: var(--red) !important;
        border-color: rgba(215,52,75,.25) !important;
    }

    .badge.b-info, .badge.bg-info {
        background: rgba(47,107,216,.12) !important;
        color: var(--blue) !important;
        border-color: rgba(47,107,216,.25) !important;
    }

    .badge.b-accent, .badge.bg-primary {
        background: rgba(251,196,46,.18) !important;
        color: var(--gold-ink) !important;
        border-color: rgba(251,196,46,.35) !important;
    }

[data-theme="dark"] .badge.b-accent, [data-theme="dark"] .badge.bg-primary {
    color: var(--gold) !important;
}

.badge.b-secondary, .badge.bg-secondary {
    background: var(--bg-inset) !important;
    color: var(--text-muted) !important;
    border-color: var(--border) !important;
}

.badge-close { opacity: 0.55; }
.badge-close:hover { opacity: 0.85; }
[data-theme="dark"] .badge-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* Belt badge */
.belt {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 3px 7px 3px 4px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 600;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    color: var(--text);
    white-space: nowrap;
}

.swatch {
    display: inline-block;
    width: 18px;
    height: 10px;
    border-radius: 2px;
    border: 1px solid rgba(0,0,0,.15);
    flex-shrink: 0;
    overflow: hidden;
}

.belt span:last-child {
    padding-right: 3px;
}

/* Belt picker (custom select) */
.belt-picker {
    position: relative;
}

.belt-picker-trigger {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 10px 2.25rem 10px 12px;
    cursor: pointer;
    user-select: none;
    background: var(--bg-elev);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23828BA0' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 16px 12px;
    transition: border-color .15s;
}

    .belt-picker-trigger:focus {
        outline: none;
        border-color: var(--gold);
        box-shadow: 0 0 0 3px rgba(251,196,46,.15);
    }

.belt-picker-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 200;
    background: var(--bg-elev);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    max-height: 280px;
    overflow-y: auto;
}

.belt-picker-option {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 7px 12px;
    cursor: pointer;
}

    .belt-picker-option:hover {
        background: var(--bg-soft);
    }

    .belt-picker-option.is-selected {
        background: var(--bg-inset);
    }

/* ── Multi-select filter (filtro de clases) ──────────────────────────────── */
.msel-wrap {
    position: relative;
    width: 100%;
}

.msel-trigger {
    display: flex;
    align-items: center;
    padding: 10px 2.25rem 10px 12px;
    cursor: pointer;
    user-select: none;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23828BA0' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 16px 12px;
    transition: border-color .15s, box-shadow .15s;
    font-size: 13.5px;
    line-height: 1.5;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.msel-trigger--open,
.msel-trigger:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
}

.msel-trigger--active {
    border-color: var(--accent);
}

.msel-placeholder {
    color: var(--text-muted);
}

.msel-backdrop {
    position: fixed;
    inset: 0;
    z-index: 199;
}

.msel-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 200;
    background: var(--bg-elev);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    max-height: 300px;
    overflow-y: auto;
}

.msel-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 12px 3px;
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-muted);
    border-top: 1px solid var(--border);
    cursor: pointer;
    user-select: none;
    transition: background .1s;
}

.msel-group-header:first-child {
    border-top: none;
}

.msel-group-header:hover {
    background: var(--bg-soft);
    color: var(--text);
}

.msel-group-check {
    font-size: 11px;
    opacity: 0.35;
    transition: opacity .1s, color .1s;
}

.msel-group-check.is-active {
    opacity: 1;
    color: var(--accent);
}

.msel-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    cursor: pointer;
    font-size: 13.5px;
    transition: background .1s;
}

.msel-option:hover {
    background: var(--bg-soft);
}

.msel-option.is-selected {
    background: var(--bg-inset);
}

.msel-option--all {
    color: var(--text-muted);
    font-size: 13px;
    border-bottom: 1px solid var(--border);
}

.msel-check-icon {
    width: 15px;
    flex-shrink: 0;
    text-align: center;
    font-size: 13px;
    color: var(--accent);
}

.msel-horario {
    color: var(--text-muted);
    margin-left: 4px;
}

/* Avatar */
.avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: var(--navy-700);
    color: var(--gold);
    display: inline-grid;
    place-items: center;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 12px;
    flex-shrink: 0;
    border: 1.5px solid var(--bg-elev);
}

    .avatar.lg {
        width: 48px;
        height: 48px;
        font-size: 16px;
    }

.avatar-img {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    object-fit: cover;
    border: 1.5px solid var(--bg-elev);
    flex-shrink: 0;
}

/* ====== TABLE ====== */
.table-wrap, .table-responsive {
    overflow-x: auto;
}

.col-shrink { width: 1%; white-space: nowrap; }
.icon-sm    { font-size: 13px; }

.table, table.tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    background: transparent;
    border-color: var(--border);
    margin-bottom: 0;
    --bs-table-bg: transparent;
    --bs-table-hover-bg: var(--bg-soft);
}

    .table thead th, table.tbl thead th {
        text-align: left;
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-weight: 600;
        color: var(--text-soft);
        padding: 12px var(--row-pad-x);
        border-bottom: 1px solid var(--border) !important;
        background: var(--bg-soft);
        white-space: nowrap;
        vertical-align: middle;
    }

    .table tbody td, table.tbl tbody td {
        padding: var(--row-pad-y) var(--row-pad-x);
        border-bottom: 1px solid var(--border) !important;
        border-color: var(--border);
        vertical-align: middle;
        color: var(--text);
        background: transparent;
    }

    .table tbody tr, table.tbl tbody tr {
        transition: background .15s;
    }

        .table-hover tbody tr:hover td,
        .table tbody tr:hover td,
        table.tbl tbody tr:hover td {
            background: var(--bg-soft) !important;
        }

.table-dark {
    --bs-table-bg: var(--navy-800);
    --bs-table-color: var(--cream);
    background: var(--navy-800);
}

    .table-dark th {
        color: color-mix(in srgb, var(--cream) 80%, transparent) !important;
        background: var(--navy-700) !important;
    }

    .table-dark td {
        color: var(--cream);
        border-color: var(--navy-600) !important;
    }

.table-light {
    --bs-table-bg: var(--bg-soft);
}

.align-middle td, .align-middle th {
    vertical-align: middle;
}

/* ── Sticky actions column (always first) ───────────────────────────────── */
table.tbl thead th:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
}

table.tbl tbody td:first-child {
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--bg-elev);
}

table.tbl tbody tr:hover td:first-child {
    background: var(--bg-soft) !important;
}

table.tbl tbody tr.row-selected td { background: color-mix(in srgb, var(--accent) 9%, transparent) !important; }
table.tbl tbody tr.row-selected:hover td { background: color-mix(in srgb, var(--accent) 14%, transparent) !important; }
table.tbl tbody tr.row-selected td:first-child { background: color-mix(in srgb, var(--accent) 9%, transparent) !important; }
table.tbl tbody tr.row-selected:hover td:first-child { background: color-mix(in srgb, var(--accent) 14%, transparent) !important; }

/* ── Table footer / pagination ─────────────────────────────────────────── */
.tbl-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    font-size: 12.5px;
    color: var(--text-muted);
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
    gap: 8px;
}

.tbl-pager {
    display: flex;
    gap: 4px;
    align-items: center;
}

    .tbl-pager .btn-page {
        min-width: 32px;
        height: 30px;
        padding: 0 8px;
        border-radius: var(--radius-sm);
        background: transparent;
        border: 1px solid transparent;
        color: var(--text-muted);
        font-size: 12.5px;
        cursor: pointer;
        transition: background .15s, color .15s, border-color .15s;
    }

        .tbl-pager .btn-page:hover:not(:disabled) {
            background: var(--bg-soft);
            color: var(--text);
        }

        .tbl-pager .btn-page.active {
            background: var(--primary);
            color: #fff;
            border-color: var(--primary);
            font-weight: 600;
        }

        .tbl-pager .btn-page:disabled {
            opacity: .4;
            cursor: default;
        }

    .tbl-pager .ellipsis {
        min-width: 24px;
        text-align: center;
        color: var(--text-muted);
        font-size: 12px;
    }

/* ====== ALERT ====== */
.alert {
    border-radius: var(--radius);
    padding: 12px 16px;
    border: 1px solid;
}

.alert-info {
    background: rgba(47,107,216,.08);
    border-color: rgba(47,107,216,.2);
    color: var(--blue);
}

.alert-success {
    background: rgba(63,157,92,.08);
    border-color: rgba(63,157,92,.2);
    color: var(--green);
}

.alert-warning {
    background: rgba(240,138,42,.08);
    border-color: rgba(240,138,42,.2);
    color: var(--orange);
}

.alert-danger {
    background: rgba(215,52,75,.08);
    border-color: rgba(215,52,75,.2);
    color: var(--red);
}

/* Progress / bar */
.bar {
    height: 6px;
    background: var(--bg-inset);
    border-radius: 999px;
    overflow: hidden;
}

    .bar > span, .bar > div {
        display: block;
        height: 100%;
        background: var(--accent);
        border-radius: 999px;
        transition: width .3s;
    }

    .bar.b-green > span, .bar.b-green > div {
        background: var(--green);
    }

    .bar.b-red > span, .bar.b-red > div {
        background: var(--red);
    }

    .bar.b-orange > span, .bar.b-orange > div {
        background: var(--orange);
    }

.progress {
    height: 6px;
    background: var(--bg-inset);
    border-radius: 999px;
}

.progress-bar {
    background: var(--accent);
    border-radius: 999px;
}

/* ====== MODAL ====== */
.modal {
    border: 0 !important;
}

.modal-content {
    background: var(--bg-elev) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    color: var(--text);
}

.modal-header {
    background: transparent !important;
    border-bottom: 1px solid var(--border) !important;
    padding: 18px 22px 12px !important;
    border-radius: calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px) 0 0 !important;
}

.modal-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 18px;
    color: var(--text);
}

.modal-body {
    padding: 18px 22px !important;
}

.modal-footer {
    background: var(--bg-soft) !important;
    border-top: 1px solid var(--border) !important;
    padding: 14px 22px !important;
    border-radius: 0 0 calc(var(--radius-lg) - 1px) calc(var(--radius-lg) - 1px) !important;
}

.modal-backdrop {
    backdrop-filter: blur(4px);
    background: rgba(7,16,31,.55) !important;
}

.btn-close {
    color: var(--text-muted);
    opacity: .7;
}

    .btn-close:hover {
        opacity: 1;
    }

/* ====== SPINNER ====== */
.spinner-border {
    color: var(--accent);
}

    .spinner-border.text-primary {
        color: var(--accent) !important;
    }

/* ====== TOAST / TOASTS ====== */
.toast {
    background: var(--bg-elev) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-lg) !important;
    color: var(--text) !important;
}

.toast-header {
    background: var(--bg-soft) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text) !important;
}

.toast-container {
    z-index: 1100;
}

/* ====== SWEETALERT2 overrides ====== */
.swal2-popup {
    background: var(--bg-elev) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    color: var(--text) !important;
}

.swal2-title {
    color: var(--text) !important;
    font-family: var(--font-display) !important;
}

.swal2-html-container {
    color: var(--text-muted) !important;
}

.swal2-confirm {
    background: var(--accent) !important;
    color: var(--accent-ink) !important;
    border-radius: var(--radius-sm) !important;
}

.swal2-cancel {
    background: transparent !important;
    color: var(--text) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
}

/* ====== TABS ====== */
.nav-tabs {
    border-bottom: 1px solid var(--border);
    gap: 4px;
    padding: 0 4px;
    flex-wrap: nowrap;
}

    .nav-tabs .nav-link {
        background: transparent;
        border: 0;
        padding: 10px 14px;
        font-size: 13.5px;
        font-weight: 500;
        color: var(--text-muted);
        border-bottom: 2px solid transparent;
        margin-bottom: -1px;
        transition: color .15s, border-color .15s;
        border-radius: 0;
    }

        .nav-tabs .nav-link:hover {
            color: var(--text);
            border-color: transparent;
            background: transparent;
        }

        .nav-tabs .nav-link.active {
            color: var(--text);
            border-bottom-color: var(--accent);
            background: transparent;
            border-color: transparent transparent var(--accent);
        }

    .nav-tabs .nav-item.show .nav-link {
        color: var(--text);
    }

/* ====== TABS (sistema propio, igual que plantilla) ====== */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border); padding: 0 4px; }

.tab {
    background: transparent;
    border: 0;
    padding: 10px 14px;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--text-muted);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color .15s, border-color .15s;
}

.tab:hover { color: var(--text); }

.tab.active { color: var(--text); border-bottom-color: var(--accent); }

.tab .count {
    margin-left: 6px;
    font-size: 11px;
    font-family: var(--font-mono);
    background: var(--bg-inset);
    color: var(--text-muted);
    padding: 1px 6px;
    border-radius: 999px;
}

/* ====== ACTIVITY FEED ====== */
.activity-item {
    display: flex;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
    align-items: flex-start;
}

    .activity-item:last-child {
        border-bottom: 0;
    }

    .activity-item .ic {
        width: 32px;
        height: 32px;
        border-radius: 9px;
        display: grid;
        place-items: center;
        flex-shrink: 0;
        font-weight: 700;
    }

        .activity-item .ic.t-gold {
            background: rgba(251,196,46,.18);
            color: var(--gold-ink);
        }

        .activity-item .ic.t-red {
            background: rgba(215,52,75,.15);
            color: var(--red);
        }

        .activity-item .ic.t-green {
            background: rgba(63,157,92,.15);
            color: var(--green);
        }

        .activity-item .ic.t-blue {
            background: rgba(47,107,216,.15);
            color: var(--blue);
        }

        .activity-item .ic.t-orange {
            background: rgba(240,138,42,.15);
            color: var(--orange);
        }

    .activity-item .txt {
        font-size: 13px;
        line-height: 1.4;
        flex: 1;
    }

        .activity-item .txt b {
            font-weight: 600;
        }

    .activity-item .when {
        font-size: 11.5px;
        color: var(--text-soft);
        margin-top: 1px;
        display: block;
    }

/* ====== DIVIDER ====== */
.div {
    height: 1px;
    background: var(--border);
    margin: 0;
}

/* ====== CONTAINER adjustments inside .main ====== */
/* Todas las páginas ocupan el ancho disponible de .main: neutralizamos los
   topes de ancho de Bootstrap (.container) y de los formularios (.form-container*). */
.main .container-fluid,
.main .container {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
}

.main .form-container,
.main .form-container-sm,
.main .form-container-lg,
.main .form-container-xl {
    max-width: 100%;
}

.main .py-3 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.main > .container-fluid > h1,
.main > .container-fluid > h2,
.main > .container > h1,
.main > .container > h2 {
    margin-bottom: 20px;
}

/* ====== VALIDATION ====== */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--green);
}

.invalid {
    outline: 1px solid var(--red);
}

.validation-message {
    color: var(--red);
    font-size: 0.8125rem;
    margin-top: 0.25rem;
}

/* ====== LOGIN PAGE ====== */
.login-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--navy-900) 0%, var(--navy-800) 60%, var(--navy-600) 100%);
    padding: 1.5rem;
    overflow: auto;
}

.login-card {
    background: var(--bg-elev);
    border-radius: var(--radius-lg);
    padding: 3rem 2.5rem;
    width: 100%;
    max-width: 420px;
    text-align: center;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border);
}

.login-logo img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--gold);
    margin-bottom: 1.25rem;
    box-shadow: 0 0 0 6px rgba(251,196,46,.15);
}

.login-title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: .25rem;
    font-family: var(--font-display);
}

.login-subtitle {
    font-size: .85rem;
    color: var(--text-muted);
    margin-bottom: 2rem;
}

.login-providers {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

.btn-social-login {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: var(--bg-elev);
    color: var(--text);
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    padding: .75rem 1.5rem;
    font-size: .9rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s, box-shadow .15s;
    width: 100%;
    justify-content: center;
}

    .btn-social-login:hover {
        background: var(--bg-soft);
        box-shadow: var(--shadow);
        color: var(--text);
        text-decoration: none;
    }

.login-error {
    margin-top: 1.25rem;
    padding: .75rem 1rem;
    background: rgba(215,52,75,.08);
    border: 1px solid rgba(215,52,75,.25);
    border-radius: var(--radius-sm);
    color: var(--red);
    font-size: .82rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}

/* ====== BLAZOR ERROR UI ====== */
.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #B91C1C;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
    border-radius: var(--radius-sm);
}

    .blazor-error-boundary::after {
        content: "Se ha producido un error.";
    }

#blazor-error-ui {
    color-scheme: light only;
    background: rgba(251,196,46,.15);
    border-top: 3px solid var(--gold);
    bottom: 0;
    left: 0;
    box-shadow: 0 -2px 10px rgba(0,0,0,.1);
    box-sizing: border-box;
    display: none;
    position: fixed;
    width: 100%;
    z-index: 1000;
    padding: .75rem 3.5rem .75rem 1.25rem;
    font-weight: 500;
    color: var(--gold-ink);
}

    #blazor-error-ui .reload {
        color: var(--gold-ink);
        font-weight: 600;
        text-decoration: underline;
        margin-left: .5rem;
    }

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 1rem;
        top: 50%;
        transform: translateY(-50%);
        opacity: .6;
    }

        #blazor-error-ui .dismiss:hover {
            opacity: 1;
        }

/* ====== RECONNECT MODAL ====== */
.components-reconnect-first-attempt-visible,
.components-reconnect-repeated-attempt-visible,
.components-reconnect-failed-visible,
.components-pause-visible,
.components-resume-failed-visible,
.components-rejoining-animation {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible,
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation,
#components-reconnect-modal.components-reconnect-paused .components-pause-visible,
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible,
#components-reconnect-modal.components-reconnect-retrying,
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible,
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible {
    display: block;
}

#components-reconnect-modal {
    background-color: var(--bg-elev);
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    transition: display .5s allow-discrete, overlay .5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity .5s both;
}

    #components-reconnect-modal[open] {
        animation: components-reconnect-modal-slideUp 1.5s cubic-bezier(.05,.89,.25,1.02) .3s, components-reconnect-modal-fadeInOpacity .5s ease-in-out .3s;
        animation-fill-mode: both;
    }

    #components-reconnect-modal::backdrop {
        background-color: rgba(0,0,0,.4);
        animation: components-reconnect-modal-fadeInOpacity .5s ease-in-out;
        opacity: 1;
    }

    #components-reconnect-modal p {
        margin: 0;
        text-align: center;
        color: var(--text);
    }

    #components-reconnect-modal button {
        border: 0;
        background: var(--accent);
        color: var(--accent-ink);
        padding: 4px 24px;
        border-radius: var(--radius-sm);
    }

.components-reconnect-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.components-rejoining-animation {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div {
        position: absolute;
        border: 3px solid var(--accent);
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation 1.5s cubic-bezier(0,.2,.8,1) infinite;
    }

        .components-rejoining-animation div:nth-child(2) {
            animation-delay: -.5s;
        }

@keyframes components-reconnect-modal-slideUp {
    0% {
        transform: translateY(30px) scale(.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

@keyframes components-rejoining-animation {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0;
        left: 0;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}

/* ====== SIDEBAR TOGGLE ICON ====== */
.sidebar-toggle-icon {
    font-size: 13px;
    transition: transform 0.22s ease;
    display: block;
}

/* Sidebar expandido → flecha apunta a la izquierda (acción: contraer) */
/* Sidebar contraído → flecha gira 180° y apunta a la derecha (acción: expandir) */
:root[data-sidebar-collapsed="true"] .sidebar-toggle-icon {
    transform: rotate(180deg);
}

/* Hamburger button — visible only on mobile (≤700px) */
.hamburger-btn { display: none; }

/* Drawer cerrado → flecha apunta a la derecha (acción: abrir) */
/* Drawer abierto  → flecha apunta a la izquierda (acción: cerrar) */
.hamburger-icon {
    font-size: 13px;
    transition: transform 0.22s ease;
    display: block;
    transform: rotate(180deg);
}

:root[data-nav-open] .hamburger-icon {
    transform: rotate(0deg);
}

/* Nav overlay — shown when mobile drawer is open */
.nav-overlay { display: none; }

/* ====== RESPONSIVE ====== */
@media (max-width: 1100px) {
    .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .dash-grid-2 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .app {
        grid-template-columns: 64px 1fr;
    }

    .sidebar .brand-text,
    .sidebar .nav-label,
    .sidebar .nav-item .lbl,
    .sidebar a.nav-item .lbl,
    .sidebar-foot .who {
        display: none;
    }

    /* Modo icono responsive: el acordeón se ignora, todo visible */
    .nav-group__body {
        grid-template-rows: 1fr !important;
    }

    /* Separador entre secciones (no hay nombres en modo icono) */
    .nav-group {
        border-top: 1px solid rgba(255,255,255,.08);
        margin-top: 8px;
        padding-top: 8px;
    }

    .nav-item, a.nav-item {
        justify-content: center;
        padding: 10px;
        overflow: visible;
        min-height: 44px;
    }

    /* Count visible as positioned badge when sidebar is collapsed */
    .nav-item .count {
        position: absolute;
        top: 3px;
        right: 3px;
        font-size: 9px;
        padding: 0 4px;
        height: 15px;
        line-height: 15px;
        min-width: 15px;
        margin-left: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .nav-scroll {
        padding-bottom: 72px;
    }

    .brand {
        justify-content: center;
        padding: 18px 0 16px;
    }

    .sidebar-foot {
        justify-content: center;
        padding: 12px 0 18px;
        background: var(--navy-800);
        position: relative;
        z-index: 1;
    }

    .main {
        padding: 20px 16px 60px;
    }

    .sidebar-toggle-btn {
        display: none;
    }

    /* ── Touch targets (Apple HIG / WCAG 2.5.5 mín. 44px) ── */
    .btn, .btn-sm, .btn-lg { min-height: 44px; }
    .btn-icon { width: 44px; height: 44px; }
    .icon-btn { width: 44px; height: 44px; }
    .input, .form-control, .form-select { min-height: 44px; }
    .segmented button { min-height: 40px; }
    .form-check-input { width: 22px !important; height: 22px !important; }

    /* ── Toggle (FormSwitch) — ampliado para touch ── */
    .switch { width: 48px; height: 28px; }
    .switch .thumb { width: 22px; height: 22px; top: 3px; left: 3px; }
    .switch input:checked + .track + .thumb { transform: translateX(20px); }

    /* ── MiniCalendar botones nav ── */
    .mini-cal-nav { width: 36px; height: 36px; }

    /* ── Scrollbar nativa en móvil ── */
    ::-webkit-scrollbar { width: 0; height: 0; }
    .table-wrap { overscroll-behavior-x: contain; }
}

@media (max-width: 700px) {
    /* ── Layout: columna única — !important para ganar a data-sidebar-collapsed ── */
    .app {
        grid-template-columns: 1fr !important;
        grid-template-areas: "topbar" "main" !important;
    }

    /* Sidebar → drawer deslizable con animación + visibility para iOS Safari */
    .sidebar {
        display: flex !important;
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 240px;
        z-index: 1000;
        box-shadow: 4px 0 24px rgba(0,0,0,.4);
        transform: translateX(-100%);
        visibility: hidden;
        transition: transform 0.27s cubic-bezier(0.4, 0, 0.2, 1),
                    visibility 0s linear 0.27s;
    }

    :root[data-nav-open] .sidebar {
        transform: translateX(0);
        visibility: visible;
        transition: transform 0.27s cubic-bezier(0.4, 0, 0.2, 1),
                    visibility 0s;
    }

    /* Overlay con fade */
    .nav-overlay {
        display: block;
        opacity: 0;
        pointer-events: none;
        position: fixed;
        inset: 0;
        background: rgba(7,16,31,.55);
        backdrop-filter: blur(2px);
        z-index: 999;
        transition: opacity 0.27s ease;
    }

    :root[data-nav-open] .nav-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    /* Restaurar labels — !important para ganar a data-sidebar-collapsed */
    .sidebar .brand-text { display: block !important; }
    .sidebar .nav-label  { display: block !important; }
    .sidebar .nav-item .lbl,
    .sidebar a.nav-item .lbl { display: block !important; flex: 1; }
    .sidebar-foot .who { display: block !important; }

    /* Drawer móvil = menú con literales → el acordeón vuelve a aplicar */
    .sidebar .nav-label.nav-group__header { display: flex !important; }
    .nav-group:not(.is-open) > .nav-group__body { grid-template-rows: 0fr !important; }

    /* Aquí sí salen los nombres de sección → quitar el separador de modo icono */
    .nav-group {
        border-top: 0 !important;
        margin-top: 0 !important;
        padding-top: 0 !important;
    }

    .brand { justify-content: flex-start !important; padding: 18px 18px 16px !important; }

    .sidebar-foot {
        justify-content: flex-start !important;
        padding: 14px 18px !important;
    }

    .nav-item, a.nav-item {
        justify-content: flex-start !important;
        padding: 9px 12px !important;
        overflow: hidden !important;
    }

    /* Restaurar badge de conteo a posición normal */
    .nav-item .count {
        position: static !important;
        display: flex !important;
        font-size: 11px;
        padding: 1px 7px;
        height: auto;
        line-height: normal;
        min-width: auto;
        text-align: left;
        margin-left: auto;
    }

    .hamburger-btn { display: grid !important; }
    .sidebar-toggle-btn { display: none !important; }

    .topbar {
        padding: 0 14px;
        gap: 8px;
    }

    .search {
        display: none;
    }

    .main {
        padding: 16px 12px 80px;
    }

    .kpi-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    /* ── Cabecera de card: la barra de opciones baja bajo el título en vez de
       desbordar en X (p.ej. calendario en Inicio) ── */
    .card-head {
        flex-wrap: wrap;
    }

    .cal-toolbar {
        justify-content: flex-start;
    }

    .kpi-grid-3 {
        grid-template-columns: 1fr;
    }

    .dash-grid-2 {
        grid-template-columns: 1fr;
    }

    /* ── Tipografía ── */
    body { font-size: 15px; }
    .h1 { font-size: 22px; }
    .h2 { font-size: 18px; }
    .h3 { font-size: 15px; }
    .field-hint, .field-error { font-size: 13px; }
    .eyebrow { font-size: 12px; }
    .table thead th, table.tbl thead th { font-size: 12px; }

    /* ── Tablas: densidad reducida, sin sticky primera columna (iOS Safari) ── */
    :root {
        --row-pad-y: 8px;
        --row-pad-x: 10px;
    }
    table.tbl thead th:first-child,
    table.tbl tbody td:first-child { position: static; }

    /* ── Modales → bottom sheet ── */
    .modal-dialog {
        margin: 0;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        max-width: 100%;
    }

    .modal-content {
        max-height: 90dvh;
        border-radius: 16px 16px 0 0 !important;
        overflow: hidden;
    }

    .modal-body {
        overflow-y: auto;
        padding: 14px 16px !important;
    }

    .modal-header {
        padding: 14px 16px 10px !important;
    }

    .modal-footer {
        padding: 12px 16px !important;
    }

    /* ── Tabla asistencia → tarjetas en móvil ── */
    .att-tbl,
    .att-tbl tbody { display: block; }
    .att-tbl thead  { display: none; }

    .att-tbl tbody tr {
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 8px 10px;
        background: var(--bg-elev);
        border: 1px solid var(--border);
        border-radius: var(--radius-sm);
        margin-bottom: 6px;
        padding: 10px 12px;
    }

    /* Especificidad mayor que table.tbl tbody td para anular border-bottom !important */
    table.tbl.att-tbl tbody td {
        border: none !important;
        padding: 0 !important;
        background: transparent !important;
    }

    /* Col 1 fila 1: nombre — texto más grande */
    .att-tbl tbody td:nth-child(1) {
        font-size: 15.5px;
        align-self: center;
    }

    /* Col 2 fila 1: solo pill de color del cinturón */
    .att-tbl tbody td:nth-child(2) {
        display: flex !important;
        align-items: center;
        justify-content: flex-end;
        align-self: center;
    }

    .att-tbl td:nth-child(2) .belt {
        background: transparent;
        border: none;
        padding: 0;
    }

    /* Ocultar texto del cinturón, dejar solo el swatch (la cajita estándar de
       18×10 que ya soporta 1/2/3 colores, igual que en el resto de la app). */
    .att-tbl td:nth-child(2) .belt > span:last-child { display: none; }

    /* Col 1-2 fila 2: botones asistencia — ocupa ambas columnas */
    .att-tbl tbody td:nth-child(3) { grid-column: 1 / -1; }

    /* Ocultar columna "registrado por" */
    .att-tbl tbody td:nth-child(4) { display: none !important; }

    /* Botones Presente / Ausente: ancho completo, altura táctil */
    .att-tbl .segmented {
        display: flex;
        width: 100%;
    }

    .att-tbl .segmented button {
        flex: 1;
        min-height: 44px;
        font-size: 13px;
        padding: 8px 6px;
    }
}

@media (max-width: 480px) {
    .kpi-grid {
        grid-template-columns: 1fr;
    }

    .page-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .main {
        padding: 14px 10px 80px;
    }

    .modal-content {
        max-height: 95dvh;
    }

    .h1 { font-size: 20px; }
}

/* ====== UTILITY ====== */
.gap-gap {
    gap: var(--gap);
}

.text-muted {
    color: var(--text-muted) !important;
}

.text-soft {
    color: var(--text-soft) !important;
}

.text-gold {
    color: var(--gold);
}

.text-success {
    color: var(--green) !important;
}

.text-danger {
    color: var(--red) !important;
}

.text-warning {
    color: var(--orange) !important;
}

.text-info {
    color: var(--blue) !important;
}

.bg-body {
    background: var(--bg) !important;
}

.border-color {
    border-color: var(--border) !important;
}

.fw-display {
    font-family: var(--font-display);
}

.fw-mono {
    font-family: var(--font-mono);
}

/* Icon size for Font Awesome inside nav */
.fas.nav-icon, .far.nav-icon {
    width: 18px;
    text-align: center;
    opacity: .85;
    font-size: 14px;
}

/* ====== CALENDARIO SEMANAL ====== */
.cal {
    display: grid;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    font-size: 12px;
    position: relative;
}

    .cal .ch {
        background: var(--bg-soft);
        border-bottom: 1px solid var(--border);
        border-right: 1px solid var(--border);
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 600;
        text-transform: uppercase;
        font-size: 10.5px;
        letter-spacing: 0.1em;
        color: var(--text-muted);
    }

        .cal .ch.today {
            color: var(--accent-ink);
            background: color-mix(in oklab, var(--accent) 25%, var(--bg-soft));
        }

    .cal .cr {
        border-bottom: 1px dashed var(--border);
        border-right: 1px solid var(--border);
    }

        .cal .cr.lbl {
            font-family: var(--font-mono);
            font-size: 10.5px;
            color: var(--text-soft);
            display: flex;
            align-items: flex-start;
            justify-content: flex-end;
            padding: 2px 6px 0 0;
            border-right: 1px solid var(--border);
            border-bottom: 0;
        }

    .cal .ev {
        position: absolute;
        border-radius: 7px;
        padding: 6px 8px;
        font-size: 11px;
        line-height: 1.25;
        overflow: hidden;
        border: 1px solid;
        cursor: pointer;
        text-decoration: none;
        transition: transform .15s, box-shadow .15s;
    }

        .cal .ev:hover {
            transform: translateY(-1px);
            box-shadow: var(--shadow);
            z-index: 2;
        }

        .cal .ev .nm {
            font-weight: 700;
            font-size: 11.5px;
        }

        .cal .ev .mt {
            font-size: 10px;
            opacity: 0.85;
            margin-top: 1px;
        }

/* ── Indicador de hora actual ─────────────────────────────────────── */
.cal-now-line {
    position: absolute;
    left: 56px;
    right: 0;
    height: 2px;
    background: #e53e3e;
    z-index: 10;
    pointer-events: none;
}

    .cal-now-line::before {
        content: '';
        position: absolute;
        left: -5px;
        top: 50%;
        transform: translateY(-50%);
        width: 10px;
        height: 10px;
        background: #e53e3e;
        border-radius: 50%;
    }

/* ── Clase activa en este momento ────────────────────────────────── */
.ev.ev-live {
    z-index: 3;
    animation: ev-live-pulse 2s ease-in-out infinite;
}

    .ev.ev-live::after {
        content: '';
        position: absolute;
        top: 5px;
        right: 5px;
        width: 7px;
        height: 7px;
        background: #e53e3e;
        border-radius: 50%;
        box-shadow: 0 0 0 2px rgba(255,255,255,.65);
        animation: ev-live-dot 1.2s ease-in-out infinite;
    }

@keyframes ev-live-pulse {
    0%, 100% { box-shadow: 0 0 0 2px rgba(229,62,62,.65), 0 4px 16px rgba(229,62,62,.3); }
    50%       { box-shadow: 0 0 0 3px rgba(229,62,62,.9),  0 4px 28px rgba(229,62,62,.55); }
}

@keyframes ev-live-dot {
    0%, 100% { opacity: 1;   transform: scale(1); }
    50%       { opacity: .2;  transform: scale(.6); }
}

.ev.t-amarillo {
    background: #FEF3CC;
    border-color: var(--gold);
    color: var(--gold-ink);
}

.ev.t-naranja {
    background: #FDE6CF;
    border-color: var(--orange);
    color: #5A2E08;
}

.ev.t-verde {
    background: #D9EEDF;
    border-color: var(--green);
    color: #1C4F2C;
}

.ev.t-azul {
    background: #D6E3F7;
    border-color: var(--blue);
    color: #14315F;
}

.ev.t-rojo {
    background: #F8D7DC;
    border-color: var(--red);
    color: #5E1622;
}

.ev.t-navy {
    background: var(--navy-800, #0D1B2A);
    border-color: var(--gold);
    color: #fff;
}

[data-theme="dark"] .ev.t-amarillo {
    background: rgba(251,196,46,.18);
    color: var(--gold);
}

[data-theme="dark"] .ev.t-naranja {
    background: rgba(240,138,42,.18);
    color: var(--orange);
}

[data-theme="dark"] .ev.t-verde {
    background: rgba(63,157,92,.18);
    color: var(--green);
}

[data-theme="dark"] .ev.t-azul {
    background: rgba(47,107,216,.18);
    color: #6695E5;
}

[data-theme="dark"] .ev.t-rojo {
    background: rgba(215,52,75,.18);
    color: #E85B70;
}

[data-theme="dark"] .ev.t-navy {
    background: rgba(251,196,46,.12);
    color: var(--gold);
}

.chart-bar.t-azul    { background: var(--blue);   }
.chart-bar.t-verde   { background: var(--green);  }
.chart-bar.t-naranja { background: var(--orange); }
.chart-bar.t-amarillo{ background: var(--gold);   }
.chart-bar.t-rojo    { background: var(--red);    }

.chart-bar.t-navy {
    background: var(--gold);
}

/* ====== SEGMENTED CONTROL ====== */
.segmented {
    display: inline-flex;
    background: var(--bg-inset);
    border-radius: 10px;
    padding: 3px;
    gap: 2px;
}

    .segmented button {
        background: transparent;
        border: 0;
        padding: 6px 12px;
        font-size: 12.5px;
        font-weight: 600;
        color: var(--text-muted);
        border-radius: 7px;
        cursor: pointer;
        transition: all .15s;
    }

        .segmented button:hover {
            color: var(--text);
        }

        .segmented button.active {
            background: var(--bg-elev);
            color: var(--text);
            box-shadow: var(--shadow-sm);
        }

        .segmented button.att-btn-present { background: rgba(63,157,92,.18); color: var(--green); }
        .segmented button.att-btn-absent  { background: rgba(215,52,75,.15);  color: var(--red); }

/* ====== ATTENDANCE LIST ====== */
.att-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 11px 0;
    border-bottom: 1px solid var(--border);
}
.att-row:last-child { border-bottom: 0; }
.att-info { flex: 1; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; min-width: 0; }
.att-name { font-weight: 600; font-size: 14px; }
.att-registrador { font-size: 11.5px; color: var(--text-muted); }

/* ── Barra de opciones del calendario (cabecera) ── */
.cal-toolbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.cal-toolbar-nav {
    display: flex;
    align-items: center;
    gap: 2px;
}

/* ====== CALENDAR MONTH VIEW ====== */
.cal-month {
    display: grid;
    grid-template-columns: repeat(7,1fr);
    gap: 4px;
}

.cal-month-hdr {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    text-align: center;
    padding: 6px 0;
}

.cal-month-day {
    min-height: 78px;
    padding: 6px;
    border-radius: 7px;
    border: 1px solid var(--border);
    background: var(--bg-elev);
    display: flex;
    flex-direction: column;
    gap: 3px;
}

    .cal-month-day.is-today {
        background: color-mix(in oklab, var(--accent) 8%, var(--bg-elev));
        border-color: color-mix(in oklab, var(--accent) 40%, var(--border));
    }

.cal-month-num {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-soft);
    font-family: var(--font-display);
    line-height: 1;
    margin-bottom: 2px;
}

.cal-month-day.is-today .cal-month-num {
    color: var(--accent);
}

.cal-month-ev {
    font-size: 10.5px;
    font-weight: 600;
    padding: 2px 5px;
    border-radius: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-decoration: none;
    border: 1px solid transparent;
    display: block;
    transition: opacity .15s;
}

    .cal-month-ev:hover {
        opacity: 0.8;
    }

/* ====== CHECK (template design system) ====== */
.check {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    cursor: pointer;
    user-select: none;
    font-size: 13.5px;
}

    .check input {
        appearance: none;
        width: 18px;
        height: 18px;
        border: 1.5px solid var(--border-strong);
        background: var(--bg-elev);
        border-radius: 5px;
        display: grid;
        place-items: center;
        transition: all .15s;
        flex-shrink: 0;
        cursor: pointer;
    }

        .check input:hover {
            border-color: var(--accent);
        }

        .check input:checked {
            background: var(--accent);
            border-color: var(--accent);
        }

/* ====== SPINNER OVERLAY ====== */
.spinner-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: color-mix(in srgb, var(--bg) 72%, transparent);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    align-items: center;
    justify-content: center;
}

    .spinner-overlay.visible {
        display: flex;
    }

/* ====== TKD SPINNER ====== */
@keyframes tkd-spin-y {
    from {
        transform: perspective(180px) rotateY(0deg);
    }

    to {
        transform: perspective(180px) rotateY(360deg);
    }
}

.tkd-spinner-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 300px;
}

.tkd-spinner-logo {
    width: 140px;
    height: 140px;
    border-radius: 50%;
    animation: tkd-spin-y 1.6s linear infinite;
}

.tkd-spinner-sm {
    display: inline-block;
    width: 16px;
    height: 16px;
    background: url('/img/logo-300x300.jpg') center / cover no-repeat;
    border-radius: 50%;
    animation: tkd-spin-y 1.6s linear infinite;
    vertical-align: middle;
    flex-shrink: 0;
}

/* ====== MINI CALENDAR ====== */
.mini-cal-wrap {
    position: relative;
    display: block;
    width: 100%;
}

.mini-cal-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    background: var(--bg-elev);
}

.mini-cal-icon { font-size: 13px; color: var(--text-muted); flex-shrink: 0; }
.mini-cal-placeholder { color: var(--text-soft); }

.mini-cal-clear {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 50%;
    background: var(--bg-inset);
    color: var(--text-soft);
    padding: 0;
    flex-shrink: 0;
    cursor: pointer;
    transition: background .12s, color .12s;
}

    .mini-cal-clear:hover {
        background: var(--red);
        color: #fff;
    }

[data-theme="dark"] .mini-cal-placeholder { color: var(--text-muted); }
[data-theme="dark"] .mini-cal-icon,
[data-theme="dark"] .mini-cal-clear { color: var(--text); }


.mini-cal-trigger--open {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
}

.mini-cal-trigger--disabled {
    opacity: 0.55;
    cursor: default;
    pointer-events: none;
}

.mini-cal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 199;
}

.mini-cal-dropdown {
    position: fixed;
    z-index: 200;
    /* top/bottom + left + width set via inline style from JS getBoundingClientRect */
}

.mini-cal {
    width: 280px;
    padding: 14px;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.mini-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.mini-cal-nav {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
}

    .mini-cal-nav:disabled {
        opacity: 0.25;
        cursor: not-allowed;
    }

.mini-cal-title {
    font-weight: 600;
    font-size: 13px;
    font-family: var(--font-display);
    color: var(--text);
    text-align: center;
    flex: 1;
}

.mini-cal-dow {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    margin-bottom: 4px;
    text-align: center;
    font-size: 11.5px;
    font-weight: 600;
    color: var(--text-muted);
}

    .mini-cal-dow > div {
        padding: 4px 0;
    }

.mini-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.mini-cal-day {
    aspect-ratio: 1 / 1;
    border-radius: var(--radius-sm);
    border: 0;
    background: transparent;
    color: var(--text);
    font-weight: 500;
    font-size: 12.5px;
    font-family: var(--font-display);
    cursor: pointer;
    transition: background .12s;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .mini-cal-day:hover:not(:disabled):not(.mini-cal-day--sel) {
        background: var(--bg-inset);
    }

.mini-cal-day--sel {
    background: var(--accent);
    color: var(--accent-ink);
    font-weight: 700;
}

.mini-cal-day--dis {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Icono de las flechas de navegación y del botón de borrar */
.mini-cal-chevron { font-size: 11px; }
.mini-cal-clear i { font-size: 10px; }

/* Título pulsable de la cabecera (sube de día → mes → año) */
.mini-cal-title-btn {
    border: 0;
    background: transparent;
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background .12s;
}

    .mini-cal-title-btn:hover {
        background: var(--bg-inset);
    }

/* Rejilla de selección de mes / año */
.mini-cal-cells {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
}

.mini-cal-cell {
    padding: 12px 0;
    border-radius: var(--radius-sm);
    border: 0;
    background: transparent;
    color: var(--text);
    font-weight: 500;
    font-size: 12.5px;
    font-family: var(--font-display);
    cursor: pointer;
    transition: background .12s;
}

    .mini-cal-cell:hover:not(:disabled):not(.mini-cal-cell--sel) {
        background: var(--bg-inset);
    }

.mini-cal-cell--sel {
    background: var(--accent);
    color: var(--accent-ink);
    font-weight: 700;
}

.mini-cal-cell--dis {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Selector de fecha de cargo en el detalle de remesa (ancho acotado) */
.remesa-fecha-edit { max-width: 200px; }

/* ====== DESCARGAS EN SEGUNDO PLANO ====== */
.bgjobs-panel {
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 1050;
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 320px;
    max-width: calc(100vw - 32px);
    max-height: calc(100vh - 32px);
    overflow-y: auto;
}

.bgjobs-card {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 12px 14px;
}

.bgjobs-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.bgjobs-estado-icon { font-size: 13px; color: var(--text-soft); flex-shrink: 0; }

.bgjobs-titulo {
    flex: 1;
    min-width: 0;
    font-weight: 600;
    font-size: 13px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bgjobs-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border: 0;
    border-radius: 50%;
    background: transparent;
    color: var(--text-soft);
    padding: 0;
    flex-shrink: 0;
    cursor: pointer;
    transition: background .12s, color .12s;
}

    .bgjobs-close:hover {
        background: var(--bg-inset);
        color: var(--text);
    }

.bgjobs-progress {
    height: 6px;
    margin-bottom: 6px;
    background: var(--bg-inset);
    border-radius: 999px;
}

    .bgjobs-progress .progress-bar {
        background-color: var(--accent);
    }

.bgjobs-bar-indeterminate { width: 100%; }

.bgjobs-msg { font-size: 11.5px; color: var(--text-muted); }
.bgjobs-ok    { color: var(--green); }
.bgjobs-error { color: var(--red); }
.bgjobs-muted { color: var(--text-muted); }

/* ====== INPUT CON ICONO ====== */
.input-icon-group { position: relative; }
.input-icon-group .form-control { padding-left: 36px !important; }
.input-icon-group .ig-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--text-muted); pointer-events: none; font-size: 13px; z-index: 1; }

/* ====== SWITCH ====== */
.switch-row { display: inline-flex; align-items: center; gap: 10px; font-size: 13.5px; cursor: pointer; user-select: none; }
.switch { position: relative; width: 38px; height: 22px; flex-shrink: 0; }
.switch input { position: absolute; inset: 0; opacity: 0; cursor: pointer; margin: 0; }
.switch .track { position: absolute; inset: 0; background: var(--border-strong); border-radius: 999px; transition: background .15s; }
.switch .thumb { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: #fff; border-radius: 999px; box-shadow: 0 1px 3px rgba(0,0,0,.2); transition: transform .2s cubic-bezier(.4,0,.2,1); pointer-events: none; }
.switch input:checked + .track { background: var(--accent); }
.switch input:checked + .track + .thumb { transform: translateX(16px); }
.switch input:focus-visible + .track { outline: 2px solid var(--accent); outline-offset: 2px; }

.check input:checked::after {
    content: "";
    width: 10px;
    height: 10px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%230B1729' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='2,6.5 5,9.5 10,3'/></svg>") no-repeat center / contain;
}

/* ====== TOOLTIP (JS-managed, position:fixed) ====== */
#app-tooltip {
    position: fixed;
    background: var(--navy-600);
    color: rgba(255,255,255,.92);
    font-size: 12px;
    font-weight: 500;
    font-family: var(--font-sans);
    white-space: nowrap;
    padding: 5px 11px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 4px 14px rgba(0,0,0,.35);
    pointer-events: none;
    opacity: 0;
    transition: opacity .14s;
    z-index: 9000;
}

/* ====== FORM UTILITIES ====== */
.form-container    { max-width: 600px; }
.form-container-sm { max-width: 480px; }
.form-container-lg { max-width: 640px; }
.form-container-xl { max-width: 900px; }

.section-label {
    font-size: 11.5px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 6px;
}
.select-narrow { max-width: 280px; }
.select-profesor { min-width: 180px; }
.form-hint     { font-size: .875rem; margin-top: .25rem; }

/* Color swatch picker (CinturonForm) */
.swatch-row      { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.swatch-btn      { width: 32px; height: 32px; border-radius: 8px; cursor: pointer; transition: transform .15s, box-shadow .15s; outline: none; }
.swatch-btn-none { width: 32px; height: 32px; border-radius: 8px; background: var(--bg-inset); cursor: pointer; font-size: 14px; color: var(--text-muted); outline: none; }

/* Lock icon in form labels */
.icon-lock { font-size: 11px; color: var(--text-muted); }

/* Cursor utilities */
.cursor-pointer  { cursor: pointer; }
.cursor-default  { cursor: default; }

/* Disabled/blocked input wrapper */
.cursor-blocked  { display: block; cursor: not-allowed; }

/* Belt picker text */
.belt-picker-placeholder { color: var(--text-muted); font-size: 13.5px; }
.belt-picker-item-text   { font-size: 13.5px; }

/* Min-width helpers for table-cell inputs and form combos */
.mw-80  { min-width:  80px; }
.mw-100 { min-width: 100px; }
.mw-135 { min-width: 135px; }
.mw-150 { min-width: 150px; }
.mw-220 { min-width: 220px; }

/* ====== DASHBOARD: DONUT CHART ====== */
.donut-chart      { display: block; margin: 0 auto; }
.donut-center-num { font-family: var(--font-display); font-weight: 700; font-size: 24px; fill: var(--text); }
.donut-center-lbl { font-family: var(--font-sans); font-size: 11px; fill: var(--text-muted); }

/* ====== LAYOUT HELPERS ====== */
.mt-gap   { margin-top: var(--gap); }
.mb-gap   { margin-bottom: var(--gap); }
.card-fill { height: 100%; margin-bottom: 0; }

/* ====== DASHBOARD: ALERTAS OPERATIVAS ====== */
.alerta-head {
    display: flex;
    align-items: center;
    gap: 8px;
}

.alerta-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 5px;
    border-radius: 999px;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}
.alerta-count--warn   { background: var(--orange); }
.alerta-count--danger { background: var(--red); }

.alerta-lista {
    max-height: 190px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.alerta-item {
    font-size: 13px;
    color: var(--text);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.alerta-item-icon {
    font-size: 10px;
    color: var(--text-muted);
    flex-shrink: 0;
    width: 12px;
}

.alerta-item-detail {
    font-size: 11.5px;
    color: var(--text-muted);
}

.alerta-empty {
    color: var(--text-muted);
    font-size: 13px;
}

/* ====== DASHBOARD: DISTRIBUCIÓN (sexo, edad) ====== */
.dist-bar {
    display: flex;
    height: 14px;
    border-radius: 999px;
    overflow: hidden;
    border: 1px solid var(--border);
}

.dist-bar-seg {
    border-right: 1px solid rgba(0,0,0,.06);
}

.dist-legend {
    margin-top: 14px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.dist-legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
}

.dist-swatch {
    width: 14px;
    height: 8px;
    border-radius: 2px;
    flex-shrink: 0;
}

.dist-legend-label  { flex: 1; }

.dist-legend-count {
    font-family: var(--font-display);
    font-weight: 600;
}

.dist-legend-pct {
    color: var(--text-muted);
    width: 34px;
    text-align: right;
}

.dist-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.dist-row + .dist-row { margin-top: 8px; }

.dist-row-lbl {
    width: 72px;
    font-size: 12.5px;
    color: var(--text);
    flex-shrink: 0;
}

.dist-row-bar {
    flex: 1;
    background: var(--border);
    border-radius: 4px;
    height: 14px;
    overflow: hidden;
}

.dist-row-count {
    font-size: 11.5px;
    font-weight: 700;
    color: var(--text);
    width: 28px;
    text-align: right;
    flex-shrink: 0;
}

/* ====== MAINTENANCE SCREEN ====== */
.maintenance-screen {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    gap: 1rem;
    padding: 2rem;
    text-align: center;
}

.maintenance-icon {
    font-size: 4rem;
    color: var(--accent);
}

.maintenance-text {
    max-width: 480px;
    font-size: 1.05rem;
}

/* Clave de parámetro en la pantalla de gestión: color de texto normal (no el
   rojo por defecto de <code>) y algo más grande para que se lea bien. */
.param-codigo {
    color: var(--text);
    font-size: 1rem;
    font-weight: 600;
}

/* ====== Visor de documentos (modal) ====== */
.docvisor-overlay {
    position: fixed;
    inset: 0;
    z-index: 1080;
    background: rgba(0, 0, 0, .55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.docvisor-dialog {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: min(1000px, 100%);
    height: min(90vh, 100%);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.docvisor-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-soft);
}

.docvisor-title {
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.docvisor-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.docvisor-body {
    flex: 1;
    min-height: 0;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-inset);
}

.docvisor-frame {
    width: 100%;
    height: 100%;
    border: 0;
    background: #fff;
}

.docvisor-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.docvisor-video {
    max-width: 100%;
    max-height: 100%;
    background: #000;
}

.docvisor-fallback {
    text-align: center;
    color: var(--text-muted);
    padding: 32px;
}

.docvisor-fallback-icon {
    font-size: 3rem;
    display: block;
    margin-bottom: 12px;
}

/* ====== Desplegable de documentos (barra superior) ====== */
.docs-menu {
    position: relative;
    display: inline-flex;
}

    .docs-menu__btn {
        position: relative;
    }

    .docs-menu__count {
        position: absolute;
        top: -2px;
        right: -2px;
        min-width: 16px;
        height: 16px;
        padding: 0 4px;
        border-radius: 8px;
        background: var(--accent);
        color: var(--accent-ink);
        font-size: 10px;
        font-weight: 700;
        line-height: 16px;
        text-align: center;
    }

/* Capa invisible para cerrar al hacer clic fuera */
.docs-menu__overlay {
    position: fixed;
    inset: 0;
    z-index: 1040;
}

.docs-menu__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 1050;
    width: 420px;
    max-width: calc(100vw - 24px);
    max-height: 60vh;
    overflow-y: auto;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-lg);
    padding: 6px;
}

    .docs-menu__head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
        padding: 8px 10px;
        font-weight: 600;
        color: var(--text);
        border-bottom: 1px solid var(--border);
        margin-bottom: 4px;
    }

    .docs-menu__curso {
        font-size: 12px;
        font-weight: 600;
        color: var(--accent);
    }

    .docs-menu__empty {
        padding: 14px 10px;
        color: var(--text-muted);
        font-size: 13px;
        text-align: center;
    }

    .docs-menu__list {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .docs-menu__item {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 8px 10px;
        border-radius: var(--radius-sm);
        cursor: pointer;
        transition: background .12s;
    }

        .docs-menu__item:hover {
            background: var(--bg-inset);
        }

    .docs-menu__icon {
        font-size: 16px;
        flex-shrink: 0;
    }

    .docs-menu__info {
        display: flex;
        flex-direction: column;
        min-width: 0;
        flex: 1;
    }

    .docs-menu__name {
        color: var(--text);
        font-size: 13px;
        font-weight: 500;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .docs-menu__desc {
        color: var(--text-muted);
        font-size: 11.5px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .docs-menu__dl {
        color: var(--text-muted);
        font-size: 13px;
        flex-shrink: 0;
        background: transparent;
        border: 0;
        padding: 4px 6px;
        border-radius: var(--radius-sm);
        cursor: pointer;
        transition: background .12s, color .12s;
    }

    .docs-menu__item:hover .docs-menu__dl {
        color: var(--accent);
    }

        .docs-menu__dl:hover {
            color: var(--accent);
            background: color-mix(in srgb, var(--accent) 15%, transparent);
        }
