/* ============================================================
   OPTIMO BUSINESS CENTRAL THEME
   Sistema de diseño Fluent / Microsoft 365 / Business Central
   Cargar DESPUÉS de style.min.css y vendor.css.
   ============================================================ */

/* ===== Tokens ===== */
:root {
    /* Tipografía sistema Segoe UI con fallbacks cross-OS */
    --bc-font: "Segoe UI", "Segoe UI Variable", system-ui, -apple-system, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    --bc-font-mono: ui-monospace, "Cascadia Mono", "Consolas", Menlo, monospace;

    /* Escala tipográfica BC (px) */
    --bc-fs-xs: 11px;
    --bc-fs-sm: 12px;
    --bc-fs-base: 13px;
    --bc-fs-md: 14px;
    --bc-fs-lg: 16px;
    --bc-fs-xl: 20px;
    --bc-fs-2xl: 24px;
    --bc-fs-3xl: 28px;

    /* Pesos */
    --bc-fw-regular: 400;
    --bc-fw-semibold: 600;
    --bc-fw-bold: 700;

    /* Alturas de línea */
    --bc-lh-tight: 1.2;
    --bc-lh-normal: 1.4;
    --bc-lh-loose: 1.6;

    /* Paleta Fluent neutral */
    --bc-ink: #201F1E;             /* texto principal */
    --bc-ink-2: #323130;           /* títulos secundarios */
    --bc-muted: #605E5C;           /* texto muted */
    --bc-muted-2: #8A8886;         /* placeholder */

    --bc-bg: #FFFFFF;              /* superficie base */
    --bc-bg-alt: #FAF9F8;          /* fondo de página */
    --bc-bg-hover: #F3F2F1;        /* hover neutro */
    --bc-bg-selected: #EDEBE9;     /* selected neutro */

    --bc-border: #EDEBE9;          /* divisor estándar */
    --bc-border-2: #E1DFDD;        /* divisor más visible */
    --bc-border-strong: #D2D0CE;   /* input border */

    /* Accent Fluent */
    --bc-accent: #0078D4;
    --bc-accent-hover: #106EBE;
    --bc-accent-pressed: #005A9E;
    --bc-accent-soft: #EFF6FC;
    --bc-accent-soft-2: #DEECF9;

    /* Estados semánticos (Fluent) */
    --bc-success: #107C10;
    --bc-success-soft: #DFF6DD;
    --bc-warning: #F2AA18;
    --bc-warning-soft: #FFF4CE;
    --bc-danger: #D13438;
    --bc-danger-soft: #FDE7E9;
    --bc-info: #0078D4;
    --bc-info-soft: #DEECF9;

    /* Radios (acabados finos BC) */
    --bc-radius-xs: 2px;
    --bc-radius-sm: 4px;
    --bc-radius-md: 6px;
    --bc-radius-lg: 8px;

    /* Sombras finas (BC depth tokens) */
    --bc-shadow-2: 0 0.6px 1.8px rgba(0,0,0,.10), 0 3.2px 7.2px rgba(0,0,0,.13);
    --bc-shadow-4: 0 0.9px 2.7px rgba(0,0,0,.10), 0 4.8px 10.8px rgba(0,0,0,.13);
    --bc-shadow-8: 0 1.6px 3.6px rgba(0,0,0,.11), 0 6.4px 14.4px rgba(0,0,0,.13);
    --bc-shadow-16: 0 3.2px 7.2px rgba(0,0,0,.13), 0 12.8px 28.8px rgba(0,0,0,.18);
    --bc-shadow-flat: 0 1px 0 rgba(0,0,0,.06);

    /* Layout */
    --bc-topbar-h: 48px;
    --bc-content-px: 12px;
    --bc-content-px-lg: 16px;

    /* Easings & duraciones */
    --bc-ease: cubic-bezier(.33,0,.67,1);
    --bc-dur-1: 90ms;
    --bc-dur-2: 150ms;
    --bc-dur-3: 240ms;

    /* Focus ring Fluent */
    --bc-focus: #0F6CBD;
    --bc-focus-ring: 0 0 0 2px var(--bc-focus);
}

/* ============================================================
   BASE: html/body y reset suave del template Pixinvent
   ============================================================ */
html,
body {
    font-family: var(--bc-font);
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-regular);
    line-height: var(--bc-lh-normal);
    color: var(--bc-ink);
    background: var(--bc-bg-alt);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "kern", "liga", "calt";
    text-rendering: optimizeLegibility;
}

/* Números tabulares para grids / listas */
.dx-datagrid,
.bc-table,
.tabular-nums,
.dx-datagrid-rowsview {
    font-variant-numeric: tabular-nums;
}

/* Headings con escala BC (compact moderado) */
h1, .h1 { font-size: var(--bc-fs-2xl); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 8px; color: var(--bc-ink); }
h2, .h2 { font-size: var(--bc-fs-xl); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 6px; color: var(--bc-ink); }
h3, .h3 { font-size: var(--bc-fs-lg); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 4px; color: var(--bc-ink); }
h4, .h4 { font-size: var(--bc-fs-md); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 4px; color: var(--bc-ink-2); }
h5, .h5 { font-size: var(--bc-fs-base); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 3px; color: var(--bc-ink-2); }
h6, .h6 { font-size: var(--bc-fs-sm); font-weight: var(--bc-fw-semibold); line-height: var(--bc-lh-tight); margin: 0 0 3px; color: var(--bc-muted); text-transform: uppercase; letter-spacing: .04em; }

