/* ============================================================
   InsCore — Dark Glass Design System
   1.  Design Tokens
   2.  Global Reset & Font Rendering
   3.  Animated Background Orbs
   4.  AppBar — Glass Surface
   5.  Drawer — Glass Surface
   6.  Cards & Papers — Glassmorphism
   7.  Tables
   8.  Inputs & Buttons
   9.  Nav Links
   10. KPI Cards
   11. Empty State
   12. Page Entry Animations
   13. Light Mode Overrides
   14. Responsive Media Queries
   ============================================================ */

/* ── 1. Design Tokens ─────────────────────────────────────── */
:root {
    /* Glassmorphism surfaces */
    --glass-bg:             rgba(10, 22, 50, 0.65);
    --glass-bg-heavy:       rgba(6, 14, 30, 0.85);
    --glass-border:         rgba(148, 163, 184, 0.10);
    --glass-border-hover:   rgba(148, 163, 184, 0.22);
    --glass-blur:           blur(20px) saturate(180%);
    --glass-blur-heavy:     blur(32px) saturate(200%);

    /* Layout */
    --app-radius-card:      18px;
    --app-radius-input:     12px;
    --app-radius-button:    10px;

    /* Shadows */
    --app-shadow-card:       0 4px 24px rgba(0, 0, 0, 0.35), 0 1px 3px rgba(0, 0, 0, 0.20);
    --app-shadow-card-hover: 0 8px 40px rgba(59, 130, 246, 0.18), 0 2px 8px rgba(0, 0, 0, 0.30);
    --app-glow-blue:         0 0 40px rgba(59, 130, 246, 0.15);
    --app-glow-violet:       0 0 40px rgba(124, 58, 237, 0.12);

    /* Animation timing */
    --anim-ease:   cubic-bezier(0.16, 1, 0.3, 1);
    --anim-fast:   180ms;
    --anim-normal: 280ms;
    --anim-slow:   500ms;

    /* Orb colors */
    --orb-blue:   rgba(59, 130, 246, 0.18);
    --orb-violet: rgba(124, 58, 237, 0.13);
    --orb-mint:   rgba(16, 185, 129, 0.10);
}

/* ── 2. Global Reset & Font Rendering ─────────────────────── */
html, body {
    font-feature-settings: 'cv11', 'ss01', 'liga' 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    background-color: var(--mud-palette-background, #050d1a);
    overflow-x: hidden;
}

/* ── 3. Animated Background Orbs ──────────────────────────── */
.app-bg-orbs {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.app-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    will-change: transform;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
}

.app-orb--blue {
    width: clamp(400px, 60vw, 900px);
    height: clamp(400px, 60vw, 900px);
    background: radial-gradient(circle, var(--orb-blue) 0%, transparent 70%);
    top: -20%;
    right: -10%;
    animation: orbFloat 14s ease-in-out infinite alternate;
}

.app-orb--violet {
    width: clamp(300px, 45vw, 700px);
    height: clamp(300px, 45vw, 700px);
    background: radial-gradient(circle, var(--orb-violet) 0%, transparent 70%);
    bottom: -15%;
    left: -5%;
    animation: orbFloat 18s ease-in-out infinite alternate-reverse;
    animation-delay: -6s;
}

.app-orb--mint {
    width: clamp(200px, 30vw, 500px);
    height: clamp(200px, 30vw, 500px);
    background: radial-gradient(circle, var(--orb-mint) 0%, transparent 70%);
    top: 40%;
    left: 30%;
    animation: orbFloat 22s ease-in-out infinite alternate;
    animation-delay: -10s;
}

@keyframes orbFloat {
    0%   { transform: translate(0, 0) scale(1); }
    33%  { transform: translate(40px, -30px) scale(1.05); }
    66%  { transform: translate(-20px, 20px) scale(0.97); }
    100% { transform: translate(30px, 40px) scale(1.03); }
}

/* Layout layers sit above orbs — only mud-layout needs stacking context;
   AppBar/Drawer/MainContent use MudBlazor's own z-indices (1100+) */
.mud-layout {
    position: relative;
    z-index: 1;
}

/* ── 4. AppBar — Glass Surface ────────────────────────────── */
.mud-appbar {
    background: var(--glass-bg-heavy) !important;
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border-bottom: 1px solid var(--glass-border) !important;
    box-shadow: none !important;
}

.mud-appbar::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(59, 130, 246, 0.35) 30%,
        rgba(124, 58, 237, 0.25) 70%,
        transparent 100%
    );
    pointer-events: none;
}

