/* ============================================================================
 * ElectroSoftERP — Design System v1.0
 * Inspirado en Linear / Stripe / Notion / Vercel
 * Sobre ArchitectUI HTML PRO como base estructural.
 * ----------------------------------------------------------------------------
 *  1. Tokens (light + dark)
 *  2. Reset suave + tipografía base
 *  3. Layout shell (header, sidebar, main)
 *  4. Page title + breadcrumbs
 *  5. Cards & superficies
 *  6. KPIs / widget-chart
 *  7. Botones
 *  8. Formularios
 *  9. Tablas
 * 10. Badges, pills, alerts
 * 11. Dropdowns, modales, tabs
 * 12. Microinteracciones (focus, hover, skeletons)
 * 13. Utilities ERP
 * ==========================================================================*/

/* ─── 1. TOKENS ─────────────────────────────────────────────────────────── */
:root {
    /* Tipografía */
    --erp-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI Variable', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --erp-font-mono: 'JetBrains Mono', 'SF Mono', ui-monospace, Menlo, Consolas, monospace;
    --erp-font-display: 'Inter', sans-serif;

    /* Escala tipográfica (modular 1.125 + clamp para responsive) */
    --erp-fs-xs:    clamp(.6875rem, 0.65vw + 0.55rem, .75rem);
    --erp-fs-sm:    clamp(.8125rem, 0.6vw + 0.7rem, .875rem);
    --erp-fs-base:  clamp(.875rem, 0.5vw + 0.78rem, .9375rem);
    --erp-fs-md:    1rem;
    --erp-fs-lg:    1.125rem;
    --erp-fs-xl:    1.3125rem;
    --erp-fs-2xl:   1.625rem;
    --erp-fs-3xl:   2rem;
    --erp-fs-display: clamp(1.75rem, 2vw + 1.25rem, 2.5rem);

    /* Pesos */
    --erp-fw-regular: 400;
    --erp-fw-medium: 500;
    --erp-fw-semibold: 600;
    --erp-fw-bold: 700;

    /* Line height */
    --erp-lh-tight: 1.2;
    --erp-lh-base:  1.5;
    --erp-lh-loose: 1.7;

    /* Spacing scale 4px-based */
    --erp-s-0:  0;
    --erp-s-1:  .25rem;
    --erp-s-2:  .5rem;
    --erp-s-3:  .75rem;
    --erp-s-4:  1rem;
    --erp-s-5:  1.25rem;
    --erp-s-6:  1.5rem;
    --erp-s-8:  2rem;
    --erp-s-10: 2.5rem;
    --erp-s-12: 3rem;

    /* Radii */
    --erp-r-xs:  4px;
    --erp-r-sm:  6px;
    --erp-r-md:  10px;
    --erp-r-lg:  14px;
    --erp-r-xl:  20px;
    --erp-r-full: 9999px;

    /* Brand: Indigo profundo + accent violet */
    --erp-brand-50:  #eef2ff;
    --erp-brand-100: #e0e7ff;
    --erp-brand-200: #c7d2fe;
    --erp-brand-300: #a5b4fc;
    --erp-brand-400: #818cf8;
    --erp-brand-500: #6366f1;
    --erp-brand-600: #4f46e5;
    --erp-brand-700: #4338ca;
    --erp-brand-800: #3730a3;
    --erp-brand-900: #312e81;

    /* Neutros (escala 0-1000, similar a Linear/Vercel) */
    --erp-n-0:    #ffffff;
    --erp-n-25:   #fbfbfc;
    --erp-n-50:   #f6f7f9;
    --erp-n-100:  #eceef2;
    --erp-n-150:  #dfe3ea;
    --erp-n-200:  #d2d7e0;
    --erp-n-300:  #bcc3cf;
    --erp-n-400:  #99a2b1;
    --erp-n-500:  #717b8d;
    --erp-n-600:  #525c6e;
    --erp-n-700:  #3b4253;
    --erp-n-800:  #262b39;
    --erp-n-850:  #1d2230;
    --erp-n-900:  #151926;
    --erp-n-950:  #0d111c;

    /* Semánticos */
    --erp-success-50:  #ecfdf5;
    --erp-success-100: #d1fae5;
    --erp-success-500: #10b981;
    --erp-success-600: #059669;
    --erp-success-700: #047857;

    --erp-warning-50:  #fffbeb;
    --erp-warning-100: #fef3c7;
    --erp-warning-500: #f59e0b;
    --erp-warning-600: #d97706;
    --erp-warning-700: #b45309;

    --erp-danger-50:   #fef2f2;
    --erp-danger-100:  #fee2e2;
    --erp-danger-500:  #ef4444;
    --erp-danger-600:  #dc2626;
    --erp-danger-700:  #b91c1c;

    --erp-info-50:     #eff6ff;
    --erp-info-100:    #dbeafe;
    --erp-info-500:    #3b82f6;
    --erp-info-600:    #2563eb;
    --erp-info-700:    #1d4ed8;

    /* TOKENS SEMÁNTICOS (light theme por defecto) */
    --c-bg-app:        var(--erp-n-50);
    --c-bg-surface:    var(--erp-n-0);
    --c-bg-elevated:   var(--erp-n-0);
    --c-bg-sunken:     var(--erp-n-100);
    --c-bg-hover:      var(--erp-n-100);
    --c-bg-active:     var(--erp-n-150);

    --c-text-strong:   var(--erp-n-900);   /* títulos */
    --c-text-base:     var(--erp-n-800);   /* body */
    --c-text-soft:     var(--erp-n-600);   /* secondary */
    --c-text-muted:    var(--erp-n-500);   /* sutil pero AA 4.5+ */
    --c-text-disabled: var(--erp-n-400);
    --c-text-on-brand: #ffffff;
    --c-text-link:     var(--erp-brand-600);

    --c-border:        var(--erp-n-150);
    --c-border-strong: var(--erp-n-200);
    --c-border-focus:  var(--erp-brand-500);

    --c-brand:         var(--erp-brand-600);
    --c-brand-soft:    var(--erp-brand-50);
    --c-brand-hover:   var(--erp-brand-700);

    --c-success:       var(--erp-success-600);
    --c-success-soft:  var(--erp-success-50);
    --c-warning:       var(--erp-warning-600);
    --c-warning-soft:  var(--erp-warning-50);
    --c-danger:        var(--erp-danger-600);
    --c-danger-soft:   var(--erp-danger-50);
    --c-info:          var(--erp-info-600);
    --c-info-soft:     var(--erp-info-50);

    /* Sidebar (light = dark navy premium siempre, similar a Linear) */
    --c-sidebar-bg:        #0f1322;
    --c-sidebar-bg-active: #1b2138;
    --c-sidebar-bg-hover:  rgba(255,255,255,.05);
    --c-sidebar-text:      #d4d9e6;
    --c-sidebar-text-soft: #8d94a8;
    --c-sidebar-heading:   #6b7388;
    --c-sidebar-active:    #ffffff;
    --c-sidebar-border:    rgba(255,255,255,.06);
    --c-sidebar-accent:    var(--erp-brand-400);

    /* Sombras (micro → macro, suaves) */
    --erp-shadow-xs: 0 1px 2px 0 rgba(15, 23, 42, 0.04);
    --erp-shadow-sm: 0 1px 3px 0 rgba(15, 23, 42, 0.06), 0 1px 2px -1px rgba(15, 23, 42, 0.04);
    --erp-shadow-md: 0 4px 8px -2px rgba(15, 23, 42, 0.08), 0 2px 4px -2px rgba(15, 23, 42, 0.04);
    --erp-shadow-lg: 0 10px 20px -4px rgba(15, 23, 42, 0.10), 0 4px 8px -4px rgba(15, 23, 42, 0.06);
    --erp-shadow-xl: 0 24px 48px -12px rgba(15, 23, 42, 0.18);
    --erp-shadow-card: 0 1px 0 0 rgba(15, 23, 42, 0.04), 0 1px 3px 0 rgba(15, 23, 42, 0.05);
    --erp-shadow-focus: 0 0 0 4px var(--c-brand-soft);
    --erp-shadow-focus-danger: 0 0 0 4px var(--erp-danger-50);

    /* Transiciones */
    --erp-t-fast: 120ms cubic-bezier(.2, 0, 0, 1);
    --erp-t-base: 200ms cubic-bezier(.2, 0, 0, 1);
    --erp-t-slow: 320ms cubic-bezier(.2, 0, 0, 1);

    /* Heights */
    --erp-h-input: 38px;
    --erp-h-input-sm: 32px;
    --erp-h-input-lg: 44px;
    --erp-h-header: 60px;

    /* Z layers */
    --erp-z-sidebar: 30;
    --erp-z-header: 40;
    --erp-z-dropdown: 1050;
    --erp-z-modal: 1060;
    --erp-z-toast: 1080;
}