small, .small { font-size: var(--bc-fs-sm); color: var(--bc-muted); }
.text-muted { color: var(--bc-muted) !important; }
.text-muted-2 { color: var(--bc-muted-2); }

/* Code / monospace */
code, kbd, samp, pre { font-family: var(--bc-font-mono); font-size: .92em; }

/* Links */
a {
    color: var(--bc-accent);
    text-decoration: none;
    transition: color var(--bc-dur-1) var(--bc-ease);
}
a:hover { color: var(--bc-accent-hover); text-decoration: underline; }
a:focus-visible { outline: 2px solid var(--bc-focus); outline-offset: 2px; border-radius: var(--bc-radius-xs); }

/* Focus visible global Fluent */
:focus-visible { outline: 2px solid var(--bc-focus); outline-offset: 2px; }

/* ============================================================
   TOPBAR (BC / M365 horizontal)
   ============================================================ */
.bc-topbar {
    height: var(--bc-topbar-h);
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    box-shadow: var(--bc-shadow-flat);
    display: flex;
    align-items: center;
    padding: 0 var(--bc-content-px);
    position: sticky;
    top: 0;
    z-index: 1000;
    font-family: var(--bc-font);
}

.bc-topbar__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-right: 18px;
    flex-shrink: 0;
}

.bc-topbar__brand img {
    height: 24px;
    width: auto;
}

.bc-topbar__brand-text {
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
    letter-spacing: -0.01em;
}

.bc-topbar__company {
    margin-right: 14px;
    min-width: 180px;
    flex-shrink: 0;
}

.bc-topbar__company .form-control,
.bc-topbar__company .dx-selectbox {
    height: 32px;
    font-size: var(--bc-fs-md);
    border: 1px solid transparent;
    border-radius: var(--bc-radius-sm);
    background: transparent;
    color: var(--bc-ink);
    padding: 0 8px;
    transition: background var(--bc-dur-1), border-color var(--bc-dur-1);
}

.bc-topbar__company .form-control:hover { background: var(--bc-bg-hover); }
.bc-topbar__company .form-control:focus {
    background: var(--bc-bg);
    border-color: var(--bc-accent);
    box-shadow: 0 0 0 1px var(--bc-accent);
    outline: none;
}

.bc-topbar__menu {
    flex: 1;
    display: flex;
    align-items: center;
    min-width: 0; /* permite shrink dentro del flex */
    position: relative;
}

/* WmsMenu host: ocupa todo el espacio disponible del topbar */
.bc-topbar__menu .wms-menu-host {
    flex: 1;
    display: flex;
    align-items: center;
    min-width: 0;
    width: 100%;
    position: relative;
}

.bc-topbar__menu .wms-menu-desktop,
.bc-topbar__menu .wms-menu-mobile {
    flex: 1;
    min-width: 0;
    position: relative;
}

/* Gradient fade a los lados: indica "hay más para desplazar" */
.bc-topbar__menu .wms-menu-desktop::before,
.bc-topbar__menu .wms-menu-desktop::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 28px;
    pointer-events: none;
    z-index: 2;
    opacity: 0;
    transition: opacity var(--bc-dur-2);
}
.bc-topbar__menu .wms-menu-desktop::before {
    left: 0;
    background: linear-gradient(90deg, var(--bc-bg) 0%, rgba(255,255,255,0) 100%);
}
.bc-topbar__menu .wms-menu-desktop::after {
    right: 0;
    background: linear-gradient(270deg, var(--bc-bg) 0%, rgba(255,255,255,0) 100%);
}

/* Mostrar fade-left cuando hay scroll desde el inicio */
.bc-topbar__menu .wms-menu-desktop.has-scroll-left::before { opacity: 1; }
.bc-topbar__menu .wms-menu-desktop.has-scroll-right::after { opacity: 1; }

.bc-topbar__menu #menuDesktopScroll {
    overflow-x: auto;
    overflow-y: hidden;
    height: var(--bc-topbar-h);
    transition: padding var(--bc-dur-2) var(--bc-ease);
    display: flex;
    align-items: center;
    /* Scrollbar fino estilo BC */
    scrollbar-width: thin;
    scrollbar-color: var(--bc-border-strong) transparent;
    /* Scroll suave al usar las flechas o JS */
    scroll-behavior: smooth;
}

/* Scrollbar WebKit: muy fino abajo, casi invisible hasta hover */
.bc-topbar__menu #menuDesktopScroll::-webkit-scrollbar {
    height: 4px;
}
.bc-topbar__menu #menuDesktopScroll::-webkit-scrollbar-track {
    background: transparent;
}
.bc-topbar__menu #menuDesktopScroll::-webkit-scrollbar-thumb {
    background: transparent;
    border-radius: 2px;
    transition: background var(--bc-dur-2);
}
.bc-topbar__menu #menuDesktopScroll:hover::-webkit-scrollbar-thumb,
.bc-topbar__menu #menuDesktopScroll:focus-within::-webkit-scrollbar-thumb {
    background: var(--bc-border-strong);
}
.bc-topbar__menu #menuDesktopScroll::-webkit-scrollbar-thumb:hover {
    background: var(--bc-muted-2);
}

.bc-topbar__menu #menuDesktopScroll .dx-menu { width: max-content; }

