:root{--brand-primary:#064e3b;--brand-secondary:#1d4ed8;--brand-accent:#22c55e;--bg-main:#071020;--bg-panel:#101827;--border:#243247;--text-main:#e5edf7;--text-muted:#9badc4;--sidebar-width:292px;--sidebar-collapsed:82px;--topbar-height:72px}*{scrollbar-width:thin;scrollbar-color:#64748b #101827}body{margin:0;background:radial-gradient(circle at 35% 5%,rgba(20,184,166,.14),transparent 28%),radial-gradient(circle at 80% 0%,rgba(59,130,246,.12),transparent 24%),linear-gradient(135deg,#071020,#09111e 55%,#08111f);color:var(--text-main);font-size:14px;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.23;background-image:linear-gradient(135deg,transparent 0 45%,rgba(34,197,94,.18) 46%,transparent 47% 100%),linear-gradient(45deg,transparent 0 52%,rgba(59,130,246,.15) 53%,transparent 54% 100%);background-size:680px 680px,820px 820px;background-position:-120px 80px,480px -40px}.layout{min-height:100vh;position:relative;z-index:1}.topbar{height:var(--topbar-height);position:fixed;top:0;left:0;right:0;z-index:40;background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary));border-bottom:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;box-shadow:0 12px 28px rgba(0,0,0,.22)}.sidebar{width:var(--sidebar-width);background:#0f172a;border-right:1px solid var(--border);position:fixed;top:var(--topbar-height);bottom:0;left:0;padding:1.15rem .9rem;overflow-y:auto;transition:width .22s ease,padding .22s ease;z-index:35}.main{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);min-height:100vh;transition:margin-left .22s ease}.content{padding:1.7rem 1.35rem 2.5rem}body.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed);padding:.9rem .55rem;overflow-x:hidden}body.sidebar-collapsed .main{margin-left:var(--sidebar-collapsed)}body.sidebar-collapsed .menu-header{justify-content:center}body.sidebar-collapsed .menu-header>div:last-child,body.sidebar-collapsed .nav-section,body.sidebar-collapsed .sidebar a span{display:none}body.sidebar-collapsed .sidebar a{justify-content:center;padding:.75rem .35rem}body.sidebar-collapsed .sidebar a i{width:auto;font-size:1.08rem}.brand-top{display:flex;align-items:center;gap:.85rem}.sidebar-toggle,.icon-btn{width:42px;height:42px;border:1px solid rgba(255,255,255,.7);border-radius:12px;background:rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.sidebar-toggle:hover,.icon-btn:hover{background:rgba(255,255,255,.16)}.brand-logo{width:45px;height:45px;border-radius:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.26);display:flex;align-items:center;justify-content:center;overflow:hidden;font-weight:900;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.brand-logo img{width:100%;height:100%;object-fit:contain;background:#fff;padding:6px}.brand-title{font-weight:900;color:#fff;line-height:1}.brand-subtitle{font-size:.72rem;color:#d8f3e6}.top-actions{display:flex;align-items:center;gap:.7rem}.company-filter{display:flex;align-items:center;gap:.35rem;color:#e2e8f0;font-size:.8rem}.company-filter select{max-width:220px;border:0;border-radius:999px;background:#fff;color:#0f172a;font-weight:800}.user-pill{border:0;border-radius:999px;background:#fff;color:#0f172a;font-weight:800;padding:.42rem .8rem}.report-btn{border-radius:999px;background:#fff;color:#0f172a;font-weight:900;border:0;padding:.47rem 1rem;text-decoration:none}.mfa-badge{border-radius:999px;padding:.42rem .75rem;font-weight:800;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.1);color:#e5edf7;text-decoration:none}.mfa-badge.ok{background:rgba(34,197,94,.18);color:#dcfce7}.mfa-badge.warn{background:rgba(245,158,11,.18);color:#fef3c7}.menu-header{display:flex;align-items:center;gap:.75rem;margin:1rem .2rem 1.1rem}.menu-icon{width:52px;height:52px;border-radius:16px;background:#eef5ff;color:#2563eb;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.menu-title{font-weight:900;color:#f8fafc}.menu-sub{font-size:.78rem;color:var(--text-muted)}.nav-section{font-size:.73rem;letter-spacing:.11em;color:#94a3b8;text-transform:uppercase;margin:1.1rem .65rem .45rem;font-weight:900}.sidebar a{color:#d6e4f6;text-decoration:none;display:flex;align-items:center;gap:.75rem;padding:.68rem .72rem;border-radius:.78rem;margin:.12rem 0;font-weight:800;white-space:nowrap}.sidebar a i{color:#38bdf8;width:18px;text-align:center}.sidebar a:hover,.sidebar a.active{background:linear-gradient(90deg,rgba(20,184,166,.7),rgba(37,99,235,.55));color:#fff}.sidebar a:hover i,.sidebar a.active i{color:#fff}.card-kpi,.table-card,.panel-card{background:rgba(16,24,39,.92);border:1px solid var(--border);border-radius:1.1rem;box-shadow:0 18px 45px rgba(0,0,0,.16);color:var(--text-main)}.kpi-label,.text-muted,.muted,.form-text{color:var(--text-muted)!important}.kpi-value{font-weight:900;font-size:2rem;color:#fff}.btn{border-radius:.72rem;font-weight:800}.btn-primary{background:#1677ff;border-color:#1677ff}.btn-success{background:#16a34a;border-color:#16a34a}.table{--bs-table-bg:transparent;--bs-table-color:var(--text-main);--bs-table-border-color:var(--border);margin-bottom:0}.table thead th,.table tbody th{font-size:.74rem;text-transform:uppercase;color:#b8c7da;background:#0d1423;font-weight:900;letter-spacing:.04em}.table td,.table th{vertical-align:middle;padding:.95rem .85rem}.form-control,.form-select{border-radius:.75rem;background:#111c2f;border:1px solid #334155;color:#e5edf7}.form-control:focus,.form-select:focus{background:#101827;color:#fff;border-color:#1f7aff;box-shadow:0 0 0 .2rem rgba(31,122,255,.15)}.form-label{color:#dbeafe}.page-title h1,.page-title h2,h1,h2,h3,h4,h5{color:#f8fafc}.auth-shell{min-height:100vh;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-shell .content{width:100%;max-width:540px;padding:0}.dropdown-menu{border-radius:.9rem;background:#0f172a;border:1px solid var(--border)}.dropdown-item{color:#e5edf7}.dropdown-item:hover{background:#1e293b;color:#fff}.bi-svg-ready svg{width:1.1em;height:1.1em;vertical-align:-.15em;display:inline-block}.alert{transition:opacity .25s ease,transform .25s ease}.brand-logo .fallback-logo{width:100%;height:100%;object-fit:contain;background:#fff;padding:7px}.sidebar-collapsed .brand-logo{width:44px;height:44px}.sidebar-collapsed .brand-subtitle{display:none}@media(max-width:991px){.topbar{position:relative;height:auto;min-height:72px;flex-wrap:wrap;gap:.75rem;padding:.75rem}.sidebar{position:fixed;top:0;left:-310px;height:100vh;width:292px;z-index:60}.main{margin-left:0;padding-top:0}.content{padding:1rem}.top-actions{flex-wrap:wrap}.company-filter select{max-width:100%}body.sidebar-mobile-open .sidebar{left:0}body.sidebar-collapsed .main{margin-left:0}body.sidebar-collapsed .sidebar{width:292px;padding:1.15rem .9rem}body.sidebar-collapsed .menu-header>div:last-child,body.sidebar-collapsed .nav-section,body.sidebar-collapsed .sidebar a span{display:block}body.sidebar-collapsed .sidebar a{justify-content:flex-start;padding:.68rem .72rem}}

/* v7 polish: icon cleanup, SaaS spacing, traceability components */
i.bi{display:inline-flex;align-items:center;justify-content:center;line-height:1;min-width:1.1em}
i.bi::before{display:none!important;content:""!important}
.sidebar a i svg,.topbar i svg,.btn i svg,h1 i svg,h2 i svg,h3 i svg,.badge i svg{width:1.08em;height:1.08em}
.brand-top{min-width:0}.brand-logo img{display:block}.brand-title{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.page-toolbar{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}.table-card{overflow:hidden}.table-responsive{border-radius:1.1rem}
.badge-soft{background:rgba(96,165,250,.15);border:1px solid rgba(96,165,250,.25);color:#bfdbfe}
.badge-status{border-radius:999px;padding:.38rem .62rem;font-weight:900;font-size:.72rem;letter-spacing:.02em}
.badge-status.sent,.badge-status.completed,.badge-status.processed,.badge-status.validated,.badge-status.read,.badge-status.delivered{background:rgba(34,197,94,.16);color:#bbf7d0;border:1px solid rgba(34,197,94,.28)}
.badge-status.failed,.badge-status.cancelled,.badge-status.invalid{background:rgba(239,68,68,.16);color:#fecaca;border:1px solid rgba(239,68,68,.28)}
.badge-status.pending,.badge-status.ready,.badge-status.uploaded,.badge-status.scheduled{background:rgba(245,158,11,.17);color:#fde68a;border:1px solid rgba(245,158,11,.28)}
.badge-status.processing{background:rgba(59,130,246,.17);color:#bfdbfe;border:1px solid rgba(59,130,246,.3)}
.kpi-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(20,184,166,.2),rgba(37,99,235,.22));border:1px solid rgba(148,163,184,.18);color:#67e8f9}
.card-kpi{position:relative;overflow:hidden}.card-kpi:after{content:"";position:absolute;right:-40px;top:-45px;width:120px;height:120px;background:rgba(59,130,246,.08);border-radius:999px}
.trace-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.trace-item{background:rgba(15,23,42,.72);border:1px solid var(--border);border-radius:1rem;padding:1rem}
.trace-title{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:#9badc4;font-weight:900}.trace-value{font-size:1.55rem;font-weight:950;color:#fff}
.section-title{display:flex;align-items:center;gap:.55rem;font-weight:950}.table-actions{white-space:nowrap}
.json-preview{max-width:360px;max-height:75px;overflow:auto;white-space:pre-wrap;font-size:.72rem;color:#cbd5e1;background:rgba(15,23,42,.75);border:1px solid rgba(148,163,184,.15);border-radius:.6rem;padding:.5rem}
.search-panel{background:rgba(16,24,39,.86);border:1px solid var(--border);border-radius:1rem;padding:1rem;margin-bottom:1rem}.header-icon{font-size:1.7rem;color:#e0f2fe}.admin-shell-note{font-size:.78rem;color:#9badc4}
@media(max-width:1199px){.trace-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.top-actions .report-btn,.top-actions .mfa-badge{padding:.42rem .65rem}}
@media(max-width:767px){.trace-grid{grid-template-columns:1fr}.brand-subtitle{display:none}.company-filter i,.report-btn i,.mfa-badge i{display:none}.user-pill{max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}

/* v8 enterprise UI: light/dark, branding, form polish, MFA layout */
:root[data-theme="dark"]{
  --page-bg:#071020;--surface:#101827;--surface-2:#0f172a;--surface-soft:rgba(16,24,39,.92);
  --text-main:#e8eef8;--text-muted:#9fb0c7;--border:#26364d;--input-bg:#111c2f;--input-border:#334155;
  --topbar-text:#fff;--shadow:0 18px 45px rgba(0,0,0,.18);--table-head:#0d1423;
}
:root[data-theme="light"]{
  --page-bg:#f4f7fb;--surface:#ffffff;--surface-2:#eef3f9;--surface-soft:rgba(255,255,255,.96);
  --text-main:#0f172a;--text-muted:#5b6b80;--border:#d9e2ef;--input-bg:#ffffff;--input-border:#c7d2e3;
  --topbar-text:#ffffff;--shadow:0 16px 38px rgba(15,23,42,.09);--table-head:#f1f5f9;
}
body{background:var(--page-bg)!important;color:var(--text-main)!important;font-size:14px;letter-spacing:.01em}
:root[data-theme="light"] body:before{opacity:.12;background-image:linear-gradient(135deg,transparent 0 45%,rgba(37,99,235,.20) 46%,transparent 47% 100%),linear-gradient(45deg,transparent 0 52%,rgba(20,184,166,.18) 53%,transparent 54% 100%)}
.topbar{background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary))!important;min-height:72px;height:72px;padding:.65rem 1rem}
.brand-logo{background:rgba(255,255,255,.18)!important}.brand-logo img{background:#fff!important;padding:6px;border-radius:12px}.brand-title{font-size:1rem}.brand-subtitle{font-size:.73rem;color:rgba(255,255,255,.78)}
.icon-btn{width:auto;min-width:44px;padding:0 .78rem;gap:.35rem}.theme-label{font-size:.78rem;font-weight:800}
.sidebar{background:var(--surface)!important;border-right:1px solid var(--border)!important;box-shadow:8px 0 30px rgba(0,0,0,.08)}
.sidebar a{color:var(--text-main)!important}.sidebar a i{color:#38bdf8}.sidebar a:hover,.sidebar a.active{background:linear-gradient(90deg,rgba(20,184,166,.84),rgba(37,99,235,.72))!important;color:#fff!important}.sidebar a:hover i,.sidebar a.active i{color:#fff!important}.nav-section{color:var(--text-muted)}
.menu-icon{background:linear-gradient(135deg,rgba(59,130,246,.16),rgba(20,184,166,.12));color:#38bdf8;border:1px solid var(--border)}.menu-title,.page-title h1,.page-title h2,h1,h2,h3,h4,h5{color:var(--text-main)!important}.menu-sub{color:var(--text-muted)!important}
.main{background:transparent}.content{max-width:1680px;margin:0 auto;width:100%;padding:1.85rem 1.45rem 2.8rem}
.card-kpi,.table-card,.panel-card,.search-panel,.trace-item{background:var(--surface-soft)!important;border:1px solid var(--border)!important;color:var(--text-main)!important;box-shadow:var(--shadow)!important}.kpi-value,.trace-value{color:var(--text-main)!important}.kpi-label,.text-muted,.muted,.form-text{color:var(--text-muted)!important}
.table{--bs-table-color:var(--text-main)!important;--bs-table-border-color:var(--border)!important}.table thead th,.table tbody th{background:var(--table-head)!important;color:var(--text-muted)!important}.table td{color:var(--text-main)!important}
.form-control,.form-select,textarea.form-control{background:var(--input-bg)!important;border:1px solid var(--input-border)!important;color:var(--text-main)!important;border-radius:.8rem!important;min-height:42px}.form-control:focus,.form-select:focus{border-color:var(--brand-secondary)!important;box-shadow:0 0 0 .2rem rgba(37,99,235,.16)!important;color:var(--text-main)!important}.form-label{color:var(--text-main)!important;margin-bottom:.45rem}.form-check{padding-top:.55rem}.form-check-input{min-height:auto!important}.helptext,ul.errorlist{color:var(--text-muted)}
.panel-card form .row.g-3{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.05rem 1.35rem!important}.panel-card form .row.g-3>[class*="col-"]{width:100%;max-width:100%}.panel-card form p{margin-bottom:1rem}.panel-card form p label{display:block;font-weight:800;margin-bottom:.42rem;color:var(--text-main)}.panel-card form p input,.panel-card form p select,.panel-card form p textarea{width:100%}.panel-card form ul{margin:.45rem 0 0;color:var(--text-muted);font-size:.84rem}.btn{border-radius:.8rem!important;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.btn-primary{background:var(--brand-secondary)!important;border-color:var(--brand-secondary)!important}.btn-outline-secondary{color:var(--text-main)!important;border-color:var(--border)!important}
.qr-box{background:#fff;border-radius:1rem;padding:1rem;display:inline-flex;box-shadow:0 20px 40px rgba(0,0,0,.18);max-width:340px;width:100%;align-items:center;justify-content:center}.qr-box img{width:100%;height:auto;max-width:300px;display:block}.mfa-panel{display:grid;grid-template-columns:minmax(260px,360px) 1fr;gap:2rem;align-items:start}.mfa-steps{background:rgba(59,130,246,.08);border:1px solid var(--border);border-radius:1rem;padding:1rem;color:var(--text-main)}.secret-box{background:var(--input-bg);border:1px solid var(--input-border);border-radius:.9rem;padding:.85rem 1rem;word-break:break-all;color:var(--text-main)}
.company-card{transition:transform .18s ease,box-shadow .18s ease}.company-card:hover{transform:translateY(-2px)}.company-logo-preview{width:58px;height:58px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;font-weight:950}.company-logo-preview img{width:100%;height:100%;object-fit:contain;padding:6px}.color-dot{width:12px;height:12px;border-radius:99px;display:inline-block;margin-right:.35rem}
.dropdown-menu{background:var(--surface)!important;border:1px solid var(--border)!important}.dropdown-item{color:var(--text-main)!important}.dropdown-item:hover{background:var(--surface-2)!important}.user-pill,.report-btn,.company-filter select{box-shadow:0 4px 12px rgba(0,0,0,.10)}
@media(max-width:1100px){.panel-card form .row.g-3{grid-template-columns:1fr!important}.mfa-panel{grid-template-columns:1fr}.qr-box{max-width:300px}.content{padding:1.1rem}}
@media(max-width:767px){.topbar{height:auto}.theme-label{display:none}.top-actions{gap:.45rem}.panel-card{padding:1rem!important}}

/* v9 UI refinement: uniform typography, cleaner header, no header report/MFA, polished forms */
:root{
  --font-sans: Inter, "Segoe UI", Roboto, Arial, sans-serif;
  --fs-xs:.75rem; --fs-sm:.825rem; --fs-md:.925rem; --fs-lg:1.1rem; --fs-xl:1.55rem;
  --radius-sm:.65rem; --radius-md:.9rem; --radius-lg:1.15rem;
}
html,body{font-family:var(--font-sans)!important;font-size:14px!important;line-height:1.45!important;font-weight:500!important}
h1,.h1{font-size:1.8rem!important;line-height:1.15!important;font-weight:850!important;letter-spacing:-.025em!important}
h2,.h2{font-size:1.45rem!important;line-height:1.2!important;font-weight:820!important;letter-spacing:-.018em!important}
h3,.h3{font-size:1.25rem!important;font-weight:800!important;letter-spacing:-.01em!important}
h4,.h4,h5,.h5{font-weight:780!important}.text-muted,.muted,.form-text{font-size:var(--fs-sm)!important}.small,small{font-size:var(--fs-xs)!important}
.topbar{height:68px!important;min-height:68px!important;padding:.55rem 1.1rem!important}.brand-top{gap:.75rem!important}.brand-logo{width:42px!important;height:42px!important;border-radius:13px!important;flex:0 0 42px!important}.brand-logo img{width:100%!important;height:100%!important;object-fit:contain!important;padding:6px!important}.brand-title{font-size:.94rem!important;font-weight:850!important;letter-spacing:-.01em!important}.brand-subtitle{font-size:.7rem!important;font-weight:600!important;opacity:.88!important}.sidebar-toggle{width:42px!important;height:42px!important;border-radius:12px!important}.top-actions{gap:.65rem!important}.mfa-badge,.report-btn,#themeToggle{display:none!important}.company-filter{gap:.45rem!important}.company-filter i{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.9)}.company-filter select{height:36px!important;min-height:36px!important;min-width:160px!important;max-width:240px!important;padding:.35rem 2rem .35rem .75rem!important;font-size:var(--fs-sm)!important;font-weight:800!important}.user-pill{height:38px!important;max-width:330px!important;display:inline-flex!important;align-items:center!important;gap:.35rem!important;padding:.38rem .85rem!important;font-size:var(--fs-sm)!important;line-height:1!important}.user-pill span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-menu.user-menu{min-width:280px!important;padding:.5rem!important;border-radius:1rem!important;box-shadow:0 18px 45px rgba(0,0,0,.24)!important}.dropdown-header{color:var(--text-muted)!important;font-weight:850!important;font-size:.72rem!important;text-transform:uppercase!important;letter-spacing:.08em!important}.dropdown-item{border-radius:.72rem!important;padding:.62rem .75rem!important;font-size:var(--fs-sm)!important;font-weight:720!important;display:flex!important;align-items:center!important;gap:.15rem!important}.dropdown-item i{width:18px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important}
.sidebar{top:68px!important}.main{padding-top:68px!important}.sidebar a{min-height:42px!important;border-radius:.85rem!important;font-size:var(--fs-sm)!important;font-weight:800!important;margin:.18rem 0!important}.sidebar a i{width:18px!important;height:18px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;margin-right:.6rem!important}.sidebar a i svg,.topbar i svg,.dropdown-item i svg,.btn i svg{width:1em!important;height:1em!important;display:block!important}.nav-section{font-size:.72rem!important;font-weight:900!important;letter-spacing:.1em!important;margin:1.05rem .45rem .45rem!important}.menu-header{margin-bottom:.9rem!important}.menu-icon{width:44px!important;height:44px!important;border-radius:14px!important}.menu-title{font-size:.88rem!important;font-weight:850!important}.menu-sub{font-size:.76rem!important}.content{padding:1.55rem 1.45rem 2.5rem!important}.panel-card,.table-card,.search-panel,.trace-item,.card-kpi{border-radius:1.05rem!important}.table{font-size:var(--fs-sm)!important}.table thead th{font-size:.72rem!important;font-weight:900!important;letter-spacing:.055em!important;text-transform:uppercase!important;padding:.9rem .85rem!important}.table td{padding:.85rem!important;vertical-align:middle!important}.btn{font-size:var(--fs-sm)!important;font-weight:820!important;border-radius:.8rem!important;min-height:38px!important;padding:.48rem .85rem!important}.btn-sm{min-height:32px!important;padding:.32rem .65rem!important;font-size:.78rem!important}.badge,.badge-status{font-size:.72rem!important;font-weight:850!important;border-radius:.6rem!important;padding:.35rem .5rem!important}.form-label{font-size:var(--fs-sm)!important;font-weight:800!important;margin-bottom:.38rem!important}.form-control,.form-select,textarea.form-control{min-height:42px!important;font-size:var(--fs-sm)!important;font-weight:600!important;border-radius:.78rem!important;padding:.55rem .72rem!important}textarea.form-control{min-height:104px!important}.panel-card form .row.g-3{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:1rem 1.15rem!important;align-items:start!important}.panel-card form .row.g-3 .col-md-6{width:100%!important;max-width:100%!important}.panel-card form .row.g-3 .col-md-6:has(textarea),.panel-card form .row.g-3 .col-md-6:has(input[type="file"]),.panel-card form .row.g-3 .col-md-6:has(.helptext){grid-column:span 1}.panel-card form .form-text,.panel-card form ul{margin-top:.45rem!important;line-height:1.45!important}.panel-card form ul{padding-left:1.15rem!important}.auth-shell .content{max-width:520px!important}.mfa-panel{grid-template-columns:minmax(280px,360px) minmax(0,1fr)!important;gap:2.25rem!important;align-items:start!important}.qr-box{max-width:320px!important;padding:1rem!important;border-radius:1rem!important}.qr-box img{max-width:288px!important}.mfa-steps{font-size:var(--fs-sm)!important;line-height:1.5!important}.secret-box{font-size:var(--fs-sm)!important;line-height:1.5!important}.company-logo-preview{width:62px!important;height:62px!important;border-radius:17px!important;background:#fff!important}.company-card .fw-bold{font-size:1rem!important}.kpi-label,.trace-title{font-size:.74rem!important}.kpi-value,.trace-value{font-size:1.8rem!important;letter-spacing:-.03em!important}
:root[data-theme="light"] .topbar{box-shadow:0 10px 28px rgba(15,23,42,.12)!important}:root[data-theme="light"] body{background:#f5f8fc!important}:root[data-theme="light"] body:before{opacity:.08!important}:root[data-theme="light"] .sidebar{background:#fff!important}:root[data-theme="light"] .panel-card,:root[data-theme="light"] .table-card,:root[data-theme="light"] .search-panel,:root[data-theme="light"] .trace-item,:root[data-theme="light"] .card-kpi{box-shadow:0 12px 32px rgba(15,23,42,.07)!important}.bi-svg-ready{font-size:1em!important;line-height:1!important}.bi-svg-ready:before{content:none!important}
@media(max-width:1250px){.panel-card form .row.g-3{grid-template-columns:repeat(2,minmax(0,1fr))!important}.company-filter select{max-width:180px!important}.user-pill{max-width:260px!important}}
@media(max-width:900px){.panel-card form .row.g-3,.mfa-panel{grid-template-columns:1fr!important}.topbar{padding:.5rem .75rem!important}.company-filter{display:none!important}.brand-subtitle{display:none!important}.user-pill{max-width:180px!important}.content{padding:1rem!important}}

/* v10 hardening: secure MFA gate, cleaner logos, reports/actions and profile permissions */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.page-title{font-size:1.75rem!important;line-height:1.15!important;font-weight:850!important;margin:0 0 .25rem!important;letter-spacing:-.025em!important;display:flex;align-items:center;gap:.55rem}.page-subtitle{color:var(--text-muted);font-size:.92rem;font-weight:560}.header-icon{color:#38bdf8;font-size:1.15em}.page-toolbar{display:flex;gap:.55rem;flex-wrap:wrap}.logo-frame{background:#fff!important;overflow:hidden!important}.brand-logo img{display:block!important;width:100%!important;height:100%!important;object-fit:contain!important;padding:7px!important}.fallback-logo{filter:none!important}.company-logo-preview{width:64px!important;height:64px!important;min-width:64px!important;border-radius:18px!important;background:#fff!important;border:1px solid rgba(148,163,184,.28)!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;color:#1d4ed8!important;font-weight:900!important;font-size:1rem!important}.company-logo-preview img{width:100%!important;height:100%!important;object-fit:contain!important;padding:9px!important;display:block!important}.company-logo-preview span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#1d4ed8}.security-gate-wrap{min-height:calc(100vh - 3rem);display:flex;align-items:center;justify-content:center;padding:1rem}.security-gate-card{width:min(1120px,100%);border:1px solid var(--border);background:rgba(16,24,39,.94);border-radius:1.2rem;padding:1.5rem;box-shadow:0 22px 60px rgba(0,0,0,.28)}.security-gate-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}.mfa-panel.clean{display:grid!important;grid-template-columns:minmax(260px,340px) minmax(0,1fr)!important;gap:2rem!important;align-items:start!important}.mfa-qr-col{min-width:0}.mfa-info-col{min-width:0}.qr-box{background:#fff!important;border-radius:1rem!important;padding:1rem!important;max-width:320px!important;margin:0 auto!important;box-shadow:0 12px 28px rgba(0,0,0,.18)}.qr-box img{width:100%!important;max-width:288px!important;height:auto!important;display:block!important;margin:auto!important}.secret-box{background:rgba(15,23,42,.74);border:1px solid var(--border);border-radius:.85rem;padding:.7rem .85rem;word-break:break-all;color:var(--text-main)}.totp-uri{display:inline-block;max-width:100%;word-break:break-all;color:inherit!important}.report-actions-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.85rem}.report-action{display:flex;flex-direction:column;gap:.35rem;padding:1rem;border:1px solid var(--border);border-radius:1rem;background:rgba(16,24,39,.84);color:var(--text-main);text-decoration:none;min-height:128px;transition:.18s ease}.report-action:hover{transform:translateY(-2px);border-color:#38bdf8;color:var(--text-main);box-shadow:0 14px 32px rgba(0,0,0,.18)}.report-action i{font-size:1.35rem;color:#38bdf8}.report-action span{font-weight:850}.report-action small{color:var(--text-muted);line-height:1.35}.report-action.featured{background:linear-gradient(135deg,rgba(29,78,216,.78),rgba(14,165,233,.42));border-color:rgba(125,211,252,.55)}.table-actions{white-space:nowrap}.auth-shell{min-height:100vh;background:radial-gradient(circle at 35% 5%,rgba(20,184,166,.14),transparent 28%),radial-gradient(circle at 80% 0%,rgba(59,130,246,.12),transparent 24%),linear-gradient(135deg,#071020,#09111e 55%,#08111f)}.auth-shell .content{max-width:none!important;width:100%!important}.auth-shell .alert{max-width:900px;margin:0 auto 1rem}.panel-card form{max-width:100%}.form-control,.form-select{background-color:rgba(15,23,42,.82)!important;color:var(--text-main)!important;border-color:var(--border)!important}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .2rem rgba(59,130,246,.18)!important;border-color:#38bdf8!important}.form-control::placeholder{color:var(--text-muted)!important}.helptext,form ul{color:var(--text-muted)!important}.dropdown-menu{background:var(--bg-panel)!important;border-color:var(--border)!important}.dropdown-item{color:var(--text-main)!important}.dropdown-item:hover{background:rgba(59,130,246,.14)!important}:root[data-theme="light"] .security-gate-card,:root[data-theme="light"] .report-action{background:#fff!important}:root[data-theme="light"] .secret-box,:root[data-theme="light"] .form-control,:root[data-theme="light"] .form-select{background:#fff!important;color:#0f172a!important}:root[data-theme="light"] .dropdown-menu{background:#fff!important}:root[data-theme="light"] .dropdown-item{color:#0f172a!important}
@media(max-width:1200px){.report-actions-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.mfa-panel.clean{grid-template-columns:1fr!important}.security-gate-head{flex-direction:column}.report-actions-grid{grid-template-columns:1fr}.page-head{align-items:stretch}.page-toolbar{width:100%}.page-toolbar .btn{flex:1}}

/* v12 SaaS security and layout refinements */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background:var(--app-bg);}
.auth-centered{width:100%;display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px);}
.auth-card{width:100%;max-width:440px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:22px;padding:34px;box-shadow:0 24px 70px rgba(0,0,0,.18);}
.auth-card.compact{max-width:430px;}
.auth-icon{width:74px;height:74px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;background:var(--brand-primary);color:#fff;font-size:30px;}
.auth-title{font-size:1.55rem;font-weight:800;line-height:1.15;margin:0 0 6px;color:var(--text-strong);}
.auth-subtitle{font-size:.93rem;color:var(--text-muted);}
.auth-card .form-control,.auth-card input{height:46px;border-radius:12px;text-align:left;}
.auth-card .btn{height:44px;border-radius:12px;font-weight:700;}
.security-note{border:1px solid var(--border-color);border-radius:10px;padding:12px;font-size:.82rem;color:var(--text-muted);background:var(--muted-bg);}
.mfa-card{width:100%;max-width:950px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:22px;padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.18);}
.mfa-card-wide{max-width:980px;}
.mfa-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;}
.mfa-setup-grid{display:grid;grid-template-columns:minmax(260px,330px) 1fr;gap:30px;align-items:start;}
.qr-box.clean{background:#fff;border-radius:18px;padding:18px;display:flex;align-items:center;justify-content:center;max-width:320px;margin:0 auto;}
.qr-box.clean img{width:100%;height:auto;display:block;}
.info-box{background:var(--muted-bg);border:1px solid var(--border-color);border-radius:16px;padding:16px;color:var(--text-normal);}
.secret-box{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:var(--input-bg);border:1px solid var(--border-color);border-radius:12px;padding:12px;color:var(--text-strong);word-break:break-all;}
.totp-uri{white-space:normal;word-break:break-all;color:var(--text-muted);}
.form-label{font-size:.84rem;font-weight:700;color:var(--text-normal);margin-bottom:7px;}
.form-text,.muted{color:var(--text-muted)!important;}
.panel-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:18px;padding:20px;box-shadow:0 18px 48px rgba(0,0,0,.10);}
.template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.template-chip{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:12px;padding:12px 14px;color:var(--text-normal);text-decoration:none;background:var(--input-bg);font-weight:600;font-size:.9rem;}
.template-chip:hover{border-color:var(--brand-secondary);color:var(--brand-secondary);}
.permissions-card{overflow:hidden;}
.permissions-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);}
.permissions-table td{vertical-align:middle;padding:14px 16px;}
.permissions-table .module-row td{background:var(--muted-bg);font-weight:800;color:var(--text-strong);font-size:.92rem;border-top:1px solid var(--border-color);}
.permission-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.72rem;color:#e83e8c;margin-top:3px;}
.card-footer-actions{border-top:1px solid var(--border-color);padding:16px;display:flex;justify-content:flex-end;background:var(--card-bg);}
.header-icon{font-size:1.35rem;color:var(--brand-secondary);vertical-align:-.1em;}
.page-title{font-size:1.65rem;font-weight:800;line-height:1.15;color:var(--text-strong);}
.page-subtitle{font-size:.93rem;color:var(--text-muted);margin-top:5px;}
.table-card .table{--bs-table-bg:transparent;--bs-table-color:var(--text-normal);--bs-table-border-color:var(--border-color);}
.table-card thead th{font-size:.73rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:800;}
.logo-frame img{width:38px;height:38px;object-fit:contain;display:block;}
.brand-logo{overflow:hidden;}
@media (max-width: 900px){.mfa-setup-grid{grid-template-columns:1fr}.template-grid{grid-template-columns:1fr}.mfa-header-row{flex-direction:column}.auth-shell{padding:18px}.mfa-card,.auth-card{padding:22px}}
/* v12 variable compatibility */
:root[data-theme="dark"]{--app-bg:var(--page-bg);--card-bg:var(--surface-soft);--border-color:var(--border);--text-strong:var(--text-main);--text-normal:var(--text-main);--muted-bg:rgba(15,23,42,.72)}
:root[data-theme="light"]{--app-bg:var(--page-bg);--card-bg:#ffffff;--border-color:var(--border);--text-strong:#0f172a;--text-normal:#243044;--muted-bg:#f3f6fa}
:root[data-theme="light"] .auth-card,:root[data-theme="light"] .mfa-card,:root[data-theme="light"] .panel-card,:root[data-theme="light"] .permissions-table .module-row td,:root[data-theme="light"] .card-footer-actions{background:#fff!important;color:#0f172a!important}
:root[data-theme="light"] .auth-shell{background:#f4f7fb!important}
:root[data-theme="light"] .auth-icon{background:#006b3f!important}
:root[data-theme="light"] .form-control,:root[data-theme="light"] .form-select,:root[data-theme="light"] .secret-box,:root[data-theme="light"] .template-chip{background:#fff!important;color:#0f172a!important;border-color:#c7d2e3!important}
:root[data-theme="light"] .info-box,:root[data-theme="light"] .security-note{background:#f8fafc!important;color:#334155!important}

/* v13 final security, MFA and SaaS polish */
html,body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;font-size:14px!important;line-height:1.45!important}.auth-shell{min-height:100vh!important;display:grid!important;place-items:center!important;padding:24px!important}.auth-shell .content{width:100%!important;max-width:980px!important}.auth-centered{min-height:auto!important;width:100%!important}.auth-card.compact{max-width:430px!important;margin:auto!important;padding:30px 28px!important;border-radius:22px!important}.auth-icon{width:72px!important;height:72px!important;font-size:1.55rem!important}.auth-title{font-size:1.45rem!important;font-weight:850!important;letter-spacing:-.02em!important}.auth-subtitle{font-size:.92rem!important}.auth-card .form-control{width:100%!important;height:46px!important;text-align:left!important}.auth-card .btn{height:44px!important}.mfa-card{max-width:980px!important;margin:auto!important;border-radius:22px!important;padding:30px!important}.mfa-setup-grid{display:grid!important;grid-template-columns:minmax(270px,340px) minmax(0,1fr)!important;gap:32px!important;align-items:start!important}.mfa-header-row{align-items:flex-start!important}.qr-box.clean{max-width:330px!important;background:#fff!important;border-radius:18px!important;padding:18px!important}.qr-box.clean img{width:100%!important;max-width:294px!important;height:auto!important}.secret-box{font-size:.82rem!important;line-height:1.45!important}.form-grid,.panel-card form{width:100%!important}.panel-card form p,.panel-card form .mb-3{margin-bottom:1rem!important}.panel-card form input,.panel-card form select,.panel-card form textarea{width:100%!important}.page-title{font-size:1.5rem!important;letter-spacing:-.025em!important}.page-subtitle{font-size:.9rem!important}.brand-title{font-size:.92rem!important}.brand-subtitle{font-size:.72rem!important}.brand-logo{width:42px!important;height:42px!important;border-radius:13px!important}.brand-logo img{width:100%!important;height:100%!important;object-fit:contain!important;background:#fff!important;padding:6px!important}.company-logo-preview img{object-fit:contain!important}.topbar{height:68px!important}.top-actions .report-btn,.top-actions .mfa-badge{display:none!important}.company-filter select{height:34px!important;font-size:.82rem!important}.user-pill{height:36px!important;font-size:.82rem!important;padding:.35rem .75rem!important}.sidebar{top:68px!important}.main{padding-top:68px!important}.sidebar a i{margin-right:0!important}.sidebar a{gap:.72rem!important}.template-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))!important}.permissions-table input[type="checkbox"]{width:16px;height:16px}.permissions-table .module-row td{font-size:.86rem!important}.report-actions-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important}.security-note{font-size:.8rem!important}.badge-status.pending{background:rgba(245,158,11,.18)!important;color:#facc15!important;border:1px solid rgba(245,158,11,.25)!important}.badge-status.active{background:rgba(34,197,94,.18)!important;color:#22c55e!important;border:1px solid rgba(34,197,94,.25)!important}
:root[data-theme="light"] body{background:#f4f7fb!important;color:#1f2937!important}:root[data-theme="light"] .auth-shell{background:#f4f7fb!important}:root[data-theme="light"] .auth-card,:root[data-theme="light"] .mfa-card,:root[data-theme="light"] .panel-card,:root[data-theme="light"] .table-card{background:#fff!important;color:#1f2937!important;border-color:#dbe3ee!important}:root[data-theme="light"] .page-title,:root[data-theme="light"] h1,:root[data-theme="light"] h2,:root[data-theme="light"] h3,:root[data-theme="light"] .auth-title{color:#111827!important}:root[data-theme="light"] .page-subtitle,:root[data-theme="light"] .auth-subtitle,:root[data-theme="light"] .muted{color:#64748b!important}:root[data-theme="light"] .form-control,:root[data-theme="light"] .form-select{background:#fff!important;color:#111827!important;border-color:#cbd5e1!important}:root[data-theme="light"] .table{--bs-table-color:#1f2937!important;--bs-table-border-color:#dbe3ee!important}:root[data-theme="light"] .table thead th{background:#f8fafc!important;color:#64748b!important}:root[data-theme="light"] .sidebar{background:#0f172a!important}
@media(max-width:900px){.mfa-setup-grid{grid-template-columns:1fr!important}.mfa-card{padding:22px!important}.auth-card.compact{padding:26px 22px!important}.topbar{height:auto!important;min-height:68px!important}.sidebar{top:0!important}.main{padding-top:0!important}}

/* v14 - ajuste visual profesional login/MFA y uniformidad */
.auth-shell{background:radial-gradient(circle at 18% 0%,rgba(20,184,166,.22),transparent 28%),radial-gradient(circle at 80% 8%,rgba(37,99,235,.18),transparent 30%),#071020!important;}
.auth-shell .content{max-width:none!important;width:100%!important;padding:0!important;}
.auth-login-page{min-height:100vh;width:100%;display:grid;place-items:center;padding:32px 18px;}
.login-shell{width:100%;max-width:920px;display:grid;grid-template-columns:1.05fr .95fr;overflow:hidden;border-radius:28px;border:1px solid rgba(148,163,184,.24);background:rgba(15,23,42,.78);box-shadow:0 34px 100px rgba(0,0,0,.36);backdrop-filter:blur(16px);}
.login-brand-panel{padding:42px;min-height:500px;background:linear-gradient(145deg,rgba(0,83,58,.95),rgba(30,64,175,.92));color:#fff;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.login-brand-panel:after{content:"";position:absolute;inset:auto -80px -120px auto;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.10);}
.login-brand-mark{width:76px;height:76px;border-radius:22px;background:#fff;display:grid;place-items:center;margin-bottom:26px;box-shadow:0 20px 55px rgba(0,0,0,.22);}
.login-brand-mark img{width:54px;height:54px;object-fit:contain;}
.login-brand-panel h1{font-size:2rem!important;line-height:1.08!important;letter-spacing:-.04em!important;margin:0 0 14px!important;color:#fff!important;font-weight:900!important;max-width:410px;}
.login-brand-panel p{font-size:1rem;color:rgba(255,255,255,.82);max-width:420px;margin:0;}
.login-security-list{display:grid;gap:10px;margin-top:32px;position:relative;z-index:1;}
.login-security-list span{display:flex;align-items:center;gap:10px;color:#eef6ff;font-weight:750;font-size:.9rem;}
.login-security-list i{color:#a7f3d0;}
.login-form-panel{padding:42px;background:rgba(10,18,33,.94);display:flex;flex-direction:column;justify-content:center;}
.login-form-head{display:flex;gap:14px;align-items:center;margin-bottom:28px;}
.login-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(145deg,var(--brand-primary),var(--brand-secondary));color:#fff;font-size:1.35rem;box-shadow:0 16px 34px rgba(37,99,235,.22);flex:0 0 auto;}
.login-icon.large{width:78px;height:78px;border-radius:50%;font-size:1.7rem;margin:0 auto 18px;}
.login-form-head h2{font-size:1.45rem!important;line-height:1.1!important;font-weight:900!important;margin:0!important;color:#f8fafc!important;letter-spacing:-.03em!important;}
.login-form-head p{margin:5px 0 0;color:#9badc4;font-size:.92rem;}
.login-form{display:grid;gap:18px;}
.field-group label,.mfa-verify-form label{display:block;font-size:.84rem;font-weight:850;color:#dbeafe;margin-bottom:8px;}
.input-with-icon{position:relative;}
.input-with-icon>i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9badc4;z-index:2;}
.input-with-icon input{padding-left:44px!important;}
.login-form .form-control,.mfa-verify-form .form-control,.mfa-steps-panel .form-control{height:48px!important;border-radius:14px!important;background:#0e1728!important;border:1px solid #334155!important;color:#f8fafc!important;font-size:.95rem!important;box-shadow:none!important;}
.login-form .form-control:focus,.mfa-verify-form .form-control:focus,.mfa-steps-panel .form-control:focus{border-color:#3b82f6!important;box-shadow:0 0 0 4px rgba(59,130,246,.15)!important;background:#0f1a2e!important;}
.login-submit{height:48px!important;border-radius:14px!important;font-weight:850!important;margin-top:4px;}
.login-footer-note{margin-top:22px;padding:12px 14px;border-radius:14px;background:rgba(148,163,184,.08);border:1px solid rgba(148,163,184,.16);color:#a8b8cc;font-size:.82rem;display:flex;gap:9px;align-items:center;}
.compact-alert{font-size:.84rem;border-radius:12px;padding:.7rem .85rem;}
.mfa-verify-shell{width:100%;max-width:430px;border-radius:28px;background:rgba(15,23,42,.92);border:1px solid rgba(148,163,184,.24);box-shadow:0 34px 100px rgba(0,0,0,.34);padding:36px;text-align:center;}
.mfa-verify-shell h1{font-size:1.42rem!important;font-weight:900!important;letter-spacing:-.03em!important;color:#f8fafc!important;margin-bottom:6px!important;}
.mfa-verify-shell p{color:#9badc4;margin-bottom:26px;}
.mfa-verify-form{text-align:left;}
.mfa-verify-form input{text-align:center!important;font-size:1.35rem!important;font-weight:800!important;letter-spacing:.48rem!important;padding-left:.48rem!important;}
.mfa-setup-shell{width:100%;max-width:980px;border-radius:28px;background:rgba(15,23,42,.92);border:1px solid rgba(148,163,184,.24);box-shadow:0 34px 100px rgba(0,0,0,.34);padding:32px;}
.mfa-setup-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:24px;}
.mfa-setup-header h1{font-size:1.6rem!important;font-weight:900!important;letter-spacing:-.035em!important;color:#f8fafc!important;margin:12px 0 4px!important;}
.mfa-setup-header p{color:#9badc4;margin:0;}
.mfa-setup-content{display:grid;grid-template-columns:minmax(260px,340px) 1fr;gap:32px;align-items:start;}
.mfa-qr-panel{text-align:center;}
.mfa-qr-panel p{color:#9badc4;font-size:.84rem;margin-top:12px;}
.mfa-steps-panel .info-box{background:rgba(30,41,59,.65)!important;border:1px solid rgba(148,163,184,.20)!important;color:#dbeafe!important;}
.mfa-steps-panel .secret-box{background:#0e1728!important;border:1px solid #334155!important;color:#f8fafc!important;border-radius:14px!important;font-size:.85rem!important;}
.qr-box.clean{box-shadow:0 18px 40px rgba(0,0,0,.20);}
/* normalización general de texto y formularios */
body,.form-control,.form-select,.btn,.dropdown-menu,.table{font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif!important;}
h1,h2,h3,h4,h5,.page-title{font-weight:900!important;letter-spacing:-.03em!important;}
.form-label{font-size:.84rem!important;font-weight:850!important;}
.panel-card form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 24px;align-items:start;}
.panel-card form>p,.panel-card form>.mb-3{margin:0!important;}
.panel-card form .helptext,.panel-card form ul,.panel-card form .form-text{font-size:.78rem!important;color:var(--text-muted)!important;margin-top:6px!important;}
.panel-card form button,.panel-card form .btn, .panel-card form hr{grid-column:1/-1;}
.panel-card form input[type="checkbox"]{width:16px!important;height:16px!important;}
/* light auth */
:root[data-theme="light"] .auth-shell{background:#eef3f9!important;}
:root[data-theme="light"] .login-form-panel,:root[data-theme="light"] .mfa-verify-shell,:root[data-theme="light"] .mfa-setup-shell{background:#fff!important;color:#111827!important;border-color:#dbe3ee!important;}
:root[data-theme="light"] .login-form-head h2,:root[data-theme="light"] .mfa-verify-shell h1,:root[data-theme="light"] .mfa-setup-header h1{color:#111827!important;}
:root[data-theme="light"] .login-form-head p,:root[data-theme="light"] .mfa-verify-shell p,:root[data-theme="light"] .mfa-setup-header p,:root[data-theme="light"] .login-footer-note{color:#64748b!important;}
:root[data-theme="light"] .login-form .form-control,:root[data-theme="light"] .mfa-verify-form .form-control,:root[data-theme="light"] .mfa-steps-panel .form-control,:root[data-theme="light"] .mfa-steps-panel .secret-box{background:#fff!important;color:#111827!important;border-color:#cbd5e1!important;}
:root[data-theme="light"] .login-footer-note,:root[data-theme="light"] .mfa-steps-panel .info-box{background:#f8fafc!important;color:#334155!important;border-color:#dbe3ee!important;}
@media(max-width:850px){.login-shell{grid-template-columns:1fr;max-width:450px}.login-brand-panel{display:none}.login-form-panel{padding:32px 26px}.mfa-setup-content{grid-template-columns:1fr}.mfa-setup-header{flex-direction:column}.panel-card form{grid-template-columns:1fr}}

/* v15 - Pulido adicional SaaS corporativo */
:root{
  --radius-xl:22px;
  --radius-lg:18px;
  --shadow-soft:0 24px 70px rgba(0,0,0,.22);
  --field-height:46px;
}

.content{max-width:1680px;margin:0 auto;width:100%;}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px;}
.page-title{display:flex;align-items:center;gap:12px;font-size:1.72rem!important;line-height:1.08!important;margin:0!important;}
.page-subtitle{color:var(--text-muted);font-size:.92rem;margin-top:6px;}
.page-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.header-icon{width:42px;height:42px;border-radius:14px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.22);color:#38bdf8;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;}

.panel-card,.table-card,.card-kpi{border-radius:var(--radius-xl)!important;padding:18px;border-color:rgba(148,163,184,.20)!important;background:rgba(15,23,42,.86)!important;backdrop-filter:blur(10px);}
.table-card{padding:0;overflow:hidden;}
.table-card .table{font-size:.88rem;}
.table-card .table thead th{padding:14px 16px!important;background:rgba(15,23,42,.94)!important;color:#b7c5d8!important;border-bottom:1px solid rgba(148,163,184,.18)!important;}
.table-card .table tbody td{padding:14px 16px!important;}
.table-hover tbody tr:hover{background:rgba(59,130,246,.065)!important;}
.table-actions{white-space:nowrap;text-align:right;}
.section-title{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--text-main);letter-spacing:-.02em;}
.section-title i{color:#38bdf8;}

.badge-status,.badge-soft{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:.34rem .62rem;font-size:.72rem;font-weight:900;letter-spacing:.02em;text-transform:uppercase;}
.badge-soft{background:rgba(148,163,184,.12);border:1px solid rgba(148,163,184,.2);color:#cbd5e1;}
.badge-status.sent,.badge-status.completed,.badge-status.processed,.badge-status.validated,.badge-status.active,.badge-status.approved{background:rgba(34,197,94,.14)!important;color:#86efac!important;border:1px solid rgba(34,197,94,.25)!important;}
.badge-status.failed,.badge-status.invalid,.badge-status.cancelled,.badge-status.error{background:rgba(239,68,68,.14)!important;color:#fca5a5!important;border:1px solid rgba(239,68,68,.25)!important;}
.badge-status.pending,.badge-status.ready,.badge-status.scheduled,.badge-status.processing{background:rgba(245,158,11,.14)!important;color:#fde68a!important;border:1px solid rgba(245,158,11,.25)!important;}

/* Formularios uniformes */
.form-control,.form-select{min-height:var(--field-height);font-size:.92rem!important;}
.form-label{margin-bottom:7px!important;color:#d7e5f7!important;}
.panel-card form .row{row-gap:18px!important;}
.panel-card form .btn{min-height:42px;padding-left:18px;padding-right:18px;}
.form-help-card{border-radius:16px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.18);padding:13px 15px;color:#bad5ff;font-size:.82rem;}

/* Login más sobrio y balanceado */
.login-shell{max-width:980px!important;min-height:560px;border-radius:30px!important;}
.login-brand-panel{padding:48px!important;}
.login-form-panel{padding:48px 46px!important;}
.login-form-head{margin-bottom:30px!important;}
.login-submit{box-shadow:0 16px 34px rgba(37,99,235,.23);}
.login-footer-note{justify-content:center;}

/* MFA: separación limpia entre setup y validación */
.mfa-setup-shell{max-width:1040px!important;padding:34px!important;}
.mfa-setup-content{grid-template-columns:330px minmax(0,1fr)!important;gap:34px!important;}
.qr-box.clean{width:100%;max-width:320px;margin:0 auto;border-radius:22px!important;padding:18px!important;background:#fff!important;}
.qr-box.clean img{width:100%;height:auto;display:block;}
.mfa-steps-panel{display:grid;gap:16px;}
.mfa-verify-shell{max-width:455px!important;padding:42px 38px!important;}
.mfa-verify-shell .login-icon{box-shadow:0 18px 42px rgba(0,83,58,.22);}
.mfa-verify-form input{height:54px!important;border-radius:16px!important;}
.security-note{border-radius:16px;background:rgba(148,163,184,.08);border:1px solid rgba(148,163,184,.14);padding:13px 14px;color:#aebdd1;}

/* Cargues */
.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;}
.template-chip{min-height:52px;border:1px solid rgba(148,163,184,.22);border-radius:15px;padding:12px 14px;text-decoration:none;color:var(--text-main);display:flex;align-items:center;gap:10px;background:rgba(15,23,42,.56);font-weight:800;}
.template-chip:hover{border-color:#3b82f6;background:rgba(59,130,246,.10);color:#fff;transform:translateY(-1px);}
.template-chip i{color:#22c55e;}
.upload-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:18px;}
.upload-step{border:1px solid rgba(148,163,184,.20);background:rgba(15,23,42,.55);border-radius:18px;padding:15px;display:flex;gap:12px;align-items:flex-start;}
.upload-step-number{width:30px;height:30px;border-radius:10px;background:#1677ff;color:#fff;display:grid;place-items:center;font-weight:900;flex:0 0 auto;}
.upload-step strong{display:block;color:#fff;line-height:1.1;}
.upload-step span{display:block;color:var(--text-muted);font-size:.8rem;margin-top:4px;}

/* Reportes */
.trace-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;}
.trace-item{border:1px solid rgba(148,163,184,.20);background:rgba(15,23,42,.86);border-radius:20px;padding:17px 18px;box-shadow:0 16px 42px rgba(0,0,0,.13);}
.trace-title{font-size:.78rem;color:var(--text-muted);font-weight:800;text-transform:uppercase;letter-spacing:.05em;}
.trace-value{font-size:1.75rem;font-weight:950;letter-spacing:-.05em;color:#fff;margin-top:5px;}
.report-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:13px;}
.report-action{border-radius:19px;border:1px solid rgba(148,163,184,.22);background:rgba(15,23,42,.75);padding:18px;text-decoration:none;color:var(--text-main);display:grid;gap:6px;min-height:130px;transition:.16s ease;}
.report-action i{font-size:1.55rem;color:#38bdf8;}
.report-action span{font-weight:950;font-size:1rem;color:#fff;}
.report-action small{color:var(--text-muted);line-height:1.35;}
.report-action:hover{transform:translateY(-2px);border-color:#3b82f6;background:rgba(59,130,246,.10);color:#fff;}
.report-action.featured{background:linear-gradient(145deg,rgba(6,78,59,.82),rgba(29,78,216,.72));border-color:rgba(255,255,255,.18);}

/* Roles y permisos */
.permissions-card{position:relative;}
.permissions-table thead th{position:sticky;top:0;z-index:3;text-align:center;}
.permissions-table thead th:first-child{text-align:left;left:0;z-index:4;}
.permissions-table tbody td:first-child{position:sticky;left:0;z-index:2;background:rgba(15,23,42,.97);min-width:300px;}
.permissions-table .module-row td{position:static!important;background:linear-gradient(90deg,rgba(59,130,246,.14),rgba(20,184,166,.10))!important;color:#e2e8f0!important;text-transform:uppercase;font-weight:950;letter-spacing:.05em;font-size:.78rem!important;}
.permission-code{font-size:.72rem;color:#38bdf8;margin-top:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;}
.permissions-table input[type="checkbox"]{width:17px!important;height:17px!important;cursor:pointer;accent-color:#1677ff;}
.card-footer-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px;border-top:1px solid rgba(148,163,184,.16);background:rgba(15,23,42,.88);position:sticky;bottom:0;z-index:5;}

/* Header y logos */
.brand-logo{background:#fff!important;}
.brand-logo img,.brand-logo .fallback-logo{object-fit:contain!important;padding:7px!important;}
.user-pill span{max-width:260px;display:inline-block;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom;}

/* Light mode */
:root[data-theme="light"] .panel-card,
:root[data-theme="light"] .table-card,
:root[data-theme="light"] .card-kpi,
:root[data-theme="light"] .trace-item,
:root[data-theme="light"] .report-action,
:root[data-theme="light"] .template-chip,
:root[data-theme="light"] .upload-step{background:#fff!important;color:#1f2937!important;border-color:#dbe3ee!important;box-shadow:0 18px 45px rgba(15,23,42,.06)!important;}
:root[data-theme="light"] .trace-value,
:root[data-theme="light"] .report-action span,
:root[data-theme="light"] .section-title,
:root[data-theme="light"] .upload-step strong{color:#111827!important;}
:root[data-theme="light"] .permissions-table tbody td:first-child{background:#fff!important;}
:root[data-theme="light"] .card-footer-actions{background:#fff!important;border-color:#e5e7eb!important;}
:root[data-theme="light"] .template-chip:hover,
:root[data-theme="light"] .report-action:hover{background:#eef6ff!important;color:#111827!important;}
:root[data-theme="light"] .badge-soft{background:#f1f5f9;color:#334155;border-color:#dbe3ee;}
:root[data-theme="light"] .form-label{color:#334155!important;}

@media(max-width:1100px){.trace-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.upload-steps{grid-template-columns:1fr}.page-head{flex-direction:column}.page-toolbar{width:100%;}.page-toolbar .btn{flex:1;}}
@media(max-width:900px){.login-shell{max-width:480px!important;min-height:auto}.login-form-panel{padding:34px 26px!important}.mfa-setup-content{grid-template-columns:1fr!important}.trace-grid{grid-template-columns:1fr}.permissions-table tbody td:first-child{position:static;min-width:260px}.permissions-table thead th{position:static}}

/* v19 - Distribución profesional de formularios, billing y uso eficiente del espacio */
.form-card form{display:block!important;width:100%!important;}
.form-grid-pro{display:grid!important;grid-template-columns:repeat(4,minmax(210px,1fr))!important;gap:18px 22px!important;align-items:start!important;width:100%!important;}
.form-grid-pro .form-field{min-width:0!important;}
.form-grid-pro .form-field[data-field="config_json"],
.form-grid-pro .form-field[data-field="description"],
.form-grid-pro .form-field[data-field="notes"]{grid-column:span 2!important;}
.form-grid-pro textarea.form-control{min-height:132px!important;resize:vertical!important;}
.form-grid-pro .form-label{font-weight:850!important;}
.form-card .form-help-card{margin-top:22px!important;}
.form-card .btn{min-width:112px!important;}
.billing-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(190px,1fr));gap:16px;margin-bottom:22px;}
.billing-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:0 18px 40px rgba(0,0,0,.10);}
.billing-card .label{font-size:.78rem;color:var(--text-muted);font-weight:850;text-transform:uppercase;letter-spacing:.05em;}
.billing-card .value{font-size:1.75rem;font-weight:950;letter-spacing:-.04em;margin-top:5px;color:var(--text-main);}
.billing-card .note{font-size:.82rem;color:var(--text-muted);margin-top:5px;}
.credential-security-note{border:1px solid rgba(34,197,94,.22);background:rgba(34,197,94,.08);color:#bbf7d0;border-radius:16px;padding:14px 16px;line-height:1.45;}
@media(max-width:1500px){.form-grid-pro{grid-template-columns:repeat(3,minmax(210px,1fr))!important}.billing-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:950px){.form-grid-pro{grid-template-columns:1fr!important}.form-grid-pro .form-field[data-field]{grid-column:span 1!important}.billing-summary-grid{grid-template-columns:1fr;}}
:root[data-theme="light"] .billing-card{background:#fff!important;border-color:#dbe3ee!important;box-shadow:0 18px 45px rgba(15,23,42,.06)!important;}
:root[data-theme="light"] .credential-security-note{background:#ecfdf5;color:#065f46;border-color:#a7f3d0;}

/* Billing rules form refinements */
.section-title-sm {
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted, #8ca0bd);
}
.billing-rule-form .form-text {
  color: var(--muted, #8ca0bd);
  font-size: .76rem;
  margin-top: .45rem;
}
.switch-card {
  min-height: 76px;
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: 1rem;
  border: 1px solid var(--border, rgba(148,163,184,.22));
  border-radius: 1rem;
  background: color-mix(in srgb, var(--card, #111827) 92%, transparent);
  cursor: pointer;
}
.switch-card input {
  margin-top: .2rem;
  flex: 0 0 auto;
}
.switch-card strong {
  display: block;
  line-height: 1.2;
}
.switch-card small {
  display: block;
  color: var(--muted, #8ca0bd);
  margin-top: .25rem;
  line-height: 1.3;
}

/* =========================================================
   V25 - DESIGN TOKENS + BRANDING DINÁMICO POR COMPAÑÍA
   Las variables vienen desde la compañía activa y permiten
   personalizar colores, logo, tipografía, radios y tema.
========================================================= */
:root{
  --radius: var(--company-radius, 14px);
  --field-height: 44px;
}
html, body, button, input, select, textarea{
  font-family: var(--company-font, 'Inter', 'Segoe UI', Arial, sans-serif) !important;
}
html[data-theme="dark"]{
  --bg-main: var(--company-dark-bg, #071020);
  --bg-panel: color-mix(in srgb, var(--company-dark-surface, #101827) 94%, #000 6%);
  --bg-card: var(--company-dark-surface, #101827);
  --text-main: var(--company-dark-text, #e5edf7);
  --text-muted: #9badc4;
  --border: color-mix(in srgb, var(--brand-secondary, #1d4ed8) 18%, #243247 82%);
}
html[data-theme="light"]{
  --bg-main: var(--company-light-bg, #eef3f8);
  --bg-panel: var(--company-light-surface, #ffffff);
  --bg-card: var(--company-light-surface, #ffffff);
  --text-main: var(--company-light-text, #172033);
  --text-muted: #5f6f86;
  --border: #dbe4f0;
}
body{
  background: radial-gradient(circle at 25% 2%, color-mix(in srgb, var(--brand-accent) 13%, transparent), transparent 27%),
              radial-gradient(circle at 80% 0%, color-mix(in srgb, var(--brand-secondary) 14%, transparent), transparent 25%),
              var(--bg-main) !important;
  color: var(--text-main) !important;
}
html[data-theme="light"] body:before{opacity:.16;filter:saturate(.85)}
html[data-theme="dark"] body:before{opacity:.23}
.topbar{
  background: linear-gradient(90deg, var(--brand-primary), var(--brand-secondary)) !important;
  color: var(--brand-topbar-text, #fff) !important;
}
.topbar .brand-title,
.topbar .brand-subtitle,
.topbar .company-filter,
.topbar .sidebar-toggle,
.topbar .icon-btn{color: var(--brand-topbar-text, #fff) !important;}
.sidebar{background: var(--company-sidebar, #0f172a) !important;}
.brand-logo,
.company-logo-preview{
  background: var(--company-logo-bg, #fff) !important;
  border-radius: calc(var(--radius) - 2px) !important;
}
.brand-logo img,
.company-logo-preview img{object-fit:contain !important;background:var(--company-logo-bg,#fff) !important;}
.panel-card,
.table-card,
.card-kpi,
.form-card,
.stat-card{
  background: var(--bg-card) !important;
  color: var(--text-main) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 18px 42px rgba(15, 23, 42, .10) !important;
}
html[data-theme="light"] .panel-card,
html[data-theme="light"] .table-card,
html[data-theme="light"] .card-kpi,
html[data-theme="light"] .form-card,
html[data-theme="light"] .stat-card{
  box-shadow: 0 16px 38px rgba(30, 41, 59, .08) !important;
}
.page-title, .page-title *, h1, h2, h3, h4, .brand-title, .menu-title, .fw-bold{color:var(--text-main)}
html[data-theme="dark"] .topbar .brand-title,
html[data-theme="dark"] .topbar .brand-subtitle{color:var(--brand-topbar-text,#fff)!important;}
html[data-theme="light"] .page-subtitle,
html[data-theme="light"] .muted,
html[data-theme="light"] .text-muted,
html[data-theme="light"] .form-text{color:#607086!important;}
.form-control,.form-select,textarea,input[type="text"],input[type="password"],input[type="email"],input[type="number"],input[type="date"],input[type="datetime-local"]{
  min-height: var(--field-height);
  border-radius: calc(var(--radius) - 4px) !important;
  border:1px solid var(--border)!important;
}
html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select,
html[data-theme="light"] textarea,
html[data-theme="light"] input[type="text"],
html[data-theme="light"] input[type="password"],
html[data-theme="light"] input[type="email"],
html[data-theme="light"] input[type="number"],
html[data-theme="light"] input[type="date"],
html[data-theme="light"] input[type="datetime-local"]{
  background:#fff!important;
  color:#172033!important;
  border-color:#cbd8e8!important;
}
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select,
html[data-theme="dark"] textarea,
html[data-theme="dark"] input[type="text"],
html[data-theme="dark"] input[type="password"],
html[data-theme="dark"] input[type="email"],
html[data-theme="dark"] input[type="number"],
html[data-theme="dark"] input[type="date"],
html[data-theme="dark"] input[type="datetime-local"]{
  background:color-mix(in srgb, var(--company-dark-surface,#101827) 82%, #000 18%)!important;
  color:var(--company-dark-text,#e5edf7)!important;
  border-color:color-mix(in srgb, var(--brand-secondary) 22%, #334155 78%)!important;
}
.form-control:focus,.form-select:focus,textarea:focus,input:focus{
  border-color:var(--brand-secondary)!important;
  box-shadow:0 0 0 .18rem color-mix(in srgb, var(--brand-secondary) 20%, transparent)!important;
}
.btn-primary{
  background:linear-gradient(135deg,var(--brand-secondary),color-mix(in srgb,var(--brand-secondary) 72%,#000 28%))!important;
  border-color:var(--brand-secondary)!important;
  border-radius:calc(var(--radius) - 5px)!important;
}
.btn-success{
  background:linear-gradient(135deg,var(--brand-accent),color-mix(in srgb,var(--brand-accent) 72%,#000 28%))!important;
  border-color:var(--brand-accent)!important;
  border-radius:calc(var(--radius) - 5px)!important;
}
.btn-outline-secondary{
  border-radius:calc(var(--radius) - 5px)!important;
}
.sidebar a.active,
.sidebar a:hover{
  background:linear-gradient(90deg,color-mix(in srgb,var(--brand-accent) 78%,transparent),color-mix(in srgb,var(--brand-secondary) 58%,transparent))!important;
}
.header-icon,
.sidebar a i{color:var(--brand-accent)!important;}
.sidebar a.active i,.sidebar a:hover i{color:#fff!important;}
.table thead th{
  background:color-mix(in srgb, var(--bg-card) 88%, var(--brand-secondary) 12%)!important;
  color:color-mix(in srgb,var(--text-main) 78%,var(--brand-secondary) 22%)!important;
}
html[data-theme="light"] .table{--bs-table-color:#172033;--bs-table-border-color:#dce5f1;}
html[data-theme="light"] .table td{color:#172033!important;}
html[data-theme="light"] .alert-info-custom,
html[data-theme="light"] .form-help-card{
  background:color-mix(in srgb,var(--brand-secondary) 8%,#fff 92%)!important;
  border-color:color-mix(in srgb,var(--brand-secondary) 22%,#dbe4f0 78%)!important;
  color:#244269!important;
}
.form-grid-pro{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:18px 20px;
}
.form-grid-pro .form-field{grid-column:span 4;}
.form-grid-pro .form-field[data-field*="notes"],
.form-grid-pro .form-field[data-field*="description"],
.form-grid-pro .form-field[data-field="config_json"],
.form-grid-pro .form-field[data-field="internal_notes"],
.form-grid-pro .form-field[data-field="client_visible_notes"]{grid-column:span 6;}
.form-grid-pro .form-field[data-field="logo_url"],
.form-grid-pro .form-field[data-field="logo_file"]{grid-column:span 6;}
@media (max-width:1200px){.form-grid-pro .form-field{grid-column:span 6}}
@media (max-width:768px){.form-grid-pro .form-field{grid-column:span 12}}
.design-token-preview{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:120px;
}
.design-token-preview .preview-dark{background:linear-gradient(135deg,var(--company-dark-bg),var(--company-dark-surface));color:var(--company-dark-text);padding:18px;}
.design-token-preview .preview-light{background:linear-gradient(135deg,var(--company-light-bg),var(--company-light-surface));color:var(--company-light-text);padding:18px;}
.design-token-palette{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.design-token-dot{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.75);box-shadow:0 3px 10px rgba(0,0,0,.16)}

/* =========================================================
   V26 - FIX SIDEBAR LEGIBILITY IN LIGHT MODE
   El sidebar conserva identidad corporativa oscura/brand,
   por eso los textos del menú NO deben heredar --text-main
   del tema claro.
========================================================= */
:root{
  --sidebar-bg: var(--company-sidebar, #0f172a);
  --sidebar-text: #e8f2ff;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: #91a6c4;
  --sidebar-icon: #38d9ff;
  --sidebar-border: rgba(148, 163, 184, .22);
}

html[data-theme="light"]{
  --sidebar-text: #eaf2ff;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: #93a6c2;
  --sidebar-icon: #22c7ff;
  --sidebar-border: rgba(148, 163, 184, .24);
}

html[data-theme="dark"]{
  --sidebar-text: #dceafe;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: #94a3b8;
  --sidebar-icon: #38bdf8;
}

.sidebar{
  background: var(--sidebar-bg) !important;
  color: var(--sidebar-text) !important;
  border-right: 1px solid var(--sidebar-border) !important;
}

.sidebar .menu-title,
.sidebar .menu-header .menu-title,
.sidebar .sidebar-title{
  color: var(--sidebar-text-strong) !important;
}

.sidebar .menu-sub,
.sidebar .nav-section{
  color: var(--sidebar-muted) !important;
}

.sidebar a,
.sidebar a:visited,
.sidebar a span{
  color: var(--sidebar-text) !important;
}

.sidebar a i,
.sidebar .menu-icon i{
  color: var(--sidebar-icon) !important;
}

.sidebar a:hover,
.sidebar a.active{
  color: #ffffff !important;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--brand-accent) 82%, transparent),
    color-mix(in srgb, var(--brand-secondary) 68%, transparent)
  ) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}

.sidebar a:hover span,
.sidebar a.active span,
.sidebar a:hover i,
.sidebar a.active i{
  color: #ffffff !important;
}

.sidebar .menu-icon{
  background: rgba(255,255,255,.09) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  color: var(--sidebar-icon) !important;
}

/* En modo contraído se muestran solo íconos por diseño. */
body.sidebar-collapsed .sidebar a span,
body.sidebar-collapsed .sidebar .menu-title,
body.sidebar-collapsed .sidebar .menu-sub,
body.sidebar-collapsed .sidebar .nav-section{
  display: none !important;
}

/* Header y contenido light más legibles */
html[data-theme="light"] .content{
  color: #172033 !important;
}
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] .page-title,
html[data-theme="light"] .page-title *{
  color: #172033 !important;
}
html[data-theme="light"] .panel-card,
html[data-theme="light"] .table-card,
html[data-theme="light"] .card-kpi,
html[data-theme="light"] .form-card,
html[data-theme="light"] .stat-card{
  background: #ffffff !important;
  border-color: #d9e4f2 !important;
}

/* v27 - Formulario de compañía y branding dinámico mejor estructurado */
.company-page-head{margin-bottom:18px!important;}
.company-form-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:20px;align-items:start;}
.company-form-main{padding:24px!important;}
.form-section-title{display:flex;align-items:center;gap:10px;font-weight:950;color:var(--text-main);font-size:1rem;margin-bottom:14px;letter-spacing:-.02em;}
.form-section-title i{width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(59,130,246,.12);color:#38bdf8;border:1px solid rgba(59,130,246,.22);}
.form-section-title.small-title{font-size:.92rem;margin-bottom:12px;}
.form-section-title.small-title i{width:28px;height:28px;border-radius:10px;}
.brand-form-grid{display:grid;gap:16px 18px;}
.brand-form-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}
.brand-form-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.brand-form-grid.align-start{align-items:start;}
.company-branding-form .panel-card form,
.company-branding-form.panel-card form{display:block!important;}
.company-branding-form .form-field{min-width:0;}
.company-branding-form .form-label{font-weight:900!important;color:var(--text-main)!important;margin-bottom:7px!important;}
.company-branding-form .form-text{color:var(--text-muted)!important;font-size:.78rem!important;margin-top:6px!important;}
.company-branding-form input[type="text"],
.company-branding-form input[type="url"],
.company-branding-form input[type="number"],
.company-branding-form input[type="file"],
.company-branding-form select,
.company-branding-form textarea{width:100%;min-height:46px;border-radius:14px!important;}
.color-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.color-field{border:1px solid rgba(148,163,184,.18);background:rgba(15,23,42,.42);border-radius:18px;padding:14px;}
.color-control{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:10px;align-items:center;}
.color-swatch{width:44px;height:44px;border-radius:14px;border:2px solid rgba(255,255,255,.55);box-shadow:0 8px 18px rgba(0,0,0,.18), inset 0 0 0 1px rgba(0,0,0,.15);}
.color-control input[type="color"]{width:100%!important;height:44px!important;min-height:44px!important;padding:4px!important;border-radius:14px!important;cursor:pointer;}
.color-value{min-width:80px;text-align:center;border-radius:999px;padding:.42rem .55rem;background:rgba(148,163,184,.12);border:1px solid rgba(148,163,184,.18);color:var(--text-main);font-weight:900;font-size:.78rem;}
.theme-token-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}
.theme-token-panel{border:1px solid rgba(148,163,184,.18);border-radius:20px;padding:16px;background:rgba(148,163,184,.06);display:grid;gap:12px;}
.brand-switch{border:1px solid rgba(148,163,184,.18);background:rgba(148,163,184,.06);border-radius:16px;padding:14px 14px 14px 46px!important;min-height:50px;display:flex;align-items:center;}
.brand-switch .form-check-input{width:2.6rem;height:1.35rem;margin-left:-34px;}
.form-actions-sticky{border-top:1px solid rgba(148,163,184,.18);padding-top:18px;}
.company-preview-card{position:sticky;top:calc(var(--topbar-height) + 20px);padding:18px!important;}
.preview-title{display:flex;align-items:center;gap:9px;font-weight:950;margin-bottom:12px;color:var(--text-main);}
.preview-title i{color:#38bdf8;}
.preview-shell{border-radius:22px;overflow:hidden;border:1px solid rgba(148,163,184,.2);background:var(--company-light-surface,#fff);box-shadow:0 20px 55px rgba(0,0,0,.14);}
.preview-topbar{display:flex;align-items:center;gap:10px;padding:14px;background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary));color:var(--brand-topbar-text,#fff);}
.preview-topbar strong{display:block;font-size:.9rem;line-height:1.1;}
.preview-topbar small{display:block;font-size:.68rem;opacity:.85;}
.preview-logo-frame{width:44px;height:44px;border-radius:14px;background:var(--company-logo-bg,#fff);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#0f172a;font-weight:950;}
.preview-logo-frame img{width:100%;height:100%;object-fit:contain;padding:6px;}
.preview-body{display:grid;grid-template-columns:126px 1fr;min-height:190px;background:var(--company-light-bg,#eef3f8);}
.preview-sidebar{background:var(--company-sidebar,#0f172a);padding:12px;display:grid;gap:8px;align-content:start;}
.preview-menu-item{display:flex;align-items:center;gap:8px;color:#cbd5e1;border-radius:12px;padding:9px 10px;font-size:.75rem;font-weight:850;}
.preview-menu-item i{color:var(--brand-accent,#22c55e);}
.preview-menu-item.active{background:linear-gradient(90deg,var(--brand-accent),var(--brand-secondary));color:#fff;}
.preview-content{padding:14px;display:grid;gap:12px;align-content:start;color:var(--company-light-text,#172033);}
.preview-card-kpi{border-radius:16px;background:var(--company-light-surface,#fff);border:1px solid rgba(148,163,184,.25);padding:14px;}
.preview-card-kpi span{display:block;font-size:.75rem;color:#64748b;font-weight:800;}
.preview-card-kpi strong{font-size:1.6rem;line-height:1;}
.preview-button{border-radius:999px;padding:10px 14px;background:var(--brand-secondary);color:#fff;text-align:center;font-size:.78rem;font-weight:900;}
.preview-note{font-size:.78rem;color:var(--text-muted);}

:root[data-theme="light"] .color-field,
:root[data-theme="light"] .theme-token-panel,
:root[data-theme="light"] .brand-switch{background:#f8fafc!important;border-color:#dbe3ee!important;}
:root[data-theme="light"] .color-value{background:#eef2f7;border-color:#d1d9e6;color:#172033;}
:root[data-theme="light"] .color-swatch{border-color:#fff;box-shadow:0 8px 20px rgba(15,23,42,.13), inset 0 0 0 1px rgba(15,23,42,.12);}
:root[data-theme="light"] .company-branding-form .form-label{color:#23314a!important;}

@media(max-width:1180px){.company-form-layout{grid-template-columns:1fr}.company-preview-card{position:relative;top:auto}.color-grid,.brand-form-grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:720px){.color-grid,.brand-form-grid.cols-2,.brand-form-grid.cols-3,.theme-token-panels{grid-template-columns:1fr}.preview-body{grid-template-columns:1fr}.preview-sidebar{grid-template-columns:repeat(3,1fr)}.preview-menu-item span{display:none}.color-control{grid-template-columns:44px minmax(0,1fr)}}

/* =========================================================
   V28 - Matriz de permisos completa + ajustes visuales
========================================================= */
.permissions-card{border-radius:22px!important;overflow:hidden;}
.permissions-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;}
.permissions-summary{display:flex;gap:10px;flex-wrap:wrap;}
.permission-pill{border:1px solid var(--border);background:color-mix(in srgb,var(--bg-card) 92%,var(--brand-secondary) 8%);border-radius:999px;padding:8px 12px;font-size:.78rem;font-weight:900;color:var(--text-main);}
.permissions-table{border-collapse:separate!important;border-spacing:0!important;}
.permissions-table thead th{height:54px!important;vertical-align:middle!important;font-size:.76rem!important;letter-spacing:.07em!important;text-transform:uppercase!important;}
.permissions-table thead th:not(:first-child){min-width:155px;}
.permissions-table tbody td{vertical-align:middle!important;}
.permissions-table tbody tr:not(.module-row) td{height:62px!important;}
.permissions-table tbody tr:not(.module-row):hover td{background:color-mix(in srgb,var(--brand-secondary) 7%,transparent)!important;}
.permissions-table tbody td:first-child{min-width:380px!important;}
.permission-title{display:flex;align-items:center;gap:9px;font-weight:900;color:var(--text-main);}
.permission-title:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brand-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-accent) 18%,transparent);}
.permission-code{display:inline-flex;margin-top:7px;padding:3px 8px;border-radius:999px;background:color-mix(in srgb,var(--brand-secondary) 10%,transparent);border:1px solid color-mix(in srgb,var(--brand-secondary) 18%,transparent);}
.permissions-table input[type="checkbox"]{width:20px!important;height:20px!important;border-radius:6px!important;}
.module-row td{height:48px!important;font-size:.82rem!important;}
.module-row td:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--brand-secondary);margin-right:9px;vertical-align:middle;}
.card-footer-actions{align-items:center;}
.card-footer-actions:before{content:"Los cambios aplican inmediatamente en menú y validaciones backend.";margin-right:auto;color:var(--text-muted);font-size:.82rem;font-weight:700;}
html[data-theme="light"] .permissions-table tbody td:first-child{background:#fff!important;}
html[data-theme="light"] .permissions-table tbody tr:not(.module-row):hover td{background:#f2f7ff!important;}
html[data-theme="light"] .permissions-table .module-row td{background:linear-gradient(90deg,#eaf2ff,#edfdf7)!important;color:#18314f!important;border-color:#d8e5f3!important;}
html[data-theme="light"] .permission-code{color:#095bb5!important;background:#eef6ff!important;border-color:#cfe2ff!important;}

/* KPI cards consumo/facturación */
.consumption-kpi-grid,.billing-summary-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))!important;gap:16px!important;margin-bottom:22px!important;}
.consumption-kpi-card,.billing-card,.card-kpi,.stat-card{min-height:112px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.consumption-kpi-card:after,.billing-card:after,.card-kpi:after,.stat-card:after{content:"";position:absolute;right:-38px;top:-48px;width:126px;height:126px;border-radius:50%;background:color-mix(in srgb,var(--brand-secondary) 11%,transparent);}
.consumption-kpi-card .label,.billing-card .label,.stat-card .label{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:950;color:var(--text-muted)!important;}
.consumption-kpi-card .value,.billing-card .value,.stat-card .value{font-size:1.65rem!important;line-height:1.1;font-weight:950;color:var(--text-main)!important;letter-spacing:-.04em;}
.consumption-kpi-card .note,.billing-card .note,.stat-card .note{font-size:.82rem;color:var(--text-muted)!important;margin-top:4px;}
html[data-theme="light"] .consumption-kpi-card,
html[data-theme="light"] .billing-card,
html[data-theme="light"] .card-kpi,
html[data-theme="light"] .stat-card{background:#fff!important;border-color:#dbe5f1!important;box-shadow:0 16px 36px rgba(15,23,42,.06)!important;}

/* Producción: legibilidad general de tablas y cards */
.table-card .table tbody td{border-color:color-mix(in srgb,var(--border) 80%,transparent)!important;}
.table-card .table thead th{white-space:nowrap;}
.page-toolbar .btn{box-shadow:0 8px 18px rgba(15,23,42,.08);}
html[data-theme="light"] .table-card .table thead th{background:#f7faff!important;color:#475569!important;}
html[data-theme="light"] .table-card .table tbody tr:hover td{background:#f7fbff!important;}
html[data-theme="light"] .form-help-card{color:#1f4d7a!important;}


/* v28 - Operación masiva y dashboard ejecutivo refinado */
.stats-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(245px,1fr))!important;gap:16px!important;}
.stat-card{padding:22px 24px!important;align-items:center!important;text-align:center!important;gap:4px!important;}
.stat-card .label,.stat-card>span:first-child{font-size:.78rem!important;text-transform:uppercase!important;letter-spacing:.07em!important;font-weight:950!important;color:var(--text-muted)!important;}
.stat-card .value,.stat-card>strong{font-size:1.78rem!important;line-height:1.08!important;font-weight:950!important;color:var(--text-main)!important;letter-spacing:-.045em!important;}
.stat-card .note{font-size:.82rem!important;color:var(--text-muted)!important;}
.executive-hero{position:relative;overflow:hidden;border:1px solid color-mix(in srgb,var(--brand-secondary) 22%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--brand-secondary) 18%,transparent),rgba(15,23,42,.72));border-radius:26px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 20px 52px rgba(0,0,0,.16)}
.executive-hero:after{content:"";position:absolute;right:-70px;top:-90px;width:250px;height:250px;border-radius:50%;background:color-mix(in srgb,var(--brand-secondary) 17%,transparent);pointer-events:none}.executive-hero-content,.executive-actions{position:relative;z-index:1}.executive-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.billing-check{display:flex!important;align-items:center;gap:8px;margin:0;color:var(--text-muted);font-weight:800}.billing-check .form-check-input{margin:0}.executive-filter{padding:18px 20px!important}.executive-kpis .executive-stat{min-height:142px!important}.executive-stat .stat-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:color-mix(in srgb,var(--brand-secondary) 14%,transparent);border:1px solid color-mix(in srgb,var(--brand-secondary) 24%,transparent);color:#60a5fa;margin-bottom:8px}.executive-section{padding:22px!important}.section-heading{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.alert-list{display:grid;gap:12px}.empty-state{border:1px dashed var(--border);border-radius:18px;background:rgba(148,163,184,.055)}
html[data-theme="light"] .executive-hero{background:linear-gradient(135deg,#eef6ff,#ffffff)!important;box-shadow:0 18px 44px rgba(15,23,42,.08)!important}html[data-theme="light"] .executive-stat .stat-icon{background:#eef6ff!important;color:#1d4ed8!important;border-color:#cfe1ff!important}
@media(max-width:900px){.executive-hero{flex-direction:column;align-items:flex-start}.executive-actions{width:100%;justify-content:flex-start}.section-heading{flex-direction:column}.stats-grid{grid-template-columns:1fr!important}}