/* ── Dark mode ── */
[data-theme="dark"] {
    --c-bg-app:        var(--erp-n-950);
    --c-bg-surface:    var(--erp-n-900);
    --c-bg-elevated:   var(--erp-n-850);
    --c-bg-sunken:     var(--erp-n-950);
    --c-bg-hover:      var(--erp-n-800);
    --c-bg-active:     var(--erp-n-700);

    --c-text-strong:   #f4f6fb;
    --c-text-base:     #e2e6ee;
    --c-text-soft:     #a7afbf;
    --c-text-muted:    #8d94a8;
    --c-text-disabled: var(--erp-n-500);

    --c-border:        rgba(255,255,255,.07);
    --c-border-strong: rgba(255,255,255,.13);
    --c-border-focus:  var(--erp-brand-400);

    --c-brand-soft:    rgba(99,102,241,.15);
    --c-success-soft:  rgba(16,185,129,.12);
    --c-warning-soft:  rgba(245,158,11,.12);
    --c-danger-soft:   rgba(239,68,68,.12);
    --c-info-soft:     rgba(59,130,246,.12);

    --c-sidebar-bg:        #0a0d18;
    --c-sidebar-bg-active: #181d2e;

    --erp-shadow-xs: 0 1px 2px 0 rgba(0,0,0,.5);
    --erp-shadow-sm: 0 2px 4px 0 rgba(0,0,0,.4);
    --erp-shadow-md: 0 4px 12px -2px rgba(0,0,0,.5);
    --erp-shadow-lg: 0 10px 24px -6px rgba(0,0,0,.55);
    --erp-shadow-card: 0 0 0 1px rgba(255,255,255,.04), 0 1px 4px rgba(0,0,0,.3);
    --erp-shadow-focus: 0 0 0 4px rgba(99,102,241,.25);
}

/* ─── 2. RESET + TIPOGRAFÍA BASE ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body, .app-container {
    font-family: var(--erp-font-sans) !important;
    font-size: var(--erp-fs-base) !important;
    line-height: var(--erp-lh-base);
    color: var(--c-text-base);
    background: var(--c-bg-app) !important;
    font-feature-settings: "cv02", "cv03", "cv04", "cv11", "ss01";
    letter-spacing: -0.005em;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--c-text-strong);
    font-weight: var(--erp-fw-semibold);
    letter-spacing: -0.015em;
    line-height: var(--erp-lh-tight);
    margin: 0;
}
h1 { font-size: var(--erp-fs-3xl); }
h2 { font-size: var(--erp-fs-2xl); }
h3 { font-size: var(--erp-fs-xl); }
h4 { font-size: var(--erp-fs-lg); }
h5 { font-size: var(--erp-fs-md); }
h6 { font-size: var(--erp-fs-base); }

p { margin: 0 0 var(--erp-s-3); color: var(--c-text-base); }

small, .small { font-size: var(--erp-fs-xs); line-height: 1.45; }

code, kbd, pre, samp {
    font-family: var(--erp-font-mono);
    font-size: .8125em;
    padding: .12em .35em;
    background: var(--c-bg-sunken);
    color: var(--c-text-strong);
    border-radius: var(--erp-r-xs);
    border: 1px solid var(--c-border);
    font-feature-settings: "calt" 0;
}
pre { padding: var(--erp-s-3); }

a { color: var(--c-text-link); text-decoration: none; transition: color var(--erp-t-fast); }
a:hover { color: var(--c-brand-hover); text-decoration: underline; text-underline-offset: 2px; }

hr { border-color: var(--c-border); opacity: 1; }

::selection { background: var(--erp-brand-100); color: var(--erp-brand-900); }
[data-theme="dark"] ::selection { background: var(--erp-brand-700); color: #fff; }

/* Override Bootstrap "muted" para que pase AA */
.text-muted, .opacity-7 { color: var(--c-text-soft) !important; opacity: 1 !important; }
.opacity-5 { color: var(--c-text-muted) !important; opacity: 1 !important; }
.opacity-10 { opacity: 1 !important; }
.text-secondary { color: var(--c-text-soft) !important; }