/* Botones flecha ‹ › opcionales: aparecen sobre el fade cuando hay overflow */
.bc-topbar__menu .menu-scroll-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--bc-bg);
    border: 1px solid var(--bc-border-strong);
    color: var(--bc-ink);
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 3;
    box-shadow: var(--bc-shadow-2);
    transition: background var(--bc-dur-1), color var(--bc-dur-1);
    padding: 0;
}
.bc-topbar__menu .menu-scroll-btn:hover { background: var(--bc-accent); color: #fff; border-color: var(--bc-accent); }
.bc-topbar__menu .menu-scroll-btn.left  { left: 2px; }
.bc-topbar__menu .menu-scroll-btn.right { right: 2px; }
.bc-topbar__menu .wms-menu-desktop.has-scroll-left  .menu-scroll-btn.left  { display: inline-flex; }
.bc-topbar__menu .wms-menu-desktop.has-scroll-right .menu-scroll-btn.right { display: inline-flex; }
.bc-topbar__menu .menu-scroll-btn svg { width: 12px; height: 12px; }

/* Padding dinámico para que el botón ‹ › no tape los items del menú */
.bc-topbar__menu .wms-menu-desktop.has-scroll-left  #menuDesktopScroll { padding-left: 30px; }
.bc-topbar__menu .wms-menu-desktop.has-scroll-right #menuDesktopScroll { padding-right: 30px; }

/* ============================================================
   WMS Mobile drawer (dxPopup del WmsMenu)
   ============================================================ */
#mobilePopup .dx-popup-wrapper > .dx-overlay-content {
    border-radius: 0 var(--bc-radius-md) var(--bc-radius-md) 0;
    box-shadow: var(--bc-shadow-16);
}

#mobilePopup .dx-popup-title {
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    padding: 10px 14px;
    min-height: var(--bc-topbar-h);
    align-items: center;
}

#mobilePopup .dx-popup-title .dx-toolbar-label {
    font-family: var(--bc-font);
    font-size: var(--bc-fs-lg);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
}

#mobilePopup .dx-popup-title .dx-closebutton {
    width: 32px;
    height: 32px;
    border-radius: var(--bc-radius-sm);
}

#mobilePopup .dx-popup-title .dx-closebutton:hover {
    background: var(--bc-bg-hover);
}

#mobilePopup .dx-popup-content { padding: 0; }

#mobilePopup .mobileTree .dx-treeview-item {
    padding: 8px 12px;
    font-size: var(--bc-fs-md);
}

#mobilePopup .mobileTree .dx-treeview-item.dx-state-hover {
    background: var(--bc-bg-hover);
}

/* Shading detrás del drawer (overlay click-to-close) */
.dx-overlay-shader { background: rgba(0, 0, 0, 0.32); }

/* Toolbar móvil con look BC */
#toolbarMobile {
    background: transparent;
    height: var(--bc-topbar-h);
}

#toolbarMobile .dx-toolbar-items-container { height: var(--bc-topbar-h); }

#toolbarMobile .dx-button {
    background: transparent;
    border: none;
    width: 36px;
    height: 36px;
    border-radius: var(--bc-radius-sm);
}

#toolbarMobile .dx-button.dx-state-hover { background: var(--bc-bg-hover); }
#toolbarMobile .dx-button .dx-icon { color: var(--bc-ink-2); }

/* dxMenu horizontal: forzamos look BC */
.bc-topbar__menu .dx-menu-base {
    background: transparent;
    border: none;
}

.bc-topbar__menu .dx-menu-horizontal > .dx-menu-items-container > .dx-menu-item-wrapper > .dx-menu-item {
    padding: 0 12px;
    height: var(--bc-topbar-h);
    line-height: var(--bc-topbar-h);
    border-radius: 0;
    color: var(--bc-ink);
    font-weight: var(--bc-fw-regular);
    font-size: var(--bc-fs-md);
    transition: background var(--bc-dur-1), color var(--bc-dur-1);
    position: relative;
}

.bc-topbar__menu .dx-menu-item .dx-menu-item-content {
    padding: 0;
    color: inherit;
}

.bc-topbar__menu .dx-menu-item.dx-state-hover {
    background: var(--bc-bg-hover);
}

.bc-topbar__menu .dx-menu-item.dx-menu-item-expanded,
.bc-topbar__menu .dx-menu-item.dx-state-active {
    background: var(--bc-bg-hover);
    color: var(--bc-accent);
}

/* Underline accent en hover/active (look BC nativo) */
.bc-topbar__menu .dx-menu-horizontal > .dx-menu-items-container > .dx-menu-item-wrapper > .dx-menu-item::after {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 0;
    height: 2px;
    background: transparent;
    transition: background var(--bc-dur-2) var(--bc-ease);
}

.bc-topbar__menu .dx-menu-horizontal > .dx-menu-items-container > .dx-menu-item-wrapper > .dx-menu-item.dx-state-hover::after,
.bc-topbar__menu .dx-menu-horizontal > .dx-menu-items-container > .dx-menu-item-wrapper > .dx-menu-item.dx-menu-item-expanded::after {
    background: var(--bc-accent);
}

/* Submenús dxMenu (popovers verticales) — SOLO aplica al popout, NO al menú
   horizontal del topbar (que tiene su propio template Bootstrap d-flex). */
.dx-submenu {
    background: var(--bc-bg);
    border: 1px solid var(--bc-border-2);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-8);
    padding: 4px 0;
    min-width: 240px;
}

.dx-submenu .dx-menu-item {
    padding: 6px 12px;
    font-size: var(--bc-fs-md);
    color: var(--bc-ink);
}