/* Brand name — gradient text */
.mud-appbar .mud-typography-h6 {
    font-family: 'Syne', system-ui, sans-serif;
    font-weight: 700;
    letter-spacing: -0.01em;
    background: linear-gradient(135deg, #e2e8f0 0%, #94a3b8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── 5. Drawer — Glass Surface ────────────────────────────── */
.mud-drawer {
    background: var(--glass-bg-heavy) !important;
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border-right: 1px solid var(--glass-border) !important;
}

.mud-drawer::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background: linear-gradient(
        180deg,
        transparent 0%,
        rgba(59, 130, 246, 0.40) 30%,
        rgba(124, 58, 237, 0.30) 70%,
        transparent 100%
    );
    pointer-events: none;
}

/* Drawer: el menú de navegación scrollea dentro del drawer (alto fijo bajo el AppBar),
   de forma independiente al scroll de la página — así se alcanzan los grupos del final
   (Ajustes, Manual) sin alargar la página al abrir una categoría. */
.app-drawer .mud-drawer-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

.app-drawer .mud-navmenu {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
}

/* ── Barra compacta "pegajosa" de páginas de detalle (PageHeader) ──
   Vive en la columna de contenido (se alinea sola a su ancho) y se pega bajo el AppBar fijo.
   En reposo ocupa 0 alto (invisible); al salir la cabecera grande, JS añade .is-stuck y se
   despliega. Fondo opaco reutilizando superficie + tinte, idéntico a la cabecera fija de listados. */
.ins-detail-stickybar {
    position: sticky;
    top: var(--mud-appbar-height, 64px);
    z-index: 30;
    display: flex;
    align-items: center;
    gap: 12px;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    padding: 0 10px;
    border-radius: var(--app-radius-input);
    border-bottom: 1px solid var(--glass-border);
    background-color: var(--mud-palette-surface);
    background-image: linear-gradient(rgba(10, 22, 50, 0.50), rgba(10, 22, 50, 0.50));
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    transition: max-height var(--anim-normal) var(--anim-ease),
                opacity var(--anim-fast) var(--anim-ease);
}

.ins-detail-stickybar.is-stuck {
    max-height: 56px;
    opacity: 1;
    pointer-events: auto;
    padding-top: 6px;
    padding-bottom: 6px;
    margin-bottom: 1rem;
}

.ins-detail-stickybar__title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
}

/* ── 6. Cards & Papers — Glassmorphism ────────────────────── */
.mud-paper {
    background: var(--glass-bg) !important;
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--app-radius-card);
    transition:
        box-shadow var(--anim-normal) var(--anim-ease),
        border-color var(--anim-normal) var(--anim-ease),
        transform var(--anim-normal) var(--anim-ease);
}

.mud-card {
    box-shadow: var(--app-shadow-card);
}

.mud-card:hover,
.mud-paper.app-card-hover:hover {
    box-shadow: var(--app-shadow-card-hover);
    border-color: var(--glass-border-hover);
    transform: translateY(-2px);
}

/* Dialogs */
.mud-dialog {
    background: rgba(6, 14, 35, 0.94) !important;
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border: 1px solid var(--glass-border-hover);
    border-radius: var(--app-radius-card);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.60), var(--app-glow-blue);
}