/* Forzar contraste mínimo en textos pequeños comunes */
small.text-muted, .widget-content small { color: var(--c-text-soft) !important; }
small { color: inherit; }

/* ─── 3. LAYOUT SHELL ───────────────────────────────────────────────────── */

/* HEADER */
.app-header.header-shadow {
    background: var(--c-bg-surface) !important;
    border-bottom: 1px solid var(--c-border) !important;
    box-shadow: var(--erp-shadow-xs) !important;
    height: var(--erp-h-header);
    color: var(--c-text-base);
    backdrop-filter: saturate(180%) blur(8px);
}
.app-header__logo {
    background: var(--c-sidebar-bg) !important;
    width: 280px !important;
    transition: width var(--erp-t-base);
}
.closed-sidebar .app-header__logo { width: 70px !important; }
.app-header__logo .logo-src {
    background-image: url('architectui/images/logo-inverse.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: left center;
    width: 100%; height: 30px;
    margin-left: 4px;
    filter: brightness(1.05);
}

.app-header .search-wrapper .search-input {
    background: var(--c-bg-sunken);
    border: 1px solid transparent;
    color: var(--c-text-base);
    height: var(--erp-h-input);
    padding: 0 var(--erp-s-4) 0 var(--erp-s-4);
    border-radius: var(--erp-r-md);
    font-size: var(--erp-fs-sm);
    width: 280px;
    transition: all var(--erp-t-fast);
}
.app-header .search-wrapper .search-input::placeholder { color: var(--c-text-muted); }
.app-header .search-wrapper .search-input:focus {
    outline: none;
    background: var(--c-bg-surface);
    border-color: var(--c-border-focus);
    box-shadow: var(--erp-shadow-focus);
    width: 360px;
}

.header-btn-lg .widget-heading { color: var(--c-text-strong); font-weight: var(--erp-fw-semibold); font-size: var(--erp-fs-sm); }
.header-btn-lg .widget-subheading { color: var(--c-text-muted); font-size: var(--erp-fs-xs); }

/* SIDEBAR — Premium dark navy */
.app-sidebar.sidebar-shadow {
    background: var(--c-sidebar-bg) !important;
    border-right: 1px solid var(--c-sidebar-border) !important;
    box-shadow: none !important;
    width: 280px !important;
    transition: width var(--erp-t-base);
}
.closed-sidebar .app-sidebar { width: 70px !important; }
.app-main__outer { padding-left: 280px; transition: padding-left var(--erp-t-base); }
.closed-sidebar .app-main__outer { padding-left: 70px; }

.scrollbar-sidebar {
    background: transparent !important;
    padding: var(--erp-s-2) 0;
}

.vertical-nav-menu { padding: 0; }

/* Headings (Dashboard / Inventario / etc.) */
.app-sidebar__heading {
    text-transform: uppercase !important;
    font-size: 10.5px !important;
    font-weight: var(--erp-fw-semibold) !important;
    letter-spacing: .085em !important;
    color: var(--c-sidebar-heading) !important;
    padding: var(--erp-s-4) var(--erp-s-5) var(--erp-s-2) !important;
    margin: 0 !important;
    border: 0 !important;
}
.app-sidebar__heading::before { display: none !important; }

/* Items */
.vertical-nav-menu li > a {
    display: flex !important;
    align-items: center;
    gap: var(--erp-s-3);
    padding: var(--erp-s-2) var(--erp-s-5) !important;
    margin: 2px var(--erp-s-3) !important;
    border-radius: var(--erp-r-md) !important;
    color: var(--c-sidebar-text) !important;
    font-size: var(--erp-fs-sm) !important;
    font-weight: var(--erp-fw-medium);
    line-height: 1.35;
    transition: background var(--erp-t-fast), color var(--erp-t-fast), transform var(--erp-t-fast);
    position: relative;
    border: 0 !important;
}
.vertical-nav-menu li > a:hover {
    background: var(--c-sidebar-bg-hover) !important;
    color: #ffffff !important;
    text-decoration: none;
}
.vertical-nav-menu li > a.mm-active,
.vertical-nav-menu li.mm-active > a,
.vertical-nav-menu li > a.active {
    background: var(--c-sidebar-bg-active) !important;
    color: var(--c-sidebar-active) !important;
    font-weight: var(--erp-fw-semibold);
}
.vertical-nav-menu li > a.mm-active::before,
.vertical-nav-menu li.mm-active > a::before,
.vertical-nav-menu li > a.active::before {
    content: '';
    position: absolute;
    left: -10px; top: 8px; bottom: 8px;
    width: 3px;
    background: var(--c-sidebar-accent);
    border-radius: 0 3px 3px 0;
}

.vertical-nav-menu i.metismenu-icon {
    font-size: 17px !important;
    color: var(--c-sidebar-text-soft) !important;
    opacity: 1 !important;
    width: 22px;
    height: 22px;
    text-align: center;
    line-height: 22px;
    transition: color var(--erp-t-fast);
    flex-shrink: 0;
    position: static !important;
    margin: 0 !important;
}
.vertical-nav-menu li > a:hover i.metismenu-icon,
.vertical-nav-menu li > a.mm-active i.metismenu-icon { color: var(--c-sidebar-accent) !important; }

/* Items deshabilitados (futuras fases) */
.vertical-nav-menu li > a.text-muted { color: rgba(255,255,255,.35) !important; }
.vertical-nav-menu li > a.text-muted:hover { background: transparent !important; cursor: not-allowed; }
.vertical-nav-menu .badge.rounded-pill {
    margin-left: auto;
    font-size: 9px;
    padding: 2px 7px;
    font-weight: var(--erp-fw-semibold);
    letter-spacing: .03em;
    text-transform: uppercase;
}

/* Cuando sidebar está cerrado, ocultar labels */
.closed-sidebar .vertical-nav-menu li > a > *:not(.metismenu-icon) { display: none; }
.closed-sidebar .app-sidebar__heading { font-size: 0 !important; padding: var(--erp-s-2) 0 !important; }

/* MAIN */
.app-main__inner {
    background: var(--c-bg-app) !important;
    padding: var(--erp-s-6) var(--erp-s-6) var(--erp-s-8) !important;
}
@media (max-width: 768px) { .app-main__inner { padding: var(--erp-s-4); } }

.app-footer {
    background: var(--c-bg-surface) !important;
    border-top: 1px solid var(--c-border);
    box-shadow: none !important;
}
.app-footer .nav-link { color: var(--c-text-soft) !important; font-size: var(--erp-fs-xs); }

/* ─── 4. PAGE TITLE + BREADCRUMB ────────────────────────────────────────── */
.app-page-title, .app-page-title.app-page-title-simple {
    background: transparent !important;
    padding: 0 0 var(--erp-s-5) !important;
    margin: 0 0 var(--erp-s-5) !important;
    border-bottom: 1px solid var(--c-border);
}
.page-title-head {
    color: var(--c-text-strong);
    font-size: var(--erp-fs-2xl);
    font-weight: var(--erp-fw-bold);
    letter-spacing: -0.025em;
    margin: 0 0 var(--erp-s-2);
    display: flex;
    align-items: center;
    gap: var(--erp-s-2);
}
.page-title-head i {
    color: var(--c-brand) !important;
    background: none !important;
    -webkit-background-clip: initial !important;
    -webkit-text-fill-color: initial !important;
    font-size: 28px;
    opacity: 1 !important;
}
.page-title-subheading { padding-top: var(--erp-s-1); }
.page-title-subheading .breadcrumb {
    margin: 0; padding: 0;
    background: transparent;
    font-size: var(--erp-fs-xs);
}
.breadcrumb-item { color: var(--c-text-muted); }
.breadcrumb-item a { color: var(--c-text-soft); font-weight: var(--erp-fw-medium); }
.breadcrumb-item a:hover { color: var(--c-brand); text-decoration: none; }
.breadcrumb-item.active { color: var(--c-text-strong); font-weight: var(--erp-fw-semibold); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--c-text-muted); content: '/'; padding: 0 var(--erp-s-1); }