.dx-submenu .dx-menu-item.dx-state-hover {
    background: var(--bc-bg-hover);
    color: var(--bc-accent);
}

/* Dentro del popout, asegurar que el span del texto no colapse cuando
   el item-content (que viene con d-flex) intenta calcular width.
   Usamos selector específico .dx-submenu para no afectar el menú root. */
.dx-submenu .dx-menu-item-content {
    width: 100%;
}

.dx-submenu .dx-menu-item-content > span {
    flex: 1 1 auto;
    white-space: nowrap;
    min-width: 0;
    display: inline-block;
}

/* Iconos derecha (acciones rápidas) */
.bc-topbar__actions {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    margin-left: 12px;
}

.bc-topbar__icon-btn {
    width: 36px;
    height: 36px;
    border-radius: var(--bc-radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--bc-ink-2);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background var(--bc-dur-1), color var(--bc-dur-1);
    position: relative;
    text-decoration: none;
}

.bc-topbar__icon-btn:hover {
    background: var(--bc-bg-hover);
    color: var(--bc-accent);
    text-decoration: none;
}

.bc-topbar__icon-btn:active { background: var(--bc-bg-selected); }

.bc-topbar__icon-btn i { font-size: 16px; line-height: 1; }

/* Badge sobre icono (notificaciones) */
.bc-topbar__icon-btn .badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    font-size: var(--bc-fs-xs);
    font-weight: var(--bc-fw-semibold);
    line-height: 16px;
    border-radius: 999px;
    background: var(--bc-danger);
    color: #fff;
}

/* Avatar perfil topbar */
.bc-topbar__avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    margin-left: 4px;
    border: 1px solid var(--bc-border-2);
    object-fit: cover;
    cursor: pointer;
    transition: box-shadow var(--bc-dur-1);
}
.bc-topbar__avatar:hover { box-shadow: 0 0 0 2px var(--bc-accent-soft); }

/* ============================================================
   PAGE WRAPPER & CONTAINER (sin sidebar)
   Override del template Pixinvent
   ============================================================ */
#main-wrapper {
    background: var(--bc-bg-alt);
    min-height: 100vh;
}

#main-wrapper .page-wrapper {
    margin-left: 0 !important;     /* mata el espacio del sidebar */
    background: var(--bc-bg-alt) !important;
    min-height: calc(100vh - var(--bc-topbar-h));
    padding-top: 0;
}

#main-wrapper .container-fluid {
    padding: var(--bc-content-px-lg);
    max-width: 1600px;
    margin: 0 auto;
}

/* Ocultar elementos del template Pixinvent que sobran */
#main-wrapper > .left-sidebar,
#main-wrapper > .topbar,                /* topbar viejo Pixinvent (solo si fuera hermano directo) */
.preloader,
.right-sidebar,
.sidebar-footer,
.chat-windows {
    display: none !important;
}

/* Breadcrumb basura del template (sparkcharts $0 hidden) — solo cuando NO está dentro del topbar */
.page-wrapper > .row.page-titles,
.container-fluid > .row.page-titles {
    display: none !important;
}

/* Matar waves effects (ripple Material) que no calza con BC */
.waves-effect, .waves-input-wrapper {
    -webkit-mask-image: none !important;
            mask-image: none !important;
}
.waves-ripple { display: none !important; }

/* ============================================================
   FOOTER BC
   ============================================================ */
.footer {
    background: var(--bc-bg);
    border-top: 1px solid var(--bc-border);
    color: var(--bc-muted);
    font-size: var(--bc-fs-sm);
    padding: 8px 16px;
    text-align: center;
}

/* ============================================================
   CARDS / PANELES (.bc-panel + Bootstrap .card)
   ============================================================ */
.bc-panel,
.card {
    background: var(--bc-bg);
    border: 1px solid var(--bc-border);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-flat);
    margin-bottom: 12px;
    transition: box-shadow var(--bc-dur-2) var(--bc-ease);
}

.bc-panel:hover,
.card.bc-panel--hoverable:hover {
    box-shadow: var(--bc-shadow-4);
}

.bc-panel__hdr,
.card-header {
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    padding: 8px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: var(--bc-radius-md) var(--bc-radius-md) 0 0;
}

.bc-panel__title,
.card-header h4,
.card-header h5 {
    margin: 0;
    font-size: var(--bc-fs-lg);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
    letter-spacing: -0.01em;
}

.bc-panel__body,
.card-body {
    padding: 12px;
}

.bc-panel__footer,
.card-footer {
    background: var(--bc-bg-alt);
    border-top: 1px solid var(--bc-border);
    padding: 8px 14px;
    border-radius: 0 0 var(--bc-radius-md) var(--bc-radius-md);
}

/* ============================================================
   HOME CARD (patrón replicado de TarConfig)
   ============================================================ */
.bc-home-card {
    background: var(--bc-bg);
    border: 1px solid var(--bc-border);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-flat);
    overflow: hidden;
    margin-bottom: 16px;
    transition: box-shadow var(--bc-dur-2);
}

.bc-home-card__hdr {
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    padding: 8px 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.bc-home-card__title {
    margin: 0;
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
    letter-spacing: -0.01em;
}

.bc-home-card__hdr i {
    color: var(--bc-accent);
    font-size: 16px;
}

.bc-home-card__body {
    padding: 10px 14px 12px;
}

/* ============================================================
   DASHBOARD MINI (KPI cards con health border-left)
   Replicado de tar-dash-mini
   ============================================================ */
.bc-dash-mini {
    background: var(--bc-bg);
    border: 1px solid var(--bc-border);
    border-left: 3px solid var(--bc-border-strong);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-flat);
    padding: 10px 14px;
    cursor: pointer;
    transition: transform var(--bc-dur-1), box-shadow var(--bc-dur-2), border-color var(--bc-dur-2);
    height: 100%;
    position: relative;
    text-decoration: none;
    display: block;
    color: var(--bc-ink);
}