/* Popovers / dropdowns */
.mud-popover-paper {
    background: rgba(6, 14, 35, 0.96) !important;
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border: 1px solid var(--glass-border-hover);
    border-radius: var(--app-radius-input);
}

/* .ins-tall-popover (selects de lista larga) vive ahora en el RCL compartido insLayout.css —
   SSOT único para los 3 hosts; se eliminó de aquí para no duplicar. */

/* ── 7. Tables ─────────────────────────────────────────────── */
.mud-table-root .mud-table-head .mud-table-cell {
    font-family: 'Inter', system-ui, sans-serif;
    font-weight: 600;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--mud-palette-text-secondary);
    background: rgba(10, 22, 50, 0.50) !important;
    border-bottom: 1px solid var(--glass-border);
}

.mud-table-root .mud-table-body .mud-table-row {
    transition: background-color var(--anim-fast) ease;
}

.mud-table-root .mud-table-row.app-row-hover:hover,
.mud-table-root .mud-table-body .mud-table-row:hover {
    background-color: rgba(59, 130, 246, 0.06) !important;
}

.mud-table-root .mud-table-cell {
    border-bottom: 1px solid var(--glass-border);
}

/* ── Listados: área de scroll acotada al viewport (patrón data-grid) ──
   Las superficies de listado envuelven la rejilla en un MudPaper redondeado
   marcado con .ins-listado. Acotamos la altura del contenedor propio de la
   rejilla (.mud-table-container) a la pantalla y lo hacemos desplazable en
   ambos ejes; combinado con FixedHeader="true" en la MudDataGrid, la cabecera
   queda pegada arriba y AMBAS barras (vertical y horizontal) viven en el borde
   del área visible. Así la barra horizontal está SIEMPRE a la vista, sin tener
   que bajar al final de una lista larga (la chapuza anterior, overflow-x:auto
   global, dejaba la barra al fondo de la tabla completa). Las esquinas
   redondeadas siguen recortando porque el scroll vive en el hijo. */
.ins-listado .mud-table-container {
    /* Descuento = barra superior + cabecera de página + pestañas + barra de
       búsqueda de la propia tarjeta (~293px en la página más cargada, Recibos)
       + el pager inferior (~52px) + holgura. Con esto, en la página más densa
       la barra horizontal y el pager caben dentro del viewport sin bajar al
       final de la lista; en páginas más ligeras simplemente sobra aire. */
    max-height: calc(100dvh - 22rem);
    min-height: 12rem;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

/* La cabecera fija (FixedHeader) queda pegada arriba mientras el cuerpo se
   desplaza por debajo. El tinte de cabecera de la app es translúcido (alpha
   0.50 en oscuro / 0.80 en claro), lo que dejaba TRASLUCIR las filas al pasar
   bajo ella. Lo volvemos OPACO sin cambiar su aspecto: una base sólida de
   superficie + el mismo tinte por encima (gradiente plano). Reusa los valores
   existentes, así el color es idéntico al estático. */
.ins-listado .mud-table-container .mud-table-head .mud-table-cell {
    background-color: var(--mud-palette-surface) !important;
    background-image: linear-gradient(rgba(10, 22, 50, 0.50), rgba(10, 22, 50, 0.50)) !important;
}

body.ins-light .ins-listado .mud-table-container .mud-table-head .mud-table-cell {
    background-color: var(--mud-palette-surface) !important;
    background-image: linear-gradient(rgba(248, 250, 255, 0.80), rgba(248, 250, 255, 0.80)) !important;
}

/* ── Kanban board (Trello/Salesforce) ───────────────────────────
   Columnas en UNA fila con scroll horizontal, en lugar de un grid que
   envuelve y deja la última columna colgando abajo (caso 7 estados de
   siniestros). Compartido por los tableros de siniestros y prospectos. */
.ins-kanban-board {
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 8px;
    scroll-snap-type: x proximity;
}

.ins-kanban-column {
    flex: 0 0 248px;
    min-width: 248px;
    scroll-snap-align: start;
}

/* ── Toolbar transversal de listas (ListToolbar) ───────────────── */
.app-list-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--glass-border);
}