.page-title-actions .btn { box-shadow: var(--erp-shadow-sm); }

/* ─── 5. CARDS & SUPERFICIES ────────────────────────────────────────────── */
.card, .main-card.card {
    background: var(--c-bg-surface) !important;
    border: 1px solid var(--c-border) !important;
    border-radius: var(--erp-r-lg) !important;
    box-shadow: var(--erp-shadow-card) !important;
    color: var(--c-text-base);
    margin-bottom: var(--erp-s-5);
    transition: box-shadow var(--erp-t-base), border-color var(--erp-t-base);
}
.card:hover { box-shadow: var(--erp-shadow-sm) !important; }

.card-header, .card-header-tab.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--c-border) !important;
    padding: var(--erp-s-4) var(--erp-s-5) !important;
}
.card-header-title {
    color: var(--c-text-strong) !important;
    font-size: var(--erp-fs-md) !important;
    font-weight: var(--erp-fw-semibold) !important;
    letter-spacing: -0.01em;
    text-transform: none !important;
    display: flex;
    align-items: center;
    gap: var(--erp-s-2);
}
.card-header-title .header-icon {
    font-size: 18px;
    background: var(--c-brand-soft) !important;
    color: var(--c-brand) !important;
    -webkit-background-clip: initial !important;
    -webkit-text-fill-color: initial !important;
    width: 32px;
    height: 32px;
    border-radius: var(--erp-r-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 1 !important;
}
.card-body { padding: var(--erp-s-5) !important; color: var(--c-text-base); }
.card-footer { background: transparent !important; border-top: 1px solid var(--c-border) !important; padding: var(--erp-s-3) var(--erp-s-5) !important; }

/* ─── 6. KPI / WIDGET-CHART ─────────────────────────────────────────────── */
.widget-chart, .widget-chart.widget-chart2 {
    background: var(--c-bg-surface) !important;
    border: 1px solid var(--c-border) !important;
    border-radius: var(--erp-r-lg) !important;
    box-shadow: var(--erp-shadow-card) !important;
    padding: var(--erp-s-5) !important;
    margin-bottom: var(--erp-s-5);
    transition: transform var(--erp-t-base), box-shadow var(--erp-t-base);
    position: relative;
    overflow: hidden;
}
.widget-chart:hover {
    transform: translateY(-2px);
    box-shadow: var(--erp-shadow-md) !important;
}
.widget-chart::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--c-brand), var(--erp-brand-400));
}
.widget-chart.card-shadow-success::before { background: linear-gradient(90deg, var(--erp-success-500), var(--erp-success-700)); }
.widget-chart.card-shadow-warning::before { background: linear-gradient(90deg, var(--erp-warning-500), var(--erp-warning-700)); }
.widget-chart.card-shadow-danger::before  { background: linear-gradient(90deg, var(--erp-danger-500),  var(--erp-danger-700)); }
.widget-chart.card-shadow-info::before    { background: linear-gradient(90deg, var(--erp-info-500),    var(--erp-info-700)); }
.widget-chart.card-shadow-secondary::before { background: linear-gradient(90deg, var(--erp-n-300), var(--erp-n-500)); }