.bc-dash-mini::after {
    content: "→";
    position: absolute;
    right: 12px;
    top: 14px;
    color: var(--bc-border-strong);
    font-size: 1.1rem;
    transition: transform var(--bc-dur-2), color var(--bc-dur-2);
}

.bc-dash-mini:hover {
    transform: translateY(-1px);
    box-shadow: var(--bc-shadow-4);
    text-decoration: none;
    color: var(--bc-ink);
}

.bc-dash-mini:hover::after {
    transform: translateX(3px);
    color: var(--bc-accent);
}

.bc-dash-mini.ok      { border-left-color: var(--bc-success); }
.bc-dash-mini.warn    { border-left-color: var(--bc-warning); }
.bc-dash-mini.danger  { border-left-color: var(--bc-danger); }
.bc-dash-mini.neutral { border-left-color: var(--bc-accent); }

.bc-dash-mini__label {
    font-size: var(--bc-fs-xs);
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--bc-muted);
    font-weight: var(--bc-fw-semibold);
    margin: 0;
}

.bc-dash-mini__value {
    font-size: var(--bc-fs-2xl);
    font-weight: var(--bc-fw-bold);
    color: var(--bc-ink);
    line-height: 1;
    margin: 6px 0 4px;
    font-variant-numeric: tabular-nums;
}

.bc-dash-mini__sub {
    font-size: var(--bc-fs-sm);
    color: var(--bc-muted);
}

/* ============================================================
   STEP INDICATOR 1 → 2 → 3 (replicado de tar-steps)
   ============================================================ */
.bc-steps {
    display: flex;
    align-items: stretch;
    gap: 8px;
    margin: 0 0 16px;
}

.bc-step {
    flex: 1;
    background: var(--bc-bg);
    border: 1px solid var(--bc-border);
    border-radius: var(--bc-radius-md);
    padding: 10px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: border-color var(--bc-dur-2), box-shadow var(--bc-dur-2);
    text-decoration: none;
    color: var(--bc-ink);
}

.bc-step:hover { border-color: var(--bc-accent); box-shadow: var(--bc-shadow-flat); text-decoration: none; }
.bc-step.active { border-color: var(--bc-accent); background: var(--bc-accent-soft); }
.bc-step.done   { border-color: var(--bc-success); background: var(--bc-success-soft); }

.bc-step__num {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--bc-bg-hover);
    color: var(--bc-muted);
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-bold);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.bc-step.active .bc-step__num { background: var(--bc-accent); color: #fff; }
.bc-step.done   .bc-step__num { background: var(--bc-success); color: #fff; }

.bc-step__label {
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
    line-height: 1.2;
}

.bc-step__sub {
    font-size: var(--bc-fs-xs);
    color: var(--bc-muted);
}

/* ============================================================
   SEARCH BAR con shortcut "/" (replicado de tar-search)
   ============================================================ */
.bc-search-wrap {
    position: relative;
    margin: 0 0 16px;
    max-width: 560px;
}

.bc-search-wrap input {
    width: 100%;
    height: 36px;
    padding: 6px 40px 6px 36px;
    border: 1px solid var(--bc-border-strong);
    border-radius: var(--bc-radius-md);
    background: var(--bc-bg);
    font-size: var(--bc-fs-md);
    font-family: var(--bc-font);
    color: var(--bc-ink);
    transition: border-color var(--bc-dur-1), box-shadow var(--bc-dur-1);
}

.bc-search-wrap input::placeholder { color: var(--bc-muted-2); }

.bc-search-wrap input:focus {
    outline: none;
    border-color: var(--bc-accent);
    box-shadow: 0 0 0 1px var(--bc-accent);
}

.bc-search-wrap .icon-left {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bc-muted-2);
    pointer-events: none;
    font-size: 14px;
}

.bc-search-wrap .kbd-hint {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--bc-fs-xs);
    color: var(--bc-muted);
    background: var(--bc-bg-hover);
    padding: 2px 6px;
    border-radius: var(--bc-radius-xs);
    font-family: var(--bc-font-mono);
    pointer-events: none;
    border: 1px solid var(--bc-border);
}

.bc-search-wrap input:not(:placeholder-shown) ~ .kbd-hint { display: none; }

/* ============================================================
   BOTONES Bootstrap → look Fluent
   ============================================================ */
.btn,
.dx-button {
    font-family: var(--bc-font);
    font-size: var(--bc-fs-md);
    font-weight: var(--bc-fw-semibold);
    border-radius: var(--bc-radius-sm) !important;
    text-transform: none;
    transition: background var(--bc-dur-1), border-color var(--bc-dur-1), color var(--bc-dur-1);
}

.btn-primary,
.dx-button.dx-button-default {
    background: var(--bc-accent);
    border-color: var(--bc-accent);
    color: #fff;
}

.btn-primary:hover,
.dx-button.dx-button-default.dx-state-hover {
    background: var(--bc-accent-hover);
    border-color: var(--bc-accent-hover);
    color: #fff;
}