.app-list-toolbar__search {
    min-width: 280px;
    flex: 1 1 280px;
    max-width: 420px;
}

.app-list-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

/* ── 8. Inputs & Buttons ───────────────────────────────────── */
.mud-input-outlined-border {
    border-color: var(--glass-border) !important;
    border-radius: var(--app-radius-input) !important;
    transition: border-color var(--anim-fast) ease, box-shadow var(--anim-fast) ease;
}

.mud-input-outlined:hover .mud-input-outlined-border {
    border-color: var(--glass-border-hover) !important;
}

.mud-input-outlined.mud-focused .mud-input-outlined-border {
    border-color: rgba(59, 130, 246, 0.60) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

.mud-input-control .mud-input-slot {
    border-radius: var(--app-radius-input);
    background: rgba(10, 22, 50, 0.40);
}

.mud-button-root {
    border-radius: var(--app-radius-button) !important;
    text-transform: none;
    font-family: 'Inter', system-ui, sans-serif;
    font-weight: 500;
    letter-spacing: 0.02em;
    transition:
        box-shadow var(--anim-fast) var(--anim-ease),
        transform var(--anim-fast) var(--anim-ease);
}

.mud-button-filled.mud-button-filled-primary {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.30);
}

.mud-button-filled.mud-button-filled-primary:hover {
    box-shadow: 0 6px 24px rgba(59, 130, 246, 0.45);
    transform: translateY(-1px);
}

.mud-button-filled.mud-button-filled-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.30);
}

/* ── 9. Nav Links ─────────────────────────────────────────── */
.mud-nav-link {
    margin: 2px 8px;
    border-radius: 10px;
    transition:
        background-color var(--anim-fast) ease,
        color var(--anim-fast) ease;
}

.mud-nav-link:hover {
    background-color: rgba(59, 130, 246, 0.08);
}

.mud-nav-link.active {
    background: linear-gradient(
        90deg,
        rgba(59, 130, 246, 0.18) 0%,
        rgba(59, 130, 246, 0.06) 100%
    );
    color: #60a5fa !important;
    border-radius: 10px;
    box-shadow: inset 3px 0 0 #3b82f6;
}

.mud-nav-link.active .mud-icon-root {
    color: #3b82f6 !important;
}

/* ── 10. KPI Cards ────────────────────────────────────────── */
.app-kpi-card {
    position: relative;
    background: linear-gradient(
        135deg,
        rgba(59, 130, 246, 0.10) 0%,
        rgba(10, 22, 50, 0.60) 100%
    ) !important;
    border: 1px solid rgba(59, 130, 246, 0.18) !important;
    box-shadow: var(--app-glow-blue), var(--app-shadow-card);
    transition:
        box-shadow var(--anim-normal) var(--anim-ease),
        transform var(--anim-normal) var(--anim-ease),
        border-color var(--anim-normal) ease;
}

/* Tarjetas navegables: acento azul claro + cursor de enlace, distinguible YA en reposo. */
.app-kpi-card--link {
    cursor: pointer;
    border-color: rgba(59, 130, 246, 0.30) !important;
}

/* Tarjetas SOLO informativas (sin destino): tono neutro y sin glow azul, para que recedan
   y el contraste con las navegables se lea de un vistazo sin necesidad de hover. */
.app-kpi-card:not(.app-kpi-card--link) {
    background: linear-gradient(
        135deg,
        rgba(148, 163, 184, 0.05) 0%,
        rgba(10, 22, 50, 0.55) 100%
    ) !important;
    border-color: rgba(148, 163, 184, 0.12) !important;
    box-shadow: var(--app-shadow-card);
}

