/* ============================================================
   eFacto ONE — Bootstrap 5 Custom Theme v2.0
   Outlook-style Shell + AI + Favourites + Module Selection
   ============================================================ */
:root{--ef-primary:#0D6EFD;--ef-primary-hover:#0a58ca;--ef-primary-subtle:rgba(13,110,253,.08);--ef-secondary:#6C757D;--ef-success:#198754;--ef-warning:#FFC107;--ef-danger:#DC3545;--ef-info:#0DCAF0;--ef-appbar-width:54px;--ef-sidebar-width:232px;--ef-topbar-height:46px;--ef-footer-height:30px;--ef-appbar-bg:#1E293B;--ef-topbar-bg:var(--bs-body-bg);--ef-footer-bg:var(--bs-body-bg);--ef-font:Inter,Segoe UI,system-ui,sans-serif;--ef-fs:13.5px;--ef-login-g1:#0f2740;--ef-login-g2:#1b4b7a;--ef-login-g3:#2563eb}
/* Font size scaling — changes root font-size so ALL px/rem values scale proportionally */
[data-font-size=small]{font-size:12px !important;--ef-fs:12px}
[data-font-size=medium]{font-size:14px !important;--ef-fs:13.5px}
[data-font-size=large]{font-size:16px !important;--ef-fs:15px}
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0;padding:0;overflow:hidden;font-family:var(--ef-font);font-size:var(--ef-fs);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

/* Page Router */
.page{display:none;height:100%}.page.active{display:flex;flex-direction:column}
.page-login.active{display:flex;flex-direction:row}.page-modules.active{display:flex;flex-direction:column}
.page-shell.active{display:flex;flex-direction:row;height:100vh}

/* ===== LOGIN ===== */
.login-left{flex:1;min-height:100vh;padding:48px 44px;color:#fff;background:linear-gradient(135deg,var(--ef-login-g1),var(--ef-login-g2) 50%,var(--ef-login-g3));display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;top:-40%;right:-25%;width:70%;height:180%;background:radial-gradient(ellipse,rgba(255,255,255,.06),transparent 70%);border-radius:50%;transform:rotate(-12deg);pointer-events:none}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:36px;position:relative;z-index:1}
.login-brand .logo-box{width:44px;height:44px;background:rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.143rem;backdrop-filter:blur(8px)}
.login-brand h1{font-size:1.857rem;font-weight:700;letter-spacing:-.5px;margin:0}.login-brand .tagline{font-size:0.929rem;opacity:.7}
.login-features{display:flex;flex-direction:column;gap:11px;position:relative;z-index:1}
.login-feat{display:flex;align-items:center;gap:10px;font-size:0.929rem;opacity:.85}
.login-feat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.login-stats{display:flex;gap:28px;margin-top:40px;position:relative;z-index:1}.login-stat .num{font-size:2rem;font-weight:700}.login-stat .lbl{font-size:0.786rem;opacity:.7;text-transform:uppercase;letter-spacing:.5px}
.login-right{flex:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bs-body-bg)}
.login-card{width:100%;max-width:380px}.login-card h2{font-size:1.571rem;font-weight:700;color:var(--bs-emphasis-color);margin-bottom:4px}
.login-card .sub{font-size:0.929rem;color:var(--bs-secondary-color);margin-bottom:28px}
.login-card .form-label{font-size:0.786rem;font-weight:600;color:var(--bs-secondary-color);text-transform:uppercase;letter-spacing:.4px}
.login-card .form-control{border-radius:8px;padding:10px 14px;font-size:0.929rem}
.login-card .form-control:focus{border-color:var(--ef-primary);box-shadow:0 0 0 3px var(--ef-primary-subtle)}
.btn-login{width:100%;padding:11px;border-radius:8px;font-size:1rem;font-weight:600;background:var(--ef-primary);border:none;color:#fff;cursor:pointer;transition:all .2s}
.btn-login:hover{background:var(--ef-primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(13,110,253,.25)}
.login-divider{display:flex;align-items:center;gap:12px;margin:18px 0;font-size:0.857rem;color:var(--bs-secondary-color)}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--bs-border-color)}
.sso-buttons{display:flex;gap:10px}
.sso-btn{flex:1;padding:9px;border:1px solid var(--bs-border-color);border-radius:8px;background:var(--bs-body-bg);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:0.857rem;color:var(--bs-body-color);transition:all .15s}
.sso-btn:hover{border-color:var(--ef-primary);background:var(--ef-primary-subtle)}
.mfa-hint{margin-top:18px;padding-top:14px;border-top:1px solid var(--bs-border-color);text-align:center;font-size:0.857rem;color:var(--bs-secondary-color)}

/* ===== MODULE SELECTION ===== */
.modules-topbar{padding:14px 32px;background:var(--bs-body-bg);border-bottom:1px solid var(--bs-border-color);display:flex;align-items:center;justify-content:space-between}
.modules-topbar .brand{display:flex;align-items:center;gap:10px}
.modules-topbar .brand .logo-box{width:36px;height:36px;background:var(--ef-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1rem}
.modules-topbar .brand h3{font-size:1.214rem;font-weight:700;color:var(--bs-emphasis-color);margin:0}
.modules-header{padding:24px 32px 0;background:var(--bs-body-bg)}
.modules-header h2{font-size:1.571rem;font-weight:700;color:var(--bs-emphasis-color);margin-bottom:4px}
.modules-header p{font-size:0.929rem;color:var(--bs-secondary-color);margin-bottom:18px}
.domain-tabs{display:flex;gap:8px;flex-wrap:wrap;padding-bottom:14px}
.domain-tab{padding:6px 16px;border-radius:20px;font-size:0.857rem;font-weight:600;cursor:pointer;border:1.5px solid var(--bs-border-color);color:var(--bs-secondary-color);background:transparent;transition:all .2s}
.domain-tab:hover{border-color:var(--ef-primary);color:var(--ef-primary)}
.domain-tab.active{background:var(--ef-primary);color:#fff;border-color:var(--ef-primary)}
.modules-grid-wrap{flex:1;overflow-y:auto;padding:22px 32px;background:var(--bs-tertiary-bg)}
.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px;max-width:960px}
.module-card{background:var(--bs-body-bg);border:1.5px solid var(--bs-border-color);border-radius:12px;padding:20px 16px;text-align:center;cursor:pointer;transition:all .25s;position:relative}
.module-card:hover{border-color:var(--ef-primary);transform:translateY(-3px);box-shadow:0 8px 24px rgba(13,110,253,.1)}
.module-card.selected{border-color:var(--ef-primary);background:var(--ef-primary-subtle)}
.module-card .m-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:1.429rem;color:#fff}
.module-card h4{font-size:0.929rem;font-weight:600;color:var(--bs-emphasis-color);margin-bottom:2px}
.module-card .m-desc{font-size:0.75rem;color:var(--bs-secondary-color);line-height:1.3}
.module-card .m-badge{position:absolute;top:8px;right:8px;font-size:0.643rem;padding:2px 7px;border-radius:10px;font-weight:600}

/* ===== APP BAR ===== */
.app-bar{width:var(--ef-appbar-width);background:var(--ef-appbar-bg);display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:2px;z-index:1050;border-right:1px solid #0f172a;flex-shrink:0;overflow-y:auto;overflow-x:hidden}
.app-bar::-webkit-scrollbar{width:0}
.ab-brand{width:36px;height:36px;background:var(--ef-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;font-weight:800;color:#fff;font-size:0.929rem;flex-shrink:0;cursor:pointer;border:none;transition:all .15s}
.ab-brand:hover{transform:scale(1.06)}
.app-btn{width:42px;height:42px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:#94a3b8;border:none;background:transparent;transition:all .15s;gap:1px;flex-shrink:0}
.app-btn i{font-size:1.214rem}.app-btn span{font-size:0.571rem;line-height:1;white-space:nowrap}
.app-btn:hover{background:rgba(255,255,255,.08);color:#e2e8f0}.app-btn.active{background:var(--ef-primary);color:#fff}
.ab-spacer{flex:1}.ab-sep{width:28px;height:1px;background:rgba(255,255,255,.1);margin:4px 0;flex-shrink:0}

/* ===== SHELL RIGHT ===== */
.shell-right{flex:1;display:flex;flex-direction:column;min-width:0}

/* ===== TOP BAR ===== */
.top-bar{height:var(--ef-topbar-height);background:var(--ef-topbar-bg);border-bottom:1px solid var(--bs-border-color);display:flex;align-items:center;padding:0 12px;gap:8px;flex-shrink:0;transition:background .2s}
.top-bar .module-label{font-size:1rem;font-weight:700;color:var(--bs-emphasis-color);min-width:80px;white-space:nowrap}
.module-tabs{display:flex;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}.module-tabs::-webkit-scrollbar{display:none}
.module-tab{padding:4px 12px;border-radius:6px;font-size:0.857rem;cursor:pointer;border:none;background:transparent;color:var(--bs-secondary-color);white-space:nowrap;transition:all .15s}
.module-tab:hover{background:var(--bs-tertiary-bg);color:var(--bs-emphasis-color)}
.module-tab.active{background:var(--ef-primary-subtle);color:var(--ef-primary);font-weight:600}
.topbar-actions{display:flex;gap:2px;align-items:center}
.icon-btn{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--bs-secondary-color);border:none;background:transparent;transition:all .15s;font-size:1.071rem}
.icon-btn:hover{background:var(--bs-tertiary-bg);color:var(--bs-emphasis-color)}
.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--ef-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:0.786rem;font-weight:700;cursor:pointer;flex-shrink:0}
.ask-ai-btn{display:flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;font-size:0.821rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.ask-ai-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,.3)}.ask-ai-btn i{font-size:1rem}

/* ===== SHELL BODY ===== */
.shell-body{flex:1;display:flex;overflow:hidden}

/* ===== NAV SIDEBAR ===== */
.nav-sidebar{width:var(--ef-sidebar-width);background:var(--bs-body-bg);border-right:1px solid var(--bs-border-color);overflow-y:auto;overflow-x:hidden;transition:width .2s ease;flex-shrink:0;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--bs-border-color) transparent}
.nav-sidebar.collapsed{width:0;min-width:0;border-right:none;overflow:hidden}
.nav-section-label{font-size:0.679rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--bs-secondary-color);padding:14px 14px 4px;white-space:nowrap;overflow:hidden}
.nav-sidebar.collapsed .nav-section-label{opacity:0;height:0;padding:0;margin:0;overflow:hidden}
.nav-item-row{display:flex;align-items:center;gap:10px;padding:6px 14px;cursor:pointer;border-radius:6px;margin:1px 6px;transition:all .12s;color:var(--bs-secondary-color);text-decoration:none;white-space:nowrap;font-size:0.893rem}
.nav-item-row i.nav-icon{font-size:1.071rem;flex-shrink:0;width:18px;text-align:center}
.nav-item-row .nav-text{overflow:hidden;flex:1}
.nav-item-row .nav-arrow{margin-left:auto;font-size:0.714rem;transition:transform .2s;flex-shrink:0}
.nav-item-row .nav-badge{margin-left:auto;font-size:0.714rem;padding:2px 7px;border-radius:10px;background:var(--ef-primary-subtle);color:var(--ef-primary);font-weight:600}
.nav-item-row:hover{background:var(--bs-tertiary-bg);color:var(--bs-emphasis-color)}
.nav-item-row.active{background:var(--ef-primary-subtle);color:var(--ef-primary);font-weight:600}
.nav-sidebar.collapsed .nav-item-row .nav-text,.nav-sidebar.collapsed .nav-arrow,.nav-sidebar.collapsed .nav-badge{display:none}
.nav-sidebar.collapsed .nav-item-row{justify-content:center;padding:8px}
.sub-nav{padding-left:24px;overflow:hidden;transition:max-height .25s ease}.sub-nav.collapsed{max-height:0!important}
.sub-nav .nav-item-row{font-size:0.857rem;padding:4px 10px}.nav-sidebar.collapsed .sub-nav{display:none}

/* Favourites */
.fav-section{border-top:1px solid var(--bs-border-color);margin-top:auto;padding-top:4px}
.fav-item{position:relative}.fav-item .fav-remove{display:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:0.714rem;color:var(--bs-secondary-color);cursor:pointer;padding:2px}
.fav-item:hover .fav-remove{display:block}.fav-item .fav-remove:hover{color:var(--ef-danger)}
.nav-sidebar.collapsed .fav-section{display:none}

/* ===== MAIN CONTENT ===== */
.main-content{flex:1;overflow-y:auto;padding:18px 22px;background:var(--bs-tertiary-bg);font-size:var(--ef-fs);min-width:0}

/* ===== FOOTER ===== */
.bottom-bar{display:none;height:var(--ef-footer-height);background:var(--ef-footer-bg);border-top:1px solid var(--bs-border-color);padding:0 14px;font-size:0.786rem;color:var(--bs-secondary-color);align-items:center;justify-content:space-between;flex-shrink:0;transition:background .2s}
body.fixed-footer .bottom-bar{display:flex}

/* ===== AI PANEL ===== */
.ai-panel{position:fixed;bottom:16px;right:16px;width:380px;max-height:480px;background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:1900;display:none;flex-direction:column;overflow:hidden}
.ai-panel.open{display:flex}
.ai-header{padding:12px 16px;border-bottom:1px solid var(--bs-border-color);display:flex;align-items:center;justify-content:space-between}
.ai-header h6{margin:0;font-size:1rem;font-weight:700;color:var(--bs-emphasis-color);display:flex;align-items:center;gap:6px}.ai-header h6 i{color:#8b5cf6}
.ai-body{flex:1;overflow-y:auto;padding:14px 16px}
.ai-msg{margin-bottom:12px;font-size:0.893rem;line-height:1.5}.ai-msg.user{text-align:right}
.ai-msg.user .ai-bubble{background:var(--ef-primary);color:#fff;display:inline-block;padding:8px 12px;border-radius:12px 12px 2px 12px;max-width:85%;text-align:left}
.ai-msg.bot .ai-bubble{background:var(--bs-tertiary-bg);color:var(--bs-body-color);display:inline-block;padding:8px 12px;border-radius:12px 12px 12px 2px;max-width:85%}
.ai-footer{padding:10px 12px;border-top:1px solid var(--bs-border-color);display:flex;gap:8px}
.ai-footer input{flex:1;border:1px solid var(--bs-border-color);border-radius:8px;padding:8px 12px;font-size:0.893rem;background:var(--bs-body-bg);color:var(--bs-body-color);outline:none}
.ai-footer input:focus{border-color:var(--ef-primary)}
.ai-footer button{padding:8px 14px;border:none;border-radius:8px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;font-size:0.893rem;font-weight:600;cursor:pointer}

/* ===== SEARCH OVERLAY ===== */
.search-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:3000;justify-content:center;padding-top:12vh}
.search-overlay.open{display:flex}
.search-box{width:540px;max-width:90vw;background:var(--bs-body-bg);border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.2);overflow:hidden;max-height:420px}
.search-box input{width:100%;padding:14px 18px;border:none;font-size:1.071rem;background:transparent;color:var(--bs-body-color);outline:none}
.search-results{padding:8px;border-top:1px solid var(--bs-border-color)}
.search-result-item{padding:9px 14px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:0.929rem;color:var(--bs-body-color)}
.search-result-item:hover{background:var(--bs-tertiary-bg)}
.search-result-item i{color:var(--bs-secondary-color);font-size:1rem;width:20px;text-align:center}
.search-result-item .sr-hint{margin-left:auto;font-size:0.786rem;color:var(--bs-secondary-color)}
.search-kbd{font-size:0.786rem;color:var(--bs-secondary-color);padding:8px 16px;display:flex;align-items:center;gap:4px}
.search-kbd kbd{background:var(--bs-tertiary-bg);border:1px solid var(--bs-border-color);border-radius:4px;padding:1px 6px;font-size:0.714rem;font-family:inherit}

/* ===== SETTINGS ===== */
.settings-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:1999}.settings-overlay.open{display:block}
.settings-panel{position:fixed;right:-340px;top:0;bottom:0;width:300px;background:var(--bs-body-bg);border-left:1px solid var(--bs-border-color);z-index:2000;transition:right .25s ease;overflow-y:auto;padding:18px;box-shadow:-4px 0 24px rgba(0,0,0,.1)}
.settings-panel.open{right:0}
.settings-section{margin-bottom:20px}
.settings-title{font-size:0.714rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--bs-secondary-color);margin-bottom:8px}
.color-swatches{display:flex;gap:7px;flex-wrap:wrap}
.color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:transform .15s,border-color .15s}
.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--bs-emphasis-color);transform:scale(1.1)}
.layout-option{display:flex;align-items:center;gap:8px;padding:7px 11px;border:1px solid var(--bs-border-color);border-radius:8px;cursor:pointer;margin-bottom:6px;transition:all .15s;font-size:0.893rem;color:var(--bs-body-color)}
.layout-option:hover{border-color:var(--ef-primary)}.layout-option.selected{border-color:var(--ef-primary);background:var(--ef-primary-subtle);color:var(--ef-primary)}
.font-btn{padding:5px 14px;border:1px solid var(--bs-border-color);border-radius:6px;cursor:pointer;font-size:0.893rem;background:transparent;color:var(--bs-body-color);transition:all .15s}
.font-btn:hover{border-color:var(--ef-primary)}.font-btn.selected{background:var(--ef-primary);color:#fff;border-color:var(--ef-primary)}
.lang-select{width:100%;padding:7px 12px;border-radius:8px;border:1px solid var(--bs-border-color);background:var(--bs-body-bg);color:var(--bs-body-color);font-size:0.893rem}

/* ===== CONTENT COMPONENTS ===== */
.content-card{background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:10px;padding:14px;margin-bottom:12px}
.content-card h5{font-size:0.929rem;font-weight:600;margin-bottom:10px;color:var(--bs-emphasis-color)}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.kpi-card{background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:10px;padding:13px 15px;transition:transform .2s}.kpi-card:hover{transform:translateY(-2px)}
.kpi-card .kpi-label{font-size:0.75rem;color:var(--bs-secondary-color);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:4px}
.kpi-card .kpi-value{font-size:1.5rem;font-weight:700;color:var(--bs-emphasis-color)}
.kpi-card .kpi-change{font-size:0.786rem;margin-top:2px}
.kpi-change.up{color:#198754}.kpi-change.down{color:#dc3545}.kpi-change.warn{color:#e67e22}
.badge-pill{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:0.786rem;font-weight:500}
.data-table{width:100%;border-collapse:collapse;font-size:0.857rem}
.data-table th{font-weight:600;color:var(--bs-secondary-color);text-align:left;padding:7px 12px;border-bottom:1px solid var(--bs-border-color);font-size:0.75rem;text-transform:uppercase;letter-spacing:.04em}
.data-table td{padding:8px 12px;border-bottom:1px solid var(--bs-border-color);color:var(--bs-body-color)}
.data-table tbody tr:hover{background:var(--bs-tertiary-bg)}

/* ===== RESPONSIVE ===== */
@media(max-width:992px){.kpi-row{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr!important}}
@media(max-width:768px){.page-login.active{flex-direction:column}.login-left{min-height:auto;padding:28px 24px}.login-right{min-height:auto;padding:28px 20px}.login-stats{display:none}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.ai-panel{width:calc(100vw - 32px);right:16px}}
@media(max-width:480px){.app-bar{width:44px}:root{--ef-appbar-width:44px}.modules-header{padding:18px 16px 0}.modules-grid-wrap{padding:14px}.ask-ai-btn .ai-label{display:none}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .3s ease forwards}
@media print{.app-bar,.top-bar,.nav-sidebar,.bottom-bar,.ai-panel,.search-overlay,.settings-panel,.settings-overlay{display:none!important}.shell-body{display:block!important}.main-content{padding:0!important;overflow:visible!important}}

/* Header selector pill hover */
.header-selector{border:1px solid transparent;transition:all .15s;border-radius:6px;padding:4px 8px}
.header-selector:hover{border-color:var(--bs-border-color);background:var(--bs-tertiary-bg)}

/* Header/Footer with dark backgrounds — auto light text */
.top-bar.dark-header,.top-bar.dark-header .module-label,.top-bar.dark-header .icon-btn,
.top-bar.dark-header .header-selector span,.top-bar.dark-header .header-selector strong,
.top-bar.dark-header .header-selector div{color:#e2e8f0 !important}
.top-bar.dark-header .header-selector i{color:#94a3b8 !important}
.top-bar.dark-header .header-selector:hover{border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.08)}
.top-bar.dark-header{border-bottom-color:rgba(255,255,255,.08)}
.bottom-bar.dark-footer,.bottom-bar.dark-footer span{color:#cbd5e1 !important}
.bottom-bar.dark-footer{border-top-color:rgba(255,255,255,.08)}

/* ============================================================
   BACKWARD COMPAT — Admin Portal pages (tenant-registry, etc.)
   These pages use the classic sidebar layout pattern
   ============================================================ */
.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#1E293B;z-index:1050;transition:all .25s ease;overflow:hidden;display:flex;flex-direction:column}
.sidebar-brand{height:60px;border-bottom:1px solid rgba(255,255,255,.06)}
.brand-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--ef-primary),#3B82F6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0}
.brand-text{font-size:1.15rem;color:#fff;letter-spacing:-.02em}.brand-sub{font-weight:300;opacity:.7;margin-left:2px}
.sidebar-search-group{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden}
.sidebar-search-group .input-group-text{background:transparent;border:none;color:#94A3B8;padding:6px 10px}
.sidebar-search-group .form-control{background:transparent;border:none;color:#fff;font-size:.8rem;padding:6px 8px}
.sidebar-search-group .form-control::placeholder{color:#94A3B8;opacity:.6}.sidebar-search-group .form-control:focus{box-shadow:none}
.sidebar-nav{padding:.5rem 0;flex-grow:1;overflow-y:auto}
.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}
.nav-section-title{padding:.75rem 1.25rem .4rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#94A3B8;opacity:.5}
.nav-link-sidebar{display:flex;align-items:center;padding:.55rem 1.25rem;color:#94A3B8;font-size:.85rem;transition:all .15s;gap:.75rem;border-left:3px solid transparent}
.nav-link-sidebar i:first-child{width:20px;text-align:center;font-size:1rem;flex-shrink:0}
.nav-link-sidebar:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-item.active>.nav-link-sidebar{color:#fff;background:rgba(13,110,253,.15);border-left-color:var(--ef-primary);font-weight:500}
.nav-link-sidebar .chevron-icon{font-size:.7rem;transition:transform .2s}
.nav-link-sidebar[aria-expanded="true"] .chevron-icon{transform:rotate(180deg)}
.nav-link-sidebar .badge{font-size:.6rem;font-weight:600;padding:.2em .5em}
.submenu{padding-left:0}.submenu li a{display:block;padding:.4rem 1.25rem .4rem 3.25rem;font-size:.8rem;color:#94A3B8;transition:all .15s;position:relative}
.submenu li a::before{content:'';position:absolute;left:2.25rem;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:#94A3B8;opacity:.3;transition:all .15s}
.submenu li a:hover{color:#fff;background:rgba(255,255,255,.06)}.submenu li a:hover::before{background:var(--ef-primary);opacity:1}
.sidebar-footer{border-top:1px solid rgba(255,255,255,.06);padding:1rem}
.sidebar-user-avatar{font-size:1.5rem;color:#94A3B8}.sidebar-user-info .small{color:#94A3B8}
.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:1045;backdrop-filter:blur(2px)}.sidebar-overlay.show{display:block}

/* Main wrapper for classic sidebar layout */
.main-wrapper{margin-left:260px;min-height:100vh;transition:margin-left .25s ease}
.top-navbar{height:60px;background:var(--bs-body-bg);box-shadow:0 1px 3px rgba(0,0,0,.08);z-index:1040;margin-left:260px;transition:margin-left .25s ease;display:flex;align-items:center}
.page-content{padding:calc(60px + 1.5rem) 1.5rem 1.5rem;min-height:calc(100vh - 60px)}
.page-footer{padding:1rem 1.5rem;border-top:1px solid var(--bs-border-color)}
.page-footer a{color:var(--ef-primary)}

/* Navbar search */
.navbar-search{max-width:420px}.navbar-search .input-group{background:var(--bs-tertiary-bg);border-radius:8px;border:1px solid var(--bs-border-color);overflow:hidden}
.navbar-search .input-group-text{background:transparent;border:none;color:var(--bs-secondary-color);padding:.4rem .75rem}
.navbar-search .form-control{background:transparent;border:none;font-size:.85rem;padding:.4rem .5rem;color:var(--bs-body-color)}.navbar-search .form-control:focus{box-shadow:none}
.btn-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--bs-secondary-color);background:transparent;border:none;position:relative;transition:all .15s}
.btn-icon:hover{background:var(--bs-tertiary-bg);color:var(--ef-primary)}
.notification-badge{font-size:.55rem;padding:.15em .4em;transform:translate(-50%,-25%)!important}
.notification-dropdown{width:360px;border:1px solid var(--bs-border-color);box-shadow:0 10px 40px rgba(0,0,0,.12);border-radius:12px;overflow:hidden}
.notification-item{display:flex!important;gap:.75rem;padding:.75rem 1rem!important;border-bottom:1px solid var(--bs-border-color)}
.notification-item.unread{background:rgba(13,110,253,.04)}
.notification-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem}
.avatar-circle{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--ef-primary),#3B82F6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}
.user-dropdown-btn{border:none;background:transparent;padding:4px 8px;border-radius:8px}.user-dropdown-btn:hover{background:var(--bs-tertiary-bg)}
.sidebar-toggle{color:var(--bs-secondary-color);padding:0;border:none}.sidebar-toggle:hover{color:var(--ef-primary)}

/* Cards for admin pages */
.card{background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:.5rem;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.card-header{border-bottom:1px solid var(--bs-border-color);padding:.85rem 1.25rem}
.card-title{font-weight:600;font-size:.9rem;color:var(--bs-emphasis-color)}
.kpi-card{transition:transform .2s,box-shadow .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.kpi-label{font-size:.78rem;font-weight:500;color:var(--bs-secondary-color);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.35rem}
.kpi-value{font-size:1.75rem;font-weight:700;color:var(--bs-emphasis-color);line-height:1.2;letter-spacing:-.02em}
.kpi-change{font-size:.78rem;font-weight:500;margin-top:.35rem}
.kpi-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.kpi-card-mini{transition:transform .2s}.kpi-card-mini:hover{transform:translateY(-1px)}
.kpi-mini-value{font-size:1.25rem;font-weight:700;color:var(--bs-emphasis-color)}
.kpi-mini-label{font-size:.72rem;font-weight:500;color:var(--bs-secondary-color);text-transform:uppercase;letter-spacing:.02em}
.tenant-avatar{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px}
.activity-feed{padding:0}.activity-item{display:flex;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--bs-border-color);position:relative}
.activity-item:last-child{border-bottom:none}.activity-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}
.filter-bar{background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:.5rem;padding:1rem;margin-bottom:1rem}

/* Tables */
.table{font-size:.85rem}.table thead th{font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;color:var(--bs-secondary-color);border-bottom-width:1px;padding:.75rem 1rem}
.table tbody td{padding:.75rem 1rem;vertical-align:middle;border-bottom:1px solid var(--bs-border-color);color:var(--bs-body-color)}
.table-hover tbody tr:hover{background:rgba(13,110,253,.03)}
.badge{font-weight:600;font-size:.7rem;padding:.3em .65em;border-radius:5px;letter-spacing:.02em}

/* Buttons */
.btn{font-size:.85rem;font-weight:500;border-radius:6px;padding:.45rem 1rem;transition:all .15s}
.btn-primary{background:var(--ef-primary);border-color:var(--ef-primary)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(13,110,253,.25)}
.btn-sm{font-size:.78rem;padding:.3rem .75rem}

/* Forms */
.form-control,.form-select{border:1px solid var(--bs-border-color);border-radius:6px;font-size:.85rem;padding:.5rem .75rem;color:var(--bs-body-color);background-color:var(--bs-body-bg);transition:border-color .15s,box-shadow .15s}
.form-control:focus,.form-select:focus{border-color:var(--ef-primary);box-shadow:0 0 0 3px rgba(13,110,253,.12)}
.form-label{font-size:.8rem;font-weight:600;color:var(--bs-secondary-color);margin-bottom:.35rem}

/* Tabs (wizard) */
.nav-tabs{border-bottom:2px solid var(--bs-border-color)}
.nav-tabs .nav-link{font-size:.85rem;font-weight:500;color:var(--bs-secondary-color);border:none;border-bottom:2px solid transparent;padding:.6rem 1rem;margin-bottom:-2px;transition:all .15s}
.nav-tabs .nav-link:hover{color:var(--ef-primary);border-bottom-color:rgba(13,110,253,.3)}
.nav-tabs .nav-link.active{color:var(--ef-primary);border-bottom-color:var(--ef-primary);background:transparent;font-weight:600}

/* Wizard steps */
.wizard-steps{display:flex;gap:0;counter-reset:step}
.wizard-step{flex:1;text-align:center;position:relative;padding:1rem .5rem;cursor:pointer}
.wizard-step::before{counter-increment:step;content:counter(step);width:32px;height:32px;border-radius:50%;background:var(--bs-tertiary-bg);border:2px solid var(--bs-border-color);display:flex;align-items:center;justify-content:center;margin:0 auto .4rem;font-size:.8rem;font-weight:600;color:var(--bs-secondary-color);transition:all .2s}
.wizard-step.active::before{background:var(--ef-primary);border-color:var(--ef-primary);color:#fff}
.wizard-step.completed::before{background:var(--ef-success);border-color:var(--ef-success);color:#fff;content:'\2713'}
.wizard-step-label{font-size:.72rem;font-weight:500;color:var(--bs-secondary-color)}
.wizard-step.active .wizard-step-label{color:var(--ef-primary);font-weight:600}
.wizard-step.completed .wizard-step-label{color:var(--ef-success)}
.wizard-step:not(:last-child)::after{content:'';position:absolute;top:calc(1rem + 16px);left:calc(50% + 20px);width:calc(100% - 40px);height:2px;background:var(--bs-border-color)}
.wizard-step.completed:not(:last-child)::after{background:var(--ef-success)}

/* Auth pages */
.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1E293B,#0F172A);padding:2rem}
.auth-card{width:100%;max-width:420px;background:var(--bs-body-bg);border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.auth-brand{text-align:center;margin-bottom:2rem}
.auth-brand-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--ef-primary),#3B82F6);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;margin-bottom:.75rem}

/* Modals */
.modal-content{border:none;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-header{border-bottom:1px solid var(--bs-border-color);padding:1rem 1.5rem}.modal-title{font-weight:600;font-size:1rem}
.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--bs-border-color);padding:1rem 1.5rem}

/* System health */
.system-health-card{transition:transform .2s}.system-health-card:hover{transform:translateY(-2px)}
.progress{border-radius:4px;background:var(--bs-tertiary-bg)}
.page-title{font-weight:700;color:var(--bs-emphasis-color);font-size:1.35rem;letter-spacing:-.01em}

/* Responsive for classic sidebar */
@media(max-width:991.98px){.sidebar{transform:translateX(-100%)}.sidebar.show{transform:translateX(0)}.main-wrapper{margin-left:0}.top-navbar{margin-left:0}.sidebar-toggle{display:inline-flex}}
@media(min-width:992px){.sidebar-close-btn{display:none!important}.sidebar-toggle{display:none}}
@media(max-width:575.98px){.page-content{padding:calc(60px + 1rem) 1rem 1rem}}

/* ============================================================
   AI-NATIVE UI ADDITIONS v2.0
   ============================================================ */
/* AI Colors */
:root{--ai:#8b5cf6;--ai2:#6366f1;--ai-s:rgba(139,92,246,.08);--ai-s2:rgba(139,92,246,.15)}

/* AI Pulse */
@keyframes aiPulse{0%,100%{box-shadow:0 0 0 0 rgba(139,92,246,.3)}50%{box-shadow:0 0 0 6px rgba(139,92,246,0)}}
.ai-pulse{animation:aiPulse 2s infinite}

/* Health dots on app-bar */
.app-btn .health-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;border:1.5px solid #0f172a}

/* AI Command Bar (replaces Ask AI button in header) */
.ai-cmd-bar{flex:1;max-width:400px;display:flex;align-items:center;gap:6px;padding:0 10px;height:30px;border:1px solid var(--bs-border-color);border-radius:8px;background:var(--bs-tertiary-bg);transition:all .2s;cursor:text}
.ai-cmd-bar:hover,.ai-cmd-bar:focus-within{border-color:var(--ai);box-shadow:0 0 0 2px var(--ai-s)}
.ai-cmd-bar i{color:var(--ai);font-size:0.857rem;flex-shrink:0}
.ai-cmd-bar input{flex:1;border:none;background:transparent;font-size:0.786rem;color:var(--bs-body-color);outline:none;font-family:inherit}
.ai-cmd-bar input::placeholder{color:var(--bs-secondary-color)}
.ai-cmd-bar kbd{font-size:0.571rem;padding:1px 5px;border:1px solid var(--bs-border-color);border-radius:3px;background:var(--bs-body-bg);color:var(--bs-secondary-color);font-family:inherit;flex-shrink:0}

/* AI Anomaly Alert */
.ai-alert{padding:10px 14px;border-radius:10px;margin-bottom:12px;display:flex;align-items:flex-start;gap:10px;font-size:0.821rem;line-height:1.5}
.ai-alert.warn{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);color:#92400e}
.ai-alert i.ai-alert-icon{font-size:1rem;margin-top:1px;flex-shrink:0;color:var(--ai)}
.ai-alert a{color:var(--ai);font-weight:600;cursor:pointer}

/* AI Micro-Insight on KPI cards */
.kpi-card .ai-micro{font-size:0.643rem;color:var(--ai);margin-top:5px;padding:4px 8px;background:var(--ai-s);border-radius:6px;line-height:1.35}
.kpi-card .ai-micro i{font-size:0.607rem}

/* AI Prediction Row */
.ai-pred-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.ai-pred{background:var(--bs-body-bg);border:1px solid var(--ai-s2);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px}
.ai-pred .pred-ic{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--ai),var(--ai2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:0.857rem;flex-shrink:0}
.ai-pred .pred-label{font-size:0.643rem;color:var(--bs-secondary-color);text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.ai-pred .pred-val{font-size:1rem;font-weight:700;color:var(--bs-emphasis-color)}
.ai-pred .pred-conf{font-size:0.571rem;color:var(--ai);font-weight:600}
.conf-bar{display:flex;gap:2px;margin-top:2px}.conf-bar span{height:3px;border-radius:2px;flex:1}
.conf-bar .high{background:#16a34a}.conf-bar .med{background:#f59e0b}.conf-bar .low{background:#d1d5db}

/* AI Quick Actions Strip */
.ai-qstrip{display:flex;gap:8px;overflow-x:auto;padding:8px 0;margin-bottom:12px;scrollbar-width:none}
.ai-qstrip::-webkit-scrollbar{display:none}
.ai-qa{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;background:var(--bs-body-bg);border:1px solid var(--bs-border-color);font-size:0.786rem;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}
.ai-qa:hover{border-color:var(--ai);background:var(--ai-s);color:var(--ai)}
.ai-qa i{color:var(--ai);font-size:0.857rem}
.ai-qa .qa-type{font-size:0.571rem;padding:1px 5px;border-radius:4px;background:var(--ai-s);color:var(--ai);font-weight:600}

/* AI Insights Card */
.ai-insights{background:linear-gradient(135deg,rgba(139,92,246,.04),rgba(99,102,241,.02));border:1px solid var(--ai-s2);border-radius:12px;padding:14px 18px;margin-bottom:12px}
.ai-insights h5{font-size:0.857rem;font-weight:700;color:var(--bs-emphasis-color);display:flex;align-items:center;gap:6px;margin-bottom:10px}
.ai-insights h5 i{color:var(--ai)}
.ai-insight-item{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid var(--bs-border-color);font-size:0.786rem;line-height:1.4;color:var(--bs-body-color)}
.ai-insight-item:last-child{border-bottom:none}
.ai-insight-item .ins-num{width:20px;height:20px;border-radius:50%;background:var(--ai-s);color:var(--ai);display:flex;align-items:center;justify-content:center;font-size:0.643rem;font-weight:700;flex-shrink:0;margin-top:1px}

/* AI Flag in tables */
.ai-flag{display:flex;gap:4px;align-items:center}
.ai-flag .flag{font-size:0.679rem;padding:1px 5px;border-radius:4px;font-weight:600}
.ai-flag .flag.anomaly{background:rgba(245,158,11,.1);color:#d97706}
.ai-flag .flag.dup{background:rgba(99,102,241,.1);color:var(--ai2)}

/* Sidebar AI Suggested section */
.ai-suggest-sec{background:linear-gradient(180deg,var(--ai-s),transparent);padding:4px 0;border-top:1px solid var(--ai-s2);border-bottom:1px solid var(--ai-s2);margin:4px 0}
.nav-item-row .nav-badge.ai-badge{background:var(--ai-s);color:var(--ai)}
.nav-item-row .nav-badge.warn-badge{background:rgba(245,158,11,.1);color:#d97706}

/* AI Security Badge (login page) */
.ai-security-badge{margin-top:16px;padding:10px 14px;border-radius:10px;background:var(--ai-s);border:1px solid var(--ai-s2);font-size:0.786rem;color:var(--bs-body-color);display:flex;align-items:flex-start;gap:8px}
.ai-security-badge i{color:var(--ai);font-size:1rem;margin-top:1px}

/* AI Briefing (module selection page) */
.ai-briefing{margin:0 28px 14px;padding:14px 18px;border-radius:12px;background:linear-gradient(135deg,rgba(139,92,246,.06),rgba(99,102,241,.04));border:1px solid var(--ai-s2);display:flex;gap:14px;align-items:flex-start}
.ai-briefing .ai-brief-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--ai),var(--ai2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0}
.ai-briefing .ai-brief-body{flex:1;font-size:0.821rem;line-height:1.5;color:var(--bs-body-color)}
.ai-brief-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.ai-brief-actions button{padding:4px 10px;border-radius:16px;font-size:0.679rem;font-weight:600;cursor:pointer;border:1px solid var(--bs-border-color);background:var(--bs-body-bg);color:var(--bs-secondary-color);transition:all .15s}
.ai-brief-actions button:hover{border-color:var(--ai);color:var(--ai);background:var(--ai-s)}

/* Module card AI count badge */
.module-card .ai-count{position:absolute;top:7px;right:7px;font-size:0.571rem;padding:2px 7px;border-radius:10px;font-weight:700;background:var(--ai-s);color:var(--ai)}
.module-card .ai-count.urgent{background:rgba(220,53,69,.1);color:#dc3545}
.module-card .ai-count.warn{background:rgba(245,158,11,.1);color:#d97706}

/* AI domain tab */
.domain-tab.ai-tab{background:linear-gradient(135deg,var(--ai),var(--ai2));color:#fff;border-color:var(--ai)}

/* Co-Pilot Panel (docked right) */
.copilot-panel{position:fixed;right:0;top:0;bottom:0;width:0;background:var(--bs-body-bg);border-left:1px solid var(--bs-border-color);z-index:1060;transition:width .25s ease;overflow:hidden;display:flex;flex-direction:column}
.copilot-panel.open{width:360px}
.cp-header{padding:12px 14px;border-bottom:1px solid var(--bs-border-color);display:flex;align-items:center;gap:8px;flex-shrink:0}
.cp-header .cp-icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--ai),var(--ai2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:0.857rem}
.cp-header h6{margin:0;font-size:0.857rem;font-weight:700;flex:1}
.cp-chips{padding:8px 12px;border-bottom:1px solid var(--bs-border-color);display:flex;flex-wrap:wrap;gap:4px}
.cp-chip{padding:3px 9px;border-radius:14px;font-size:0.679rem;border:1px solid var(--bs-border-color);background:transparent;color:var(--bs-secondary-color);cursor:pointer;transition:all .15s}
.cp-chip:hover{border-color:var(--ai);color:var(--ai);background:var(--ai-s)}
.cp-chat{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
.cp-msg-ai{align-self:flex-start;max-width:90%;padding:9px 12px;border-radius:12px 12px 12px 3px;background:var(--ai-s);border:1px solid var(--ai-s2);color:var(--bs-body-color);font-size:0.821rem;line-height:1.5;white-space:pre-wrap}
.cp-msg-user{align-self:flex-end;max-width:85%;padding:9px 12px;border-radius:12px 12px 3px 12px;background:var(--ef-primary);color:#fff;font-size:0.821rem;line-height:1.5}
.cp-input{padding:10px 12px;border-top:1px solid var(--bs-border-color);display:flex;gap:6px}
.cp-input input{flex:1;border:1px solid var(--bs-border-color);border-radius:8px;padding:8px 10px;font-size:0.821rem;background:var(--bs-body-bg);color:var(--bs-body-color);outline:none;font-family:inherit}
.cp-input input:focus{border-color:var(--ai)}
.cp-input button{padding:8px 12px;border:none;border-radius:8px;background:linear-gradient(135deg,var(--ai),var(--ai2));color:#fff;font-size:0.821rem;font-weight:600;cursor:pointer}

/* Fav stats */
.fav-stat{font-size:0.571rem;color:var(--bs-secondary-color);font-weight:400;margin-left:4px}

/* AI Settings section */
.ai-setting-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--bs-border-color);border-radius:8px;margin-bottom:5px;font-size:0.821rem;color:var(--bs-body-color)}
.ai-setting-row i{color:var(--ai)}
.ai-setting-row .ai-toggle{margin-left:auto}

/* Responsive for AI */
@media(max-width:992px){.ai-pred-row{grid-template-columns:1fr}}
@media(max-width:768px){.copilot-panel.open{width:100%}.ai-cmd-bar{max-width:180px}}

/* ============================================================
   COMPREHENSIVE RESPONSIVE OVERHAUL
   Mobile (≤576px) → Tablet (≤768px) → Small Laptop (≤992px) → Desktop
   ============================================================ */

/* Mobile sidebar overlay */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1055;backdrop-filter:blur(2px)}
.sidebar-overlay.show{display:block}

/* Hamburger button (visible only on mobile/tablet) */
.hamburger-btn{display:none}

/* Top bar needs to allow wrapping and scrolling */
.top-bar{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.top-bar::-webkit-scrollbar{display:none}

/* Items that can be hidden at breakpoints */
.hide-mobile{} .hide-tablet{}

/* ===== Small Laptops / Large Tablets (≤1200px) ===== */
@media(max-width:1200px){
  .header-selector strong{font-size:0.714rem!important}
  .ask-ai-btn .ai-label{display:none}
  .nav-sidebar{--ef-sidebar-width:200px;width:200px}
}

/* ===== Tablets (≤992px) ===== */
@media(max-width:992px){
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .ai-pred-row{grid-template-columns:1fr 1fr 1fr}
  .charts-grid{grid-template-columns:1fr!important}
  /* Sidebar becomes overlay on tablet */
  .nav-sidebar{position:fixed;left:var(--ef-appbar-width);top:var(--ef-topbar-height);bottom:0;z-index:1056;width:var(--ef-sidebar-width);transform:translateX(-110%);transition:transform .25s ease;box-shadow:4px 0 20px rgba(0,0,0,.15);background:var(--bs-body-bg)}
  .nav-sidebar.show{transform:translateX(0);overflow-y:auto}
  .nav-sidebar.show .nav-item-row .nav-text,
  .nav-sidebar.show .nav-arrow,
  .nav-sidebar.show .nav-badge,
  .nav-sidebar.show .nav-section-label,
  .nav-sidebar.show .fav-section{display:flex!important}
  .nav-sidebar.show .nav-section-label{display:flex!important;opacity:1!important;height:auto!important;padding:12px 14px 3px!important}
  .nav-sidebar.show .nav-item-row{justify-content:flex-start!important;padding:6px 14px!important}
  .nav-sidebar.show .nav-item-row .nav-text{display:inline!important}
  .nav-sidebar.show .sub-nav{display:block!important}
  .nav-sidebar.collapsed,.nav-sidebar.off{transform:translateX(-110%)}
  .hamburger-btn{display:flex}
  /* Hide company name text on tablet */
  .hide-tablet{display:none!important}
}

/* ===== Mobile Landscape & Portrait (≤768px) ===== */
@media(max-width:768px){
  /* App bar becomes horizontal bottom bar on mobile */
  .page-shell.active{flex-direction:column}
  .app-bar{width:100%;height:50px;flex-direction:row;padding:0 4px;overflow-x:auto;overflow-y:hidden;order:2;border-right:none;border-top:1px solid rgba(255,255,255,.06)}
  .app-bar::-webkit-scrollbar{display:none}
  .ab-brand{width:32px;height:32px;margin:0 4px 0 0;font-size:0.714rem;border-radius:6px}
  .app-btn{width:38px;height:38px;border-radius:6px}
  .app-btn i{font-size:0.929rem}
  .app-btn span{display:none}
  .ab-spacer{display:none}
  .ab-sep{width:1px;height:24px;margin:0 2px}
  .app-btn .health-dot{top:3px;right:3px;width:5px;height:5px}

  /* Shell right takes full width and fills remaining height */
  .shell-right{order:1;width:100%;flex:1;min-height:0;overflow:hidden}

  /* Top bar responsive */
  .top-bar{height:auto;min-height:42px;padding:6px 8px;gap:4px;flex-wrap:wrap}
  .icon-btn{width:28px;height:28px;font-size:0.857rem}
  .topbar-avatar{width:26px;height:26px;font-size:0.607rem}
  .topbar-actions{gap:1px}
  .ask-ai-btn{padding:3px 8px;font-size:0.679rem}
  .ask-ai-btn .ai-label{display:none}

  /* Sidebar overlay on mobile */
  .nav-sidebar{position:fixed;left:0;top:0;bottom:50px;z-index:1056;width:260px;transform:translateX(-110%);transition:transform .25s ease;box-shadow:4px 0 24px rgba(0,0,0,.2);background:var(--bs-body-bg)}
  .nav-sidebar.show{transform:translateX(0);width:260px;overflow-y:auto}
  .nav-sidebar.show .nav-item-row .nav-text,
  .nav-sidebar.show .nav-arrow,
  .nav-sidebar.show .nav-badge,
  .nav-sidebar.show .nav-section-label,
  .nav-sidebar.show .fav-section{display:flex!important}
  .nav-sidebar.show .nav-section-label{display:flex!important;opacity:1!important;height:auto!important;padding:12px 14px 3px!important}
  .nav-sidebar.show .nav-item-row{justify-content:flex-start!important;padding:6px 14px!important}
  .nav-sidebar.show .nav-item-row .nav-text{display:inline!important}
  .nav-sidebar.show .sub-nav{display:block!important}
  .nav-sidebar.collapsed,.nav-sidebar.off{transform:translateX(-110%);width:260px}
  .sidebar-overlay{z-index:1055}

  /* Content area */
  .main-content{padding:12px 10px}
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:8px}
  .ai-pred-row{grid-template-columns:1fr}
  .content-card{padding:10px}
  .ai-insights{padding:10px 12px}
  .ai-qstrip{padding:6px 0}

  /* Login */
  .page-login.active,.login-wrap{flex-direction:column!important}
  .login-l,.login-left{min-height:auto!important;padding:24px 20px!important}
  .login-r,.login-right{min-height:auto!important;padding:24px 16px!important}
  .login-stats{display:none!important}

  /* Module selection */
  .modules-topbar{padding:10px 14px;flex-wrap:wrap;gap:8px}
  .modules-header,.mod-head{padding:14px 14px 0!important}
  .modules-grid-wrap,.mod-grid-wrap{padding:12px 14px!important}
  .modules-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))!important;gap:10px!important}
  .ai-briefing{margin:0 14px 10px!important;padding:10px 12px!important;flex-direction:column;gap:8px}
  .ai-brief-icon{width:28px;height:28px;font-size:0.857rem}

  /* Co-pilot full width on mobile */
  .copilot-panel.open{width:100%!important}
  .settings-panel.open,.set-pan.open{width:100%!important}

  /* Search overlay */
  .search-box{max-width:95vw!important}

  /* Data tables scroll horizontally */
  .data-table{display:block;overflow-x:auto;white-space:nowrap}
}

/* ===== Small Mobile (≤480px) ===== */
@media(max-width:480px){
  .app-bar{height:46px}
  .app-btn{width:34px;height:34px}
  .ab-brand{width:28px;height:28px;font-size:0.607rem}

  /* Top bar — hide less important items */
  .top-bar .ef-logo-text{display:none}
  .top-bar .ef-separator{display:none}

  /* KPIs stack single column */
  .kpi-row{grid-template-columns:1fr 1fr}
  .kpi-card .kpi-value{font-size:1.143rem}
  .kpi-card .ai-micro{font-size:0.571rem}

  /* Module cards smaller */
  .modules-grid{grid-template-columns:repeat(3,1fr)!important}
  .module-card{padding:12px 8px}
  .module-card .m-icon{width:36px;height:36px;font-size:0.929rem}
  .module-card h4{font-size:0.714rem}
  .module-card .m-desc{display:none}

  .ai-alert{font-size:0.714rem;padding:8px 10px}
}

/* ===== Very Small (≤360px) ===== */
@media(max-width:360px){
  .kpi-row{grid-template-columns:1fr}
  .modules-grid{grid-template-columns:repeat(2,1fr)!important}
  .header-selector{display:none!important}
}