.btn-primary:active,
.dx-button.dx-button-default.dx-state-active {
    background: var(--bc-accent-pressed);
    border-color: var(--bc-accent-pressed);
}

.btn-secondary,
.btn-default,
.dx-button.dx-button-normal {
    background: var(--bc-bg);
    border: 1px solid var(--bc-border-strong);
    color: var(--bc-ink);
}

.btn-secondary:hover,
.btn-default:hover,
.dx-button.dx-button-normal.dx-state-hover {
    background: var(--bc-bg-hover);
    border-color: var(--bc-border-strong);
    color: var(--bc-ink);
}

.btn-success { background: var(--bc-success); border-color: var(--bc-success); color: #fff; }
.btn-warning { background: var(--bc-warning); border-color: var(--bc-warning); color: var(--bc-ink); }
.btn-danger  { background: var(--bc-danger);  border-color: var(--bc-danger);  color: #fff; }

.btn-link { color: var(--bc-accent); }
.btn-link:hover { color: var(--bc-accent-hover); }

/* Variantes suaves */
.btn-primary-soft {
    background: var(--bc-accent-soft);
    color: var(--bc-accent);
    border: 1px solid var(--bc-accent-soft-2);
}
.btn-primary-soft:hover { background: var(--bc-accent-soft-2); }

/* ============================================================
   FORMS Bootstrap → look Fluent
   ============================================================ */
.form-control,
.form-select {
    height: 32px;
    padding: 4px 8px;
    font-family: var(--bc-font);
    font-size: var(--bc-fs-md);
    color: var(--bc-ink);
    background: var(--bc-bg);
    border: 1px solid var(--bc-border-strong);
    border-radius: var(--bc-radius-sm);
    transition: border-color var(--bc-dur-1), box-shadow var(--bc-dur-1);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--bc-accent);
    box-shadow: 0 0 0 1px var(--bc-accent);
    outline: none;
}

.form-control::placeholder { color: var(--bc-muted-2); }

label {
    font-size: var(--bc-fs-sm);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink-2);
    margin-bottom: 4px;
}

/* ============================================================
   DEVEXTREME DataGrid → Fluent DetailsList
   ============================================================ */
.dx-datagrid {
    font-family: var(--bc-font) !important;
    font-size: var(--bc-fs-md);
    border: 1px solid var(--bc-border) !important;
    border-radius: var(--bc-radius-md);
    overflow: hidden;
    background: var(--bc-bg);
}

.dx-datagrid .dx-datagrid-headers {
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border-2);
    color: var(--bc-ink);
    font-weight: var(--bc-fw-semibold);
}

.dx-datagrid-headers tr td {
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink-2);
    padding: 6px 8px;
    border-color: var(--bc-border) !important;
    font-size: var(--bc-fs-xs);
    letter-spacing: .02em;
}

.dx-datagrid-rowsview .dx-row > td {
    padding: 5px 8px;
    border-color: var(--bc-border) !important;
    color: var(--bc-ink);
}

.dx-datagrid .dx-row.dx-state-hover > td,
.dx-datagrid .dx-row:hover td {
    background: #F6FAFF;
}

.dx-datagrid .dx-row-alt > td {
    background: var(--bc-bg-alt);
}

.dx-datagrid .dx-selection > td,
.dx-datagrid .dx-selection.dx-row > td {
    background: var(--bc-accent-soft) !important;
    color: var(--bc-ink);
}

.dx-datagrid .dx-link {
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-accent);
}

.dx-datagrid .dx-link:hover { color: var(--bc-accent-hover); }

/* Header panel del grid: blanco con borde inferior fino */
.dx-datagrid-header-panel {
    padding: 0;
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
}

.dx-datagrid-header-panel .dx-toolbar {
    margin: 0;
    padding: 0 12px;
    background: transparent;
    min-height: 48px;
}

.dx-datagrid-header-panel .dx-toolbar-items-container { height: 48px; align-items: center; }

.dx-datagrid-header-panel .dx-button {
    margin: 0 4px;
    border-radius: var(--bc-radius-sm);
}

.dx-datagrid-header-panel .dx-texteditor-input {
    font-family: var(--bc-font);
    font-size: var(--bc-fs-md);
}

/* Filter row + search */
.dx-datagrid .dx-datagrid-filter-row .dx-texteditor-input {
    height: 28px;
    font-size: var(--bc-fs-sm);
}

.dx-searchbox .dx-texteditor-input,
.dx-texteditor-input {
    padding: 4px 8px;
}

/* Pager Fluent */
.dx-pager {
    background: var(--bc-bg);
    border-top: 1px solid var(--bc-border);
}

.dx-pager .dx-page,
.dx-pager .dx-navigation-button {
    border-radius: var(--bc-radius-sm);
    color: var(--bc-ink);
}

.dx-pager .dx-page {
    border: 1px solid transparent;
    padding: 4px 10px;
    font-size: var(--bc-fs-sm);
}

.dx-pager .dx-page.dx-selection {
    border-color: var(--bc-accent-soft-2);
    background: var(--bc-accent-soft);
    color: var(--bc-accent);
}

.dx-pager .dx-page:not(.dx-selection):hover { background: var(--bc-bg-hover); }

/* Command links */
.dx-datagrid .dx-command-edit .dx-link {
    padding: 2px 6px;
    border-radius: var(--bc-radius-sm);
}
.dx-datagrid .dx-command-edit .dx-link:hover {
    background: var(--bc-bg-hover);
}