/* Afordancia "ir a": solo las tarjetas navegables se elevan al hover e indican destino. */
.app-kpi-card--link:hover {
    box-shadow: 0 8px 40px rgba(59, 130, 246, 0.22), 0 2px 8px rgba(0, 0, 0, 0.30);
    transform: translateY(-3px);
    border-color: rgba(59, 130, 246, 0.45) !important;
}

/* Flecha "ir a": claramente visible en reposo (pastilla con fondo) y plena al hover. */
.app-kpi-card__go {
    position: absolute;
    bottom: 10px;
    right: 12px;
    opacity: 0.75;
    color: var(--mud-palette-primary);
    background: rgba(59, 130, 246, 0.12);
    border-radius: 999px;
    padding: 2px;
    transition: opacity var(--anim-normal) ease, transform var(--anim-normal) ease,
        background-color var(--anim-normal) ease;
}

.app-kpi-card--link:hover .app-kpi-card__go {
    opacity: 1;
    background: rgba(59, 130, 246, 0.22);
    transform: translate(2px, -2px);
}

/* KPI numbers — Syne display for maximum impact */
.app-kpi-card .mud-typography-h3,
.app-kpi-card .mud-typography-h4 {
    font-family: 'Syne', system-ui, sans-serif;
    font-weight: 800;
    background: linear-gradient(135deg, #e2e8f0 0%, #93c5fd 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── 11. Empty State ──────────────────────────────────────── */
.app-empty-state {
    padding: 64px 24px;
    text-align: center;
    color: var(--mud-palette-text-secondary);
}

.app-empty-state .mud-icon-root {
    width: 64px;
    height: 64px;
    margin-bottom: 16px;
    opacity: 0.30;
    filter: drop-shadow(0 0 12px rgba(59, 130, 246, 0.30));
}

/* ── 12. Page Entry Animations ────────────────────────────── */
.mud-main-content > .mud-container {
    animation: pageEnter var(--anim-slow) var(--anim-ease) both;
}

@keyframes pageEnter {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Staggered grid items */
.mud-grid > .mud-item {
    animation: itemEnter var(--anim-slow) var(--anim-ease) both;
}

.mud-grid > .mud-item:nth-child(1) { animation-delay: 0ms; }
.mud-grid > .mud-item:nth-child(2) { animation-delay: 60ms; }
.mud-grid > .mud-item:nth-child(3) { animation-delay: 120ms; }
.mud-grid > .mud-item:nth-child(4) { animation-delay: 180ms; }
.mud-grid > .mud-item:nth-child(5) { animation-delay: 240ms; }
.mud-grid > .mud-item:nth-child(6) { animation-delay: 300ms; }
.mud-grid > .mud-item:nth-child(7) { animation-delay: 360ms; }
.mud-grid > .mud-item:nth-child(8) { animation-delay: 420ms; }

@keyframes itemEnter {
    from { opacity: 0; transform: translateY(12px) scale(0.99); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Chips */
.mud-chip {
    border-radius: 999px !important;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
}

/* Progress bars */
.mud-progress-linear .mud-progress-linear-bar {
    background: linear-gradient(90deg, #3b82f6, #7c3aed) !important;
    border-radius: 999px;
}

/* Snackbar */
.mud-snackbar {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border-hover);
    border-radius: var(--app-radius-input);
}

/* ── 13. Light Mode Overrides ─────────────────────────────── */
/* MudBlazor v7 does NOT add a class to <body>; we inject ins-light/ins-dark
   via JS (insCoreTheme.applyTheme) so these selectors fire reliably. */

body {
    transition: background-color 300ms ease;
}

body.ins-light {
    background-color: #f0f4ff;
}

body.ins-light .app-bg-orbs {
    opacity: 0.22;
}

body.ins-light .mud-paper {
    background: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: rgba(148, 163, 184, 0.20);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08), 0 1px 2px rgba(15, 23, 42, 0.04);
}

body.ins-light .mud-appbar {
    background: rgba(255, 255, 255, 0.90) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom-color: rgba(148, 163, 184, 0.20) !important;
}

body.ins-light .mud-appbar .mud-typography-h6 {
    background: linear-gradient(135deg, #0f172a 0%, #1e40af 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

body.ins-light .mud-appbar::after {
    opacity: 0.5;
}

body.ins-light .mud-drawer {
    background: rgba(248, 250, 255, 0.96) !important;
    border-right-color: rgba(148, 163, 184, 0.20) !important;
}

body.ins-light .mud-dialog {
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(148, 163, 184, 0.25);
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.15);
}

body.ins-light .mud-popover-paper {
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(148, 163, 184, 0.20);
}

body.ins-light .mud-input-control .mud-input-slot {
    background: rgba(248, 250, 252, 0.80);
}

body.ins-light .app-kpi-card {
    background: linear-gradient(
        135deg,
        rgba(59, 130, 246, 0.06) 0%,
        rgba(255, 255, 255, 0.85) 100%
    ) !important;
    border-color: rgba(59, 130, 246, 0.15) !important;
    box-shadow: 0 2px 12px rgba(59, 130, 246, 0.08);
}

/* Modo claro: navegables con acento azul, informativas en gris neutro plano. */
body.ins-light .app-kpi-card--link {
    border-color: rgba(59, 130, 246, 0.30) !important;
}

body.ins-light .app-kpi-card:not(.app-kpi-card--link) {
    background: linear-gradient(
        135deg,
        rgba(148, 163, 184, 0.10) 0%,
        rgba(255, 255, 255, 0.85) 100%
    ) !important;
    border-color: rgba(100, 116, 139, 0.18) !important;
    box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05);
}

body.ins-light .app-kpi-card .mud-typography-h3,
body.ins-light .app-kpi-card .mud-typography-h4 {
    background: linear-gradient(135deg, #0f172a 0%, #1e40af 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

body.ins-light .mud-table-root .mud-table-head .mud-table-cell {
    background: rgba(248, 250, 255, 0.80) !important;
}

body.ins-light .mud-nav-link.active {
    color: #1d4ed8 !important;
    box-shadow: inset 3px 0 0 #2563eb;
}

body.ins-light .mud-nav-link.active .mud-icon-root {
    color: #2563eb !important;
}

/* ── 14. Responsive Media Queries ─────────────────────────── */

/* Mobile — < 600px */
@media (max-width: 599px) {
    .mud-main-content > .mud-container {
        padding: 12px !important;
    }

    /* Smaller orbs on mobile to save GPU */
    .app-orb {
        filter: blur(60px);
        opacity: 0.75;
    }
    .app-orb--blue   { width: 280px; height: 280px; }
    .app-orb--violet { width: 230px; height: 230px; }
    .app-orb--mint   { width: 140px; height: 140px; }

    /* Bottom sheet dialogs on mobile */
    .mud-dialog-container .mud-dialog {
        margin: 0 !important;
        border-radius: 20px 20px 0 0 !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        max-width: 100% !important;
        max-height: 92vh;
        overflow-y: auto;
    }
}

/* Tablet — 600px–959px */
@media (min-width: 600px) and (max-width: 959px) {
    .mud-main-content > .mud-container {
        padding: 16px !important;
    }

    .app-orb--blue   { width: 480px; height: 480px; }
    .app-orb--violet { width: 370px; height: 370px; }
}

/* Accessibility — reduced motion */
@media (prefers-reduced-motion: reduce) {
    .app-orb { animation: none; }

    .mud-main-content > .mud-container,
    .mud-grid > .mud-item {
        animation: none;
    }

    .mud-card,
    .mud-paper,
    .mud-button-root,
    .mud-nav-link,
    .app-kpi-card {
        transition: none;
    }
}

/* Malla de seguridad anti-desborde de tooltips MudBlazor: acota el ancho y permite wrap para que
   ningún popover (texto largo o contenido rico) se pinte a ancho completo. El bug de posicionamiento
   en sí (flash en (0,0) por interop JS) se evita migrando los tooltips de texto largo a TextTooltip
   (title nativo) — ver src/Shared/InsCore.Ui.Gadgets/TextTooltip.razor. */
.mud-tooltip {
    max-width: min(360px, 90vw);
    white-space: normal;
    overflow-wrap: anywhere;
}

/* ── 15. Reconexión del circuito (Blazor Server) ───────────────
   Overlay visible cuando se cae la conexión SignalR. Sin esto la app quedaba congelada en
   silencio (ver App.razor + insCoreReconnect en theme.js). Blazor alterna las clases
   components-reconnect-show/-failed/-rejected sobre #components-reconnect-modal. */
#components-reconnect-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 20000; /* por encima de diálogos/popovers MudBlazor */
    align-items: center;
    justify-content: center;
    background: rgba(3, 8, 20, 0.72);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
}

#components-reconnect-modal.components-reconnect-show,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-rejected {
    display: flex;
}

.ins-reconnect__box {
    background: var(--glass-bg-heavy);
    border: 1px solid var(--glass-border-hover);
    border-radius: var(--app-radius-card);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
    padding: 28px 36px;
    text-align: center;
    color: #e2e8f0;
    font-family: 'Inter', system-ui, sans-serif;
    max-width: 90vw;
}

.ins-reconnect__spinner {
    width: 36px;
    height: 36px;
    margin: 0 auto 16px;
    border: 3px solid rgba(148, 163, 184, 0.25);
    border-top-color: #3b82f6;
    border-radius: 50%;
    animation: ins-reconnect-spin 0.8s linear infinite;
}

@keyframes ins-reconnect-spin { to { transform: rotate(360deg); } }

.ins-reconnect__msg { margin: 0; font-size: 0.95rem; }

/* El bloque de fallo solo aparece cuando se agotan los reintentos o el circuito es rechazado. */
.ins-reconnect__failed { display: none; }
.components-reconnect-failed .ins-reconnect__failed,
.components-reconnect-rejected .ins-reconnect__failed { display: block; margin-top: 12px; }
/* En fallo/rechazo ocultamos SOLO el mensaje "reconectando…" (lo sustituye el bloque de
   recuperación), pero el spinner SIGUE girando: estamos auto-recargando, no muertos. */
.components-reconnect-failed .ins-reconnect__msg,
.components-reconnect-rejected .ins-reconnect__msg { display: none; }

.ins-reconnect__failed button {
    margin-top: 10px;
    padding: 8px 20px;
    border: none;
    border-radius: var(--app-radius-button);
    background: #3b82f6;
    color: #fff;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
}
.ins-reconnect__failed button:hover { background: #2563eb; }

body.ins-light #components-reconnect-modal { background: rgba(15, 23, 42, 0.45); }
body.ins-light .ins-reconnect__box { background: rgba(255, 255, 255, 0.98); color: #0f172a; }

/* ── 16. Antídoto overlay de popover (MudBlazor 8.4) ───────────
   El popover de un MudSelect/MudDatePicker abierto monta un overlay a pantalla completa con
   z-index 1601 que tapa los botones del diálogo (backdrop del diálogo va a 1401). El primer clic
   en Cancelar/Aceptar lo "come" ese overlay → "el botón no hace nada / el modal no se cierra"
   (verificado en vivo: Playwright reporta "mud-overlay intercepts pointer events").

   Lo hacemos transparente a punteros: así el clic llega al botón al PRIMER intento. El cierre-al-
   clic-fuera del popover (que ese overlay daba) se restituye por JS (insCoreOverlay en theme.js),
   que dispara el cierre nativo SIN consumir el clic. Solo afecta al overlay del popover-provider,
   nunca al backdrop del diálogo. */
.mud-popover-provider > .mud-overlay {
    pointer-events: none !important;
}