.widget-chart .widget-title {
    color: var(--c-text-soft) !important;
    text-transform: uppercase;
    font-size: 11px !important;
    font-weight: var(--erp-fw-semibold);
    letter-spacing: .08em;
    opacity: 1 !important;
    margin-bottom: var(--erp-s-2) !important;
}
.widget-chart .widget-numbers {
    color: var(--c-text-strong) !important;
    font-size: var(--erp-fs-2xl) !important;
    font-weight: var(--erp-fw-bold);
    letter-spacing: -0.025em;
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
.widget-chart .widget-numbers .text-success { color: var(--c-success) !important; }
.widget-chart .widget-numbers .text-danger  { color: var(--c-danger)  !important; }
.widget-chart .widget-numbers small { font-weight: var(--erp-fw-regular); color: var(--c-text-soft); margin-left: var(--erp-s-1); font-size: var(--erp-fs-xs); }
.widget-chart .widget-numbers i { font-size: 16px; }

/* Reemplazar gradientes ArchitectUI legacy en KPI */
.widget-chart .widget-numbers span.opacity-10 { opacity: 1 !important; }

/* ─── 7. BOTONES ────────────────────────────────────────────────────────── */
.btn {
    font-family: var(--erp-font-sans) !important;
    font-weight: var(--erp-fw-medium) !important;
    font-size: var(--erp-fs-sm) !important;
    border-radius: var(--erp-r-md) !important;
    padding: .5rem var(--erp-s-4) !important;
    transition: all var(--erp-t-fast) !important;
    letter-spacing: -0.005em;
    border-width: 1px !important;
    box-shadow: var(--erp-shadow-xs);
    display: inline-flex !important;
    align-items: center;
    gap: var(--erp-s-2);
    line-height: 1.4;
}
.btn:focus, .btn:focus-visible {
    outline: none;
    box-shadow: var(--erp-shadow-focus) !important;
}
.btn:active { transform: translateY(1px); }
.btn-lg { padding: .6875rem var(--erp-s-5) !important; font-size: var(--erp-fs-base) !important; }
.btn-sm { padding: .3125rem var(--erp-s-3) !important; font-size: var(--erp-fs-xs) !important; }
.btn-icon, .btn.btn-icon { padding: .375rem var(--erp-s-2) !important; }

.btn-primary {
    background: var(--c-brand) !important;
    border-color: var(--c-brand) !important;
    color: #fff !important;
}
.btn-primary:hover { background: var(--c-brand-hover) !important; border-color: var(--c-brand-hover) !important; box-shadow: var(--erp-shadow-sm); }

.btn-success { background: var(--c-success) !important; border-color: var(--c-success) !important; color: #fff !important; }
.btn-success:hover { background: var(--erp-success-700) !important; border-color: var(--erp-success-700) !important; }
.btn-warning { background: var(--c-warning) !important; border-color: var(--c-warning) !important; color: #fff !important; }
.btn-danger  { background: var(--c-danger) !important; border-color: var(--c-danger) !important; color: #fff !important; }
.btn-info    { background: var(--c-info) !important; border-color: var(--c-info) !important; color: #fff !important; }
.btn-secondary { background: var(--erp-n-200) !important; border-color: var(--erp-n-200) !important; color: var(--c-text-strong) !important; }
.btn-light, .btn-outline-light {
    background: var(--c-bg-surface) !important;
    border-color: var(--c-border-strong) !important;
    color: var(--c-text-base) !important;
}
.btn-light:hover { background: var(--c-bg-hover) !important; border-color: var(--c-border-strong) !important; }

.btn-outline-primary { background: transparent !important; border-color: var(--c-brand) !important; color: var(--c-brand) !important; }
.btn-outline-primary:hover { background: var(--c-brand) !important; color: #fff !important; }
.btn-outline-secondary { border-color: var(--c-border-strong) !important; color: var(--c-text-base) !important; background: transparent !important; }
.btn-outline-secondary:hover { background: var(--c-bg-hover) !important; }
.btn-outline-danger  { border-color: var(--c-danger) !important; color: var(--c-danger) !important; background: transparent !important; }
.btn-outline-danger:hover  { background: var(--c-danger) !important; color: #fff !important; }
.btn-outline-info    { border-color: var(--c-info) !important; color: var(--c-info) !important; background: transparent !important; }
.btn-outline-info:hover { background: var(--c-info) !important; color: #fff !important; }
.btn-outline-success { border-color: var(--c-success) !important; color: var(--c-success) !important; background: transparent !important; }
.btn-outline-success:hover { background: var(--c-success) !important; color: #fff !important; }
.btn-outline-warning { border-color: var(--c-warning) !important; color: var(--c-warning) !important; background: transparent !important; }
.btn-outline-warning:hover { background: var(--c-warning) !important; color: #fff !important; }

.btn-link { color: var(--c-text-link) !important; box-shadow: none !important; padding-left: var(--erp-s-2) !important; padding-right: var(--erp-s-2) !important; }
.btn-link:hover { color: var(--c-brand-hover) !important; text-decoration: underline; }

/* ─── 8. FORMULARIOS ────────────────────────────────────────────────────── */
.form-control, .form-select {
    background: var(--c-bg-surface) !important;
    border: 1px solid var(--c-border-strong) !important;
    color: var(--c-text-base) !important;
    border-radius: var(--erp-r-md) !important;
    padding: .5rem var(--erp-s-3) !important;
    font-size: var(--erp-fs-sm) !important;
    font-family: var(--erp-font-sans) !important;
    height: var(--erp-h-input);
    transition: border-color var(--erp-t-fast), box-shadow var(--erp-t-fast), background var(--erp-t-fast);
    box-shadow: var(--erp-shadow-xs);
    line-height: 1.4;
}
.form-control-sm, .form-select-sm { height: var(--erp-h-input-sm); padding: .25rem var(--erp-s-2) !important; font-size: var(--erp-fs-xs) !important; }
.form-control-lg, .form-select-lg { height: var(--erp-h-input-lg); padding: .625rem var(--erp-s-4) !important; }
.form-control::placeholder { color: var(--c-text-muted); }
.form-control:hover, .form-select:hover { border-color: var(--c-border-strong); }
.form-control:focus, .form-select:focus {
    outline: none;
    border-color: var(--c-border-focus) !important;
    box-shadow: var(--erp-shadow-focus) !important;
    background: var(--c-bg-surface) !important;
}
.form-control:disabled, .form-control[readonly], .form-select:disabled {
    background: var(--c-bg-sunken) !important;
    color: var(--c-text-soft) !important;
    cursor: not-allowed;
}
.form-control.is-invalid { border-color: var(--c-danger) !important; }
.form-control.is-invalid:focus { box-shadow: var(--erp-shadow-focus-danger) !important; }
.form-control.is-valid    { border-color: var(--c-success) !important; }

textarea.form-control { height: auto; min-height: 84px; line-height: 1.55; }

.form-label {
    color: var(--c-text-strong) !important;
    font-size: var(--erp-fs-sm) !important;
    font-weight: var(--erp-fw-semibold);
    margin-bottom: var(--erp-s-1);
    letter-spacing: -0.005em;
}

.form-check-input {
    border: 1px solid var(--c-border-strong);
    background-color: var(--c-bg-surface);
    width: 1.05em; height: 1.05em;
    margin-top: .22em;
    transition: all var(--erp-t-fast);
}
.form-check-input:checked { background-color: var(--c-brand); border-color: var(--c-brand); }
.form-check-input:focus { box-shadow: var(--erp-shadow-focus); border-color: var(--c-brand); }
.form-check-label { color: var(--c-text-base); font-size: var(--erp-fs-sm); padding-left: var(--erp-s-1); }
.form-check { padding-left: 1.6rem; }

.form-switch .form-check-input {
    width: 2.25em; height: 1.25em; margin-left: -1.85em;
    background-color: var(--c-border-strong);
    background-image: linear-gradient(45deg, transparent, transparent);
}
.form-switch .form-check-input:checked { background-color: var(--c-brand); }
.form-switch .form-check-input:not(:checked) {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}

.input-group .input-group-text {
    background: var(--c-bg-sunken) !important;
    border: 1px solid var(--c-border-strong) !important;
    color: var(--c-text-soft) !important;
    font-size: var(--erp-fs-sm);
    padding: 0 var(--erp-s-3);
}
.input-group .input-group-text i { color: var(--c-text-soft); }

/* ─── 9. TABLAS ─────────────────────────────────────────────────────────── */
.table {
    color: var(--c-text-base) !important;
    margin-bottom: 0 !important;
    --bs-table-bg: transparent !important;
}
.table thead th {
    background: var(--c-bg-sunken) !important;
    color: var(--c-text-soft) !important;
    border-bottom: 1px solid var(--c-border) !important;
    border-top: 0 !important;
    font-weight: var(--erp-fw-semibold) !important;
    text-transform: uppercase;
    font-size: 10.5px !important;
    letter-spacing: .07em;
    padding: var(--erp-s-3) var(--erp-s-4) !important;
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: 2;
}
.table tbody td {
    color: var(--c-text-base) !important;
    padding: var(--erp-s-3) var(--erp-s-4) !important;
    border-top: 1px solid var(--c-border) !important;
    border-bottom: 0 !important;
    vertical-align: middle;
    font-size: var(--erp-fs-sm);
}
.table tbody tr { transition: background var(--erp-t-fast); }
.table-hover tbody tr:hover, .table-hover > tbody > tr:hover > * {
    background: var(--c-bg-hover) !important;
    color: var(--c-text-strong) !important;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
    --bs-table-striped-bg: var(--c-bg-sunken);
    color: var(--c-text-base) !important;
}
.table tfoot td {
    background: var(--c-bg-sunken) !important;
    color: var(--c-text-strong) !important;
    font-weight: var(--erp-fw-semibold);
    border-top: 1px solid var(--c-border) !important;
}
.table tfoot tr.table-primary td {
    background: var(--c-brand-soft) !important;
    color: var(--c-brand-hover) !important;
}
.table tfoot tr.table-light td  { background: var(--c-bg-sunken) !important; }

.table-responsive { border-radius: var(--erp-r-lg); }
.card .table-responsive { border-radius: 0 0 var(--erp-r-lg) var(--erp-r-lg); }

/* erp-empty placeholder */
.erp-empty, td.erp-empty {
    color: var(--c-text-muted) !important;
    text-align: center;
    padding: var(--erp-s-8) var(--erp-s-4) !important;
    font-size: var(--erp-fs-sm);
}
.erp-empty i { font-size: 2.5rem; color: var(--erp-n-300); display: block; margin-bottom: var(--erp-s-2); }

/* Paginación */
.pagination .page-link {
    color: var(--c-text-base);
    background: var(--c-bg-surface);
    border: 1px solid var(--c-border);
    font-size: var(--erp-fs-sm);
    padding: .3125rem var(--erp-s-3);
    transition: all var(--erp-t-fast);
}
.pagination .page-link:hover { background: var(--c-bg-hover); color: var(--c-brand); border-color: var(--c-border-strong); }
.pagination .page-item.active .page-link {
    background: var(--c-brand);
    border-color: var(--c-brand);
    color: #fff;
}

/* ─── 10. BADGES, PILLS, ALERTS ─────────────────────────────────────────── */
.badge {
    font-family: var(--erp-font-sans);
    font-weight: var(--erp-fw-semibold) !important;
    font-size: 11px !important;
    padding: .28em .55em !important;
    border-radius: var(--erp-r-sm) !important;
    letter-spacing: .02em;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    line-height: 1.35;
}
.badge.rounded-pill { border-radius: var(--erp-r-full) !important; padding: .25em .65em !important; }
.badge.bg-primary   { background: var(--c-brand-soft) !important;    color: var(--c-brand-hover) !important;   box-shadow: inset 0 0 0 1px var(--erp-brand-200); }
.badge.bg-success   { background: var(--c-success-soft) !important;  color: var(--erp-success-700) !important; box-shadow: inset 0 0 0 1px var(--erp-success-100); }
.badge.bg-warning   { background: var(--c-warning-soft) !important;  color: var(--erp-warning-700) !important; box-shadow: inset 0 0 0 1px var(--erp-warning-100); }
.badge.bg-danger    { background: var(--c-danger-soft) !important;   color: var(--erp-danger-700) !important;  box-shadow: inset 0 0 0 1px var(--erp-danger-100); }
.badge.bg-info      { background: var(--c-info-soft) !important;     color: var(--erp-info-700) !important;    box-shadow: inset 0 0 0 1px var(--erp-info-100); }
.badge.bg-secondary { background: var(--erp-n-100) !important;       color: var(--erp-n-700) !important;        box-shadow: inset 0 0 0 1px var(--erp-n-150); }

[data-theme="dark"] .badge.bg-primary   { color: var(--erp-brand-200) !important; box-shadow: inset 0 0 0 1px rgba(99,102,241,.2); }
[data-theme="dark"] .badge.bg-success   { color: #6ee7b7 !important; box-shadow: inset 0 0 0 1px rgba(16,185,129,.2); }
[data-theme="dark"] .badge.bg-warning   { color: #fcd34d !important; box-shadow: inset 0 0 0 1px rgba(245,158,11,.2); }
[data-theme="dark"] .badge.bg-danger    { color: #fca5a5 !important; box-shadow: inset 0 0 0 1px rgba(239,68,68,.2); }
[data-theme="dark"] .badge.bg-info      { color: #93c5fd !important; box-shadow: inset 0 0 0 1px rgba(59,130,246,.2); }
[data-theme="dark"] .badge.bg-secondary { background: var(--erp-n-700) !important; color: var(--erp-n-100) !important; }

/* erp-pill legacy */
.erp-pill { padding: .18em .55em; border-radius: var(--erp-r-sm); font-size: 11px; font-weight: var(--erp-fw-semibold); display: inline-flex; align-items: center; gap: 4px; }
.erp-pill-on   { background: var(--c-success-soft); color: var(--erp-success-700); }
.erp-pill-off  { background: var(--c-danger-soft);  color: var(--erp-danger-700); }
.erp-pill-info { background: var(--c-info-soft);    color: var(--erp-info-700); }

/* Alerts */
.alert {
    border-radius: var(--erp-r-md);
    border: 1px solid;
    padding: var(--erp-s-3) var(--erp-s-4);
    font-size: var(--erp-fs-sm);
    display: flex;
    align-items: flex-start;
    gap: var(--erp-s-2);
}
.alert-success { background: var(--c-success-soft) !important; border-color: var(--erp-success-100) !important; color: var(--erp-success-700) !important; }
.alert-warning { background: var(--c-warning-soft) !important; border-color: var(--erp-warning-100) !important; color: var(--erp-warning-700) !important; }
.alert-danger  { background: var(--c-danger-soft) !important;  border-color: var(--erp-danger-100) !important;  color: var(--erp-danger-700) !important; }
.alert-info    { background: var(--c-info-soft) !important;    border-color: var(--erp-info-100) !important;    color: var(--erp-info-700) !important; }
.alert i { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.alert .btn-close { padding: var(--erp-s-2); margin-left: auto; }

/* ─── 11. DROPDOWNS, MODALES, TABS, ICON WRAPPERS ───────────────────────── */
.dropdown-menu {
    background: var(--c-bg-elevated) !important;
    border: 1px solid var(--c-border) !important;
    box-shadow: var(--erp-shadow-lg) !important;
    border-radius: var(--erp-r-md) !important;
    padding: var(--erp-s-1) 0;
    color: var(--c-text-base) !important;
    z-index: var(--erp-z-dropdown);
}
.dropdown-item {
    color: var(--c-text-base) !important;
    font-size: var(--erp-fs-sm);
    padding: var(--erp-s-2) var(--erp-s-4) !important;
    display: flex;
    align-items: center;
    gap: var(--erp-s-2);
    transition: background var(--erp-t-fast);
}
.dropdown-item:hover { background: var(--c-bg-hover) !important; color: var(--c-text-strong) !important; }
.dropdown-item i.dropdown-icon { font-size: 16px; width: 18px; }
.dropdown-header { color: var(--c-text-soft); font-size: var(--erp-fs-xs); text-transform: uppercase; font-weight: var(--erp-fw-semibold); letter-spacing: .04em; padding: var(--erp-s-2) var(--erp-s-4) var(--erp-s-1); }
.dropdown-divider { border-top: 1px solid var(--c-border); margin: var(--erp-s-1) 0; }

/* Header dropdown icon wrappers */
.header-dots .icon-wrapper {
    width: 38px; height: 38px; border-radius: var(--erp-r-md);
    background: var(--c-bg-sunken) !important;
    transition: background var(--erp-t-fast);
}
.header-dots .icon-wrapper .icon-wrapper-bg { display: none; }
.header-dots .icon-wrapper .icon {
    color: var(--c-brand) !important;
    font-size: 18px;
}
.header-dots .btn:hover .icon-wrapper { background: var(--c-brand-soft) !important; }

.dropdown-menu-xl { min-width: 360px; padding: 0 !important; overflow: hidden; }
.dropdown-menu-header {
    padding: 0 !important;
    border-bottom: 1px solid var(--c-border);
}
.dropdown-menu-header-inner { padding: var(--erp-s-5) var(--erp-s-5); position: relative; }
.menu-header-image { opacity: .22 !important; }
.menu-header-title { color: #fff; font-weight: var(--erp-fw-semibold); font-size: var(--erp-fs-md); margin: 0; }
.menu-header-subtitle { color: rgba(255,255,255,.8); font-size: var(--erp-fs-xs); }

.grid-menu .btn-icon-vertical {
    border: 0 !important;
    color: var(--c-text-base) !important;
    padding: var(--erp-s-4);
    font-size: var(--erp-fs-xs);
    font-weight: var(--erp-fw-medium);
    border-right: 1px solid var(--c-border);
    border-bottom: 1px solid var(--c-border);
    transition: background var(--erp-t-fast);
}
.grid-menu .btn-icon-vertical:hover { background: var(--c-bg-hover) !important; color: var(--c-text-strong) !important; }
.grid-menu .btn-icon-vertical i { font-size: 28px !important; margin-bottom: var(--erp-s-2) !important; }

/* Modales */
.modal-content {
    background: var(--c-bg-elevated) !important;
    border: 1px solid var(--c-border) !important;
    border-radius: var(--erp-r-lg) !important;
    box-shadow: var(--erp-shadow-xl) !important;
    color: var(--c-text-base);
}
.modal-header { border-bottom: 1px solid var(--c-border); padding: var(--erp-s-4) var(--erp-s-5); }
.modal-title { color: var(--c-text-strong); font-weight: var(--erp-fw-semibold); font-size: var(--erp-fs-lg); }
.modal-body  { padding: var(--erp-s-5); }
.modal-footer { border-top: 1px solid var(--c-border); padding: var(--erp-s-3) var(--erp-s-5); }

/* Tabs / pills */
.nav-pills .nav-link {
    color: var(--c-text-soft) !important;
    font-size: var(--erp-fs-sm);
    font-weight: var(--erp-fw-medium);
    padding: var(--erp-s-2) var(--erp-s-4) !important;
    border-radius: var(--erp-r-md) !important;
    transition: all var(--erp-t-fast);
    display: inline-flex; align-items: center; gap: var(--erp-s-2);
}
.nav-pills .nav-link:hover { background: var(--c-bg-hover); color: var(--c-text-strong) !important; }
.nav-pills .nav-link.active {
    background: var(--c-brand-soft) !important;
    color: var(--c-brand-hover) !important;
    font-weight: var(--erp-fw-semibold);
}

/* List group flush */
.list-group-flush .list-group-item {
    background: transparent;
    border-color: var(--c-border) !important;
    color: var(--c-text-base);
    padding: var(--erp-s-3) var(--erp-s-5);
}
.list-group-item.text-muted { color: var(--c-text-muted) !important; }

/* Widget content (header user + activity) */
.widget-content .widget-heading { color: var(--c-text-strong); font-weight: var(--erp-fw-semibold); font-size: var(--erp-fs-sm); }
.widget-content .widget-subheading { color: var(--c-text-muted); font-size: var(--erp-fs-xs); }

.icon-wrapper.icon-wrapper-alt { width: 34px; height: 34px; }
.icon-wrapper.icon-wrapper-alt .icon-wrapper-bg { display: none; }
.icon-wrapper.icon-wrapper-alt .icon {
    font-size: 16px;
    color: var(--c-brand) !important;
    background: var(--c-brand-soft);
    width: 34px; height: 34px; border-radius: var(--erp-r-md);
    display: inline-flex; align-items: center; justify-content: center;
}
.icon-wrapper.icon-wrapper-alt .icon.text-primary { background: var(--c-brand-soft); color: var(--c-brand) !important; }
.icon-wrapper.icon-wrapper-alt .icon.text-success { background: var(--c-success-soft); color: var(--c-success) !important; }
.icon-wrapper.icon-wrapper-alt .icon.text-warning { background: var(--c-warning-soft); color: var(--c-warning) !important; }
.icon-wrapper.icon-wrapper-alt .icon.text-danger  { background: var(--c-danger-soft);  color: var(--c-danger) !important; }
.icon-wrapper.icon-wrapper-alt .icon.text-info    { background: var(--c-info-soft);    color: var(--c-info) !important; }

/* Reemplazar "icon-gradient bg-*" en headers (mantener color, no gradiente raro) */
.icon-gradient { -webkit-background-clip: initial !important; -webkit-text-fill-color: initial !important; background: none !important; }
.icon-gradient.bg-mean-fruit  { color: var(--c-brand) !important; }
.icon-gradient.bg-night-fade  { color: var(--c-info) !important; }
.icon-gradient.bg-warm-flame  { color: var(--c-warning) !important; }
.icon-gradient.bg-grow-early  { color: var(--c-success) !important; }
.icon-gradient.bg-arielle-smile { color: #06b6d4 !important; }
.icon-gradient.bg-sunny-morning { color: var(--c-warning) !important; }
.icon-gradient.bg-plum-plate  { color: #8b5cf6 !important; }
.icon-gradient.bg-premium-dark { color: var(--c-text-strong) !important; }

/* Hamburgers menu */
.hamburger .hamburger-inner,
.hamburger .hamburger-inner::before,
.hamburger .hamburger-inner::after {
    background: var(--c-text-base) !important;
}
.app-header__logo .hamburger .hamburger-inner,
.app-header__logo .hamburger .hamburger-inner::before,
.app-header__logo .hamburger .hamburger-inner::after { background: #ffffff !important; }

/* ─── 12. MICROINTERACCIONES, FOCUS, SKELETONS ──────────────────────────── */
*:focus-visible {
    outline: 2px solid var(--c-border-focus);
    outline-offset: 2px;
    border-radius: var(--erp-r-xs);
}
.btn:focus-visible, .form-control:focus-visible, .form-select:focus-visible,
.form-check-input:focus-visible, .nav-link:focus-visible, a:focus-visible {
    outline: none;
    box-shadow: var(--erp-shadow-focus);
}

@keyframes erpFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.card, .widget-chart, .app-page-title { animation: erpFadeIn 280ms cubic-bezier(.2,0,0,1) both; }

@keyframes erpShimmer { 0% { background-position: -400px 0; } 100% { background-position: 400px 0; } }
.erp-skeleton {
    display: inline-block;
    height: 1em;
    width: 100%;
    border-radius: var(--erp-r-sm);
    background: linear-gradient(90deg, var(--c-bg-sunken) 0%, var(--c-bg-hover) 40%, var(--c-bg-sunken) 80%);
    background-size: 800px 100%;
    animation: erpShimmer 1.4s linear infinite;
    color: transparent;
}
.erp-skeleton-circle { border-radius: 50%; height: 2.5em; width: 2.5em; }

/* Progress bars */
.progress { background: var(--c-bg-sunken); height: 8px; border-radius: var(--erp-r-full); overflow: hidden; }
.progress-bar { background: var(--c-brand); border-radius: var(--erp-r-full); transition: width var(--erp-t-slow); }

/* Scrollbars (WebKit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--c-border-strong); border-radius: var(--erp-r-full); border: 2px solid var(--c-bg-app); }
::-webkit-scrollbar-thumb:hover { background: var(--c-text-muted); }

/* Sidebar interno: scroll fino */
.scrollbar-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border: 2px solid transparent; }

/* ─── 13. UTILITIES ERP ─────────────────────────────────────────────────── */
.tabular-nums { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.text-strong { color: var(--c-text-strong) !important; }
.text-soft   { color: var(--c-text-soft) !important; }
.fw-semibold { font-weight: var(--erp-fw-semibold) !important; }

/* Override colores legacy de utilities Bootstrap heredados */
.text-primary { color: var(--c-brand) !important; }
.text-success { color: var(--c-success) !important; }
.text-warning { color: var(--c-warning) !important; }
.text-danger  { color: var(--c-danger) !important; }
.text-info    { color: var(--c-info) !important; }
.bg-light     { background: var(--c-bg-sunken) !important; }
.bg-primary   { background: var(--c-brand) !important; }

/* Iconos pe-7s coloreados utility shortcuts */
.pe-7s-search.text-primary, .pe-7s-info.text-info { font-size: 16px; }

/* "icon-gradient bg-mean-fruit" usado en page-title-head — el lh-anterior */
.page-title-head .icon-gradient { font-size: 26px; }

/* Mobile open-sidebar overlay */
@media (max-width: 991.98px) {
    .app-sidebar { transform: translateX(-100%); transition: transform var(--erp-t-base); }
    .sidebar-mobile-open .app-sidebar { transform: translateX(0); box-shadow: var(--erp-shadow-xl) !important; }
    .app-main__outer { padding-left: 0 !important; }
    .app-header__logo { width: 100% !important; max-width: 200px; }
}

/* Footer del card que contiene tabla */
.card > .table-responsive:last-child { border-bottom-left-radius: var(--erp-r-lg); border-bottom-right-radius: var(--erp-r-lg); }
.card > .table-responsive table { border-radius: 0; }

/* Login page overlay */
body.erp-login-page {
    background: radial-gradient(circle at 20% 20%, #4f46e5 0%, #312e81 40%, #1e1b4b 100%) !important;
    min-height: 100vh;
}
.erp-login-card {
    background: var(--c-bg-elevated);
    border-radius: var(--erp-r-xl);
    box-shadow: var(--erp-shadow-xl);
    border: 1px solid var(--c-border);
    max-width: 440px;
    margin: 8vh auto;
    padding: var(--erp-s-8);
    color: var(--c-text-base);
}

/* Card body sin padding sobre tablas */
.card-body.p-0 + .table-responsive { border-radius: 0 0 var(--erp-r-lg) var(--erp-r-lg); }
.main-card.card .card-body.p-0 { padding: 0 !important; }
.main-card.card > .table-responsive { padding: 0; }