/* ============================================================
   MODALES BC (sticky header/footer + altura segura)
   ============================================================ */
.modal-content {
    border: 1px solid var(--bc-border-2);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-16);
    background: var(--bc-bg);
}

.modal-header {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    padding: 10px 14px;
}

.modal-title {
    font-size: var(--bc-fs-lg);
    font-weight: var(--bc-fw-semibold);
    color: var(--bc-ink);
}

.modal-body {
    max-height: calc(100vh - 180px);
    overflow: auto;
    overscroll-behavior: contain;
    padding: 12px;
    background: var(--bc-bg);
}

.modal-footer {
    position: sticky;
    bottom: 0;
    z-index: 2;
    background: var(--bc-bg);
    border-top: 1px solid var(--bc-border);
    padding: 8px 14px;
}

.modal-dialog.modal-full-width { max-width: 96vw; }

/* WF modal fullscreen mantenido */
#wfModal.modal.modal-workflow .modal-dialog {
    max-width: 98vw !important;
    width: 98vw !important;
    margin: .75rem auto !important;
}
#wfModal.modal.modal-workflow .modal-content { height: calc(100vh - 32px); }
#wfModal.modal.modal-workflow .modal-body { height: calc(100vh - 140px); overflow: auto; }

/* ============================================================
   BC SHORTCUTS (dropdown favoritos/frecuentes/recientes)
   ============================================================ */
.bc-shortcuts-dropdown {
    min-width: 320px;
    max-width: 380px;
    padding: 0 !important;
    border: 1px solid var(--bc-border-2);
    border-radius: var(--bc-radius-md);
    box-shadow: var(--bc-shadow-16);
    background: var(--bc-bg);
    overflow: hidden;
}

/* Search bar dentro del dropdown shortcuts */
.bc-shortcuts-search {
    position: relative;
    padding: 8px 10px;
    background: var(--bc-bg);
    border-bottom: 1px solid var(--bc-border);
    display: flex;
    align-items: center;
    gap: 8px;
}

.bc-shortcuts-search > i.mdi {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bc-muted-2);
    font-size: 15px;
    pointer-events: none;
}

.bc-shortcuts-search input {
    flex: 1;
    height: 30px;
    border: 1px solid var(--bc-border-strong);
    border-radius: var(--bc-radius-sm);
    background: var(--bc-bg);
    padding: 0 28px 0 30px;
    font-family: var(--bc-font);
    font-size: var(--bc-fs-sm);
    color: var(--bc-ink);
    outline: none;
    transition: border-color var(--bc-dur-1), box-shadow var(--bc-dur-1);
}

.bc-shortcuts-search input::placeholder {
    color: var(--bc-muted-2);
}

.bc-shortcuts-search input:focus {
    border-color: var(--bc-accent);
    box-shadow: 0 0 0 1px var(--bc-accent);
}

.bc-shortcuts-search__clear {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--bc-bg-hover);
    border: none;
    color: var(--bc-muted);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background var(--bc-dur-1), color var(--bc-dur-1);
}

.bc-shortcuts-search__clear:hover {
    background: var(--bc-danger-soft);
    color: var(--bc-danger);
}

.bc-shortcuts-search__clear i { font-size: 13px; line-height: 1; }

.bc-shortcuts-section {
    border-bottom: 1px solid var(--bc-border);
    padding: 6px 0;
}
.bc-shortcuts-section:last-child { border-bottom: none; }

.bc-shortcuts-section__title {
    font-size: var(--bc-fs-xs);
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--bc-muted);
    font-weight: var(--bc-fw-semibold);
    padding: 6px 14px;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.bc-shortcuts-section__title i { font-size: 13px; }
.bc-shortcuts-section__title .text-warn { color: var(--bc-warning); }
.bc-shortcuts-section__title .text-hot   { color: var(--bc-danger); }
.bc-shortcuts-section__title .text-info  { color: var(--bc-accent); }

.bc-shortcuts-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 14px;
    color: var(--bc-ink);
    text-decoration: none;
    font-size: var(--bc-fs-md);
    transition: background var(--bc-dur-1);
    position: relative;
    cursor: pointer;
}

.bc-shortcuts-item:hover {
    background: var(--bc-bg-hover);
    color: var(--bc-accent);
    text-decoration: none;
}

.bc-shortcuts-item__icon {
    width: 18px;
    text-align: center;
    color: var(--bc-muted);
    flex-shrink: 0;
    font-size: 14px;
}

.bc-shortcuts-item:hover .bc-shortcuts-item__icon { color: var(--bc-accent); }

.bc-shortcuts-item__text {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bc-shortcuts-item__meta {
    font-size: var(--bc-fs-xs);
    color: var(--bc-muted-2);
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    padding: 2px 6px;
    background: var(--bc-bg-hover);
    border-radius: var(--bc-radius-xs);
}

/* Grip handle para drag-to-reorder (solo favoritos) */
.bc-shortcuts-item__grip {
    flex-shrink: 0;
    width: 14px;
    color: var(--bc-muted-2);
    opacity: 0;
    transition: opacity var(--bc-dur-1), color var(--bc-dur-1);
    cursor: grab;
    margin-left: -4px;
    line-height: 1;
    user-select: none;
}

.bc-shortcuts-item.is-fav:hover .bc-shortcuts-item__grip {
    opacity: 1;
}

.bc-shortcuts-item__grip:active { cursor: grabbing; }
.bc-shortcuts-item__grip i { font-size: 16px; line-height: 1; }

/* Estados drag */
.bc-shortcuts-item.dragging {
    opacity: 0.4;
    background: var(--bc-accent-soft);
}

.bc-shortcuts-item.drag-over-top {
    box-shadow: 0 -2px 0 0 var(--bc-accent) inset;
    background: var(--bc-accent-soft);
}

.bc-shortcuts-item.drag-over-bottom {
    box-shadow: 0 2px 0 0 var(--bc-accent) inset;
    background: var(--bc-accent-soft);
}

/* Hint visual Alt+N en favoritos */
.bc-shortcuts-item__kbd {
    font-size: 10px;
    color: var(--bc-muted-2);
    background: var(--bc-bg-alt);
    border: 1px solid var(--bc-border);
    padding: 1px 5px;
    border-radius: var(--bc-radius-xs);
    font-family: var(--bc-font-mono);
    letter-spacing: .02em;
    flex-shrink: 0;
    line-height: 1.3;
}

.bc-shortcuts-item:hover .bc-shortcuts-item__kbd {
    background: var(--bc-accent-soft);
    color: var(--bc-accent);
    border-color: var(--bc-accent-soft-2);
}

.bc-shortcuts-item__star {
    opacity: 0;
    transition: opacity var(--bc-dur-1), color var(--bc-dur-1);
    background: transparent;
    border: none;
    color: var(--bc-muted-2);
    padding: 2px 4px;
    cursor: pointer;
    line-height: 1;
    flex-shrink: 0;
}

.bc-shortcuts-item:hover .bc-shortcuts-item__star { opacity: 1; }
.bc-shortcuts-item__star.active { opacity: 1; color: var(--bc-warning); }
.bc-shortcuts-item__star:hover { color: var(--bc-warning); }

.bc-shortcuts-empty {
    padding: 12px 14px;
    color: var(--bc-muted);
    font-size: var(--bc-fs-sm);
    font-style: italic;
}

.bc-shortcuts-footer {
    padding: 8px 14px;
    background: var(--bc-bg-alt);
    border-top: 1px solid var(--bc-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-radius: 0 0 var(--bc-radius-md) var(--bc-radius-md);
}

.bc-shortcuts-footer__link {
    font-size: var(--bc-fs-xs);
    color: var(--bc-muted);
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 2px 0;
}
.bc-shortcuts-footer__link:hover { color: var(--bc-danger); text-decoration: underline; }

/* ============================================================
   ALERTS Bootstrap → look Fluent
   ============================================================ */
.alert {
    border-radius: var(--bc-radius-md);
    border: 1px solid transparent;
    padding: 10px 14px;
    font-size: var(--bc-fs-md);
}

.alert-info    { background: var(--bc-info-soft);    border-color: var(--bc-accent);  color: var(--bc-ink); }
.alert-success { background: var(--bc-success-soft); border-color: var(--bc-success); color: var(--bc-ink); }
.alert-warning { background: var(--bc-warning-soft); border-color: var(--bc-warning); color: var(--bc-ink); }
.alert-danger  { background: var(--bc-danger-soft);  border-color: var(--bc-danger);  color: var(--bc-ink); }

/* ============================================================
   BADGES
   ============================================================ */
.badge {
    font-family: var(--bc-font);
    font-size: var(--bc-fs-xs);
    font-weight: var(--bc-fw-semibold);
    padding: 2px 6px;
    border-radius: var(--bc-radius-xs);
    letter-spacing: .02em;
}

.badge-primary, .badge-info    { background: var(--bc-accent-soft);  color: var(--bc-accent); }
.badge-success                  { background: var(--bc-success-soft); color: var(--bc-success); }
.badge-warning                  { background: var(--bc-warning-soft); color: #8A6900; }
.badge-danger                   { background: var(--bc-danger-soft);  color: var(--bc-danger); }
.badge-secondary, .badge-light  { background: var(--bc-bg-hover);     color: var(--bc-ink-2); }

/* ============================================================
   UTILITIES BC
   ============================================================ */
.bc-bg          { background: var(--bc-bg); }
.bc-bg-alt      { background: var(--bc-bg-alt); }
.bc-bg-hover    { background: var(--bc-bg-hover); }
.bc-border      { border: 1px solid var(--bc-border); }
.bc-border-top  { border-top: 1px solid var(--bc-border); }
.bc-border-bot  { border-bottom: 1px solid var(--bc-border); }
.bc-rounded     { border-radius: var(--bc-radius-md); }
.bc-shadow      { box-shadow: var(--bc-shadow-4); }

.bc-text-ink    { color: var(--bc-ink); }
.bc-text-muted  { color: var(--bc-muted); }
.bc-text-accent { color: var(--bc-accent); }

.bc-stack-2 > * + * { margin-top: 8px; }
.bc-stack-3 > * + * { margin-top: 12px; }
.bc-stack-4 > * + * { margin-top: 16px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    :root { --bc-content-px-lg: 12px; }

    .bc-topbar { padding: 0 8px; }
    .bc-topbar__company { min-width: 120px; margin-right: 8px; }
    .bc-topbar__brand-text { display: none; }
    .bc-topbar__menu .dx-menu-horizontal > .dx-menu-items-container > .dx-menu-item-wrapper > .dx-menu-item {
        padding: 0 8px;
        font-size: var(--bc-fs-sm);
    }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
    .bc-topbar, .footer, .preloader, .modal-backdrop { display: none !important; }
    .page-wrapper { margin: 0 !important; background: #fff !important; }
}
