.modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:500;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);animation:fade-in .15s ease}.mbox{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius);width:92%;max-width:600px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slide-up .18s ease}.mbox.wide{max-width:780px}.mbox.xl{max-width:960px}.mhdr{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card);z-index:10}.mhdr h3{font-family:Syne,sans-serif;font-size:15px;font-weight:700;flex:1}.mcls{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;transition:color .15s}.mcls:hover{color:#f87171}.mbody{padding:16px 20px}.mftr{display:flex;gap:8px;justify-content:flex-end;padding:12px 20px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--bg-card)}.btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.btn-p{background:var(--accent-teal);color:#000}.btn-p:hover{background:#00bfa0}.btn-g{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.btn-g:hover{border-color:var(--border-bright);color:var(--text-primary)}.btn-r{background:var(--accent-red-dim);border:1px solid #ef444428;color:#f87171}.btn-r:hover{background:#ef444422}.btn-o{background:var(--accent-orange-dim);border:1px solid var(--accent-orange);color:var(--accent-orange)}.btn-o:hover{background:var(--accent-orange);color:#000}.fg{margin-bottom:10px}.fg label{display:block;font-size:10.5px;font-weight:700;color:var(--text-secondary);margin-bottom:5px;letter-spacing:.5px;text-transform:uppercase}.fgi{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 11px;font-size:13px;color:var(--text-primary);outline:none;transition:all .18s}.fgi:focus{border-color:var(--accent-teal)}.fr2{display:grid;grid-template-columns:1fr 1fr;gap:8px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}:root{--bg-deep: #060d1a;--bg-card: #0c1626;--bg-elevated: #112035;--bg-hover: #162843;--border: #1e3452;--border-bright: #2a4a72;--accent-teal: #00d4aa;--accent-teal-dim: #00d4aa22;--accent-blue: #2b7fff;--accent-blue-dim: #2b7fff20;--accent-orange: #ff6b2b;--accent-orange-dim: #ff6b2b22;--accent-amber: #f59e0b;--accent-amber-dim: #f59e0b18;--accent-red: #ef4444;--accent-red-dim: #ef444418;--accent-green: #22c55e;--accent-green-dim: #22c55e18;--accent-purple: #a855f7;--accent-purple-dim: #a855f718;--text-primary: #e8f0fe;--text-secondary: #7a9bc4;--text-muted: #3d5a7a;--sidebar-w: 260px;--header-h: 64px;--radius: 12px;--radius-sm: 8px}:root[data-theme=light]{--bg-deep: #f0f4f8;--bg-card: #ffffff;--bg-elevated: #f8fafc;--bg-hover: #e8f0fe;--border: #d1dce8;--border-bright: #a0b4cc;--text-primary: #0f1f35;--text-secondary: #4a6580;--text-muted: #8aa0b8;--accent-teal: #00a88a;--accent-teal-dim: #00a88a18;--accent-blue: #1a6ff0;--accent-blue-dim: #1a6ff015;--accent-orange: #e05a1a;--accent-orange-dim: #e05a1a15;--accent-amber: #c97f00;--accent-amber-dim: #c97f0015;--accent-red: #d93025;--accent-red-dim: #d9302515;--accent-green: #1a9c48;--accent-green-dim: #1a9c4815;--accent-purple: #8b3fd9;--accent-purple-dim: #8b3fd915}.theme-toggle{font-size:18px;transition:transform .3s ease}.theme-toggle:hover{transform:rotate(20deg) scale(1.1)}:root[data-theme=light] body{background:var(--bg-deep);color:var(--text-primary)}:root[data-theme=light] .sidebar{background:var(--bg-card);border-color:var(--border);box-shadow:2px 0 12px #00000014}:root[data-theme=light] .sidebar:before{background:radial-gradient(circle,#00a88a12 0%,transparent 70%)}:root[data-theme=light] .header{background:var(--bg-card);border-color:var(--border);box-shadow:0 1px 8px #0000000f}:root[data-theme=light] th{background:var(--bg-elevated)}:root[data-theme=light] .nav-item.active{background:var(--accent-teal-dim);color:var(--accent-teal)}:root[data-theme=light] .store-pill{background:var(--bg-elevated);border-color:var(--border)}:root[data-theme=light] .card{box-shadow:0 1px 6px #0000000f}:root[data-theme=light] .stat-card{box-shadow:0 1px 6px #0000000f}:root[data-theme=light] .mbox{box-shadow:0 8px 40px #00000026}:root[data-theme=light] .search-bar{background:var(--bg-elevated)}:root[data-theme=light] .icon-btn{background:var(--bg-elevated)}:root[data-theme=light] .tab-row{background:var(--bg-elevated)}:root[data-theme=light] .form-input,:root[data-theme=light] .input-field{background:#fff;border-color:var(--border);color:var(--text-primary)}:root[data-theme=light] .btn-ghost{color:var(--text-secondary);border-color:var(--border)}:root[data-theme=light] .btn-ghost:hover{border-color:var(--border-bright);color:var(--text-primary)}:root[data-theme=light] select option{background:#fff;color:var(--text-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:var(--bg-deep);color:var(--text-primary);min-height:100vh;overflow-x:hidden}.page{display:none}.page.active{display:flex;flex-direction:column;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar:before{content:"";position:absolute;top:-100px;left:-60px;width:280px;height:280px;background:radial-gradient(circle,#00d4aa10 0%,transparent 70%);pointer-events:none}.logo-wrap{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.logo-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.logo-text{font-family:Syne,sans-serif;font-size:16px;font-weight:800;letter-spacing:-.3px;line-height:1.1}.logo-text span{display:block;font-size:10px;font-weight:400;color:var(--text-secondary);letter-spacing:1.5px;text-transform:uppercase;font-family:DM Sans,sans-serif;margin-top:2px}.store-pill{margin:16px;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;gap:10px;cursor:pointer}.store-dot{width:8px;height:8px;background:var(--accent-green);border-radius:50%;box-shadow:0 0 8px var(--accent-green);flex-shrink:0;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 #22c55e60}50%{box-shadow:0 0 0 6px #22c55e00}}.store-name{font-size:12.5px;font-weight:600;flex:1}.store-branch{font-size:10.5px;color:var(--text-secondary);margin-top:1px}.nav-section{padding:8px 12px;overflow-y:auto;flex:1}.nav-label{font-size:10px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:var(--text-muted);padding:12px 12px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text-secondary);transition:all .18s;position:relative;margin-bottom:2px}.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background:var(--accent-teal-dim);color:var(--accent-teal);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--accent-teal);border-radius:0 3px 3px 0}.nav-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--accent-red);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:20px;min-width:20px;text-align:center}.nav-badge.warn{background:var(--accent-amber);color:#000}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s}.user-card:hover{background:var(--bg-elevated)}.user-avatar{width:34px;height:34px;background:linear-gradient(135deg,#2b7fff,#a855f7);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--text-secondary)}.header{height:var(--header-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:90}.page-title{font-family:Syne,sans-serif;font-size:18px;font-weight:700}.breadcrumb{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;margin-top:2px}.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}.search-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;display:flex;align-items:center;gap:8px;width:260px;transition:border-color .2s}.search-bar:focus-within{border-color:var(--accent-teal)}.search-bar input{background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:DM Sans,sans-serif;width:100%}.search-bar input::placeholder{color:var(--text-muted)}.icon-btn{width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .18s;position:relative}.icon-btn:hover{border-color:var(--border-bright)}.notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--accent-red);border-radius:50%;border:1.5px solid var(--bg-card)}.btn-primary{background:var(--accent-teal);color:#000;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .18s;font-family:DM Sans,sans-serif}.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:DM Sans,sans-serif;transition:all .18s;display:inline-flex;align-items:center;gap:6px}.btn-danger{background:var(--accent-red-dim);color:#f87171;border:1px solid #ef444430;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .18s}.btn-orange{background:var(--accent-orange-dim);color:var(--accent-orange);border:1px solid #ff6b2b30;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .18s}.card-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-title{font-family:Syne,sans-serif;font-size:14px;font-weight:700;flex:1}.card-action{font-size:12px;color:var(--accent-teal);cursor:pointer;font-weight:600;transition:opacity .2s}.card-action:hover{opacity:.7}.g2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.mb24{margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:all .2s;cursor:default}.stat-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.stat-card:after{content:"";position:absolute;bottom:0;right:0;width:80px;height:80px;border-radius:50%;opacity:.06}.stat-card.teal:after{background:var(--accent-teal)}.stat-card.blue:after{background:var(--accent-blue)}.stat-card.orange:after{background:var(--accent-orange)}.stat-card.purple:after{background:var(--accent-purple)}.stat-card.green:after{background:var(--accent-green)}.stat-card.red:after{background:var(--accent-red)}.stat-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.stat-icon.teal{background:var(--accent-teal-dim)}.stat-icon.blue{background:var(--accent-blue-dim)}.stat-icon.orange{background:var(--accent-orange-dim)}.stat-icon.purple{background:var(--accent-purple-dim)}.stat-icon.green{background:var(--accent-green-dim)}.stat-icon.red{background:var(--accent-red-dim)}.stat-trend{font-size:11.5px;font-weight:600;padding:3px 8px;border-radius:20px}.stat-trend.up{background:var(--accent-green-dim);color:var(--accent-green)}.stat-trend.down{background:var(--accent-red-dim);color:var(--accent-red)}.stat-trend.warn{background:var(--accent-amber-dim);color:var(--accent-amber)}.stat-val{font-family:Syne,sans-serif;font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}.stat-label{font-size:12.5px;color:var(--text-secondary)}.stat-sub{font-size:11.5px;color:var(--text-muted);margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-family:JetBrains Mono,monospace}.table-wrap{overflow-x:auto}th{padding:10px 16px;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);text-align:left;background:var(--bg-deep);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border);transition:background .18s}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}.sch-flag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--accent-purple-dim);color:var(--accent-purple);border:1px solid #a855f730;margin-left:5px;letter-spacing:.5px}.form-group{margin-bottom:16px}.form-label{font-size:12px;color:var(--text-secondary);margin-bottom:6px;display:block;font-weight:600}.form-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;color:var(--text-primary);font-size:13px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent-teal)}.form-input::placeholder{color:var(--text-muted)}select.form-input option{background:var(--bg-elevated)}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-section-title{font-family:Syne,sans-serif;font-size:13px;font-weight:700;color:var(--text-secondary);margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.tab-row{display:flex;gap:4px;padding:4px;background:var(--bg-deep);border-radius:var(--radius-sm)}.tab{padding:7px 14px;border-radius:6px;font-size:12.5px;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .18s}.tab.active{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.tab:hover:not(.active){color:var(--text-primary)}.alert-strip{display:flex;gap:12px;margin-bottom:24px;overflow-x:auto;padding-bottom:4px}.alert-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:40px;font-size:12.5px;font-weight:600;white-space:nowrap;cursor:pointer;border:1px solid transparent;transition:all .2s}.alert-chip.red{background:var(--accent-red-dim);border-color:#ef444430;color:#f87171}.alert-chip.amber{background:var(--accent-amber-dim);border-color:#f59e0b30;color:#fbbf24}.alert-chip.blue{background:var(--accent-blue-dim);border-color:#2b7fff30;color:#60a5fa}.alert-chip.purple{background:var(--accent-purple-dim);border-color:#a855f730;color:#c084fc}.stock-bar-wrap{width:90px}.stock-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:3px}.stock-fill{height:100%;border-radius:3px}.stock-fill.ok{background:var(--accent-green)}.stock-fill.low{background:var(--accent-amber)}.stock-fill.critical{background:var(--accent-red)}.stock-num{font-size:11px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fadeUp{animation:fadeUp .35s ease both}.supplier-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s;cursor:pointer}.supplier-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.supplier-logo-big{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;flex-shrink:0}.supplier-rating{display:flex;gap:2px;margin-top:4px}.star{font-size:11px;color:var(--accent-amber)}.grn-row{padding:14px 20px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border);transition:background .18s}.grn-row:hover{background:var(--bg-elevated)}.grn-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.grn-steps{display:flex;align-items:center;gap:0;margin-top:20px}.grn-step{flex:1;text-align:center;position:relative}.grn-step:after{content:"";position:absolute;top:15px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}.grn-step:last-child:after{display:none}.grn-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin:0 auto 8px;position:relative;z-index:1}.grn-dot.done{background:var(--accent-teal);color:#000}.grn-dot.active{background:var(--accent-blue);color:#fff;box-shadow:0 0 0 4px var(--accent-blue-dim)}.grn-dot.pending{background:var(--bg-elevated);color:var(--text-muted);border:2px solid var(--border)}.grn-step-label{font-size:11px;color:var(--text-secondary)}.customer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;gap:14px;align-items:flex-start;cursor:pointer;transition:all .2s}.customer-card:hover{border-color:var(--border-bright)}.cust-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0}.rx-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all .2s}.rx-upload-zone:hover{border-color:var(--accent-teal);background:var(--accent-teal-dim)}.rx-stored{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;display:flex;align-items:center;gap:12px;margin-bottom:10px;cursor:pointer;transition:background .18s}.rx-stored:hover{background:var(--bg-hover)}.timeline-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}.timeline-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}.credit-meter{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:6px}.credit-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent-green),var(--accent-amber))}.kpi-big{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center}.kpi-big-val{font-family:Syne,sans-serif;font-size:36px;font-weight:800;line-height:1}.kpi-big-label{font-size:13px;color:var(--text-secondary);margin-top:6px}.dead-stock-item{padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .18s}.dead-stock-item:hover{background:var(--bg-elevated)}.dead-days{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:800;color:var(--accent-red);line-height:1}.dead-label{font-size:10px;color:var(--text-muted)}.perf-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:5px}.perf-fill{height:100%;border-radius:3px}.chart-donut{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--accent-teal) 0% 45%,var(--accent-blue) 45% 68%,var(--accent-amber) 68% 82%,var(--accent-orange) 82% 100%);position:relative;flex-shrink:0}.chart-donut:after{content:"";position:absolute;inset:22px;background:var(--bg-card);border-radius:50%}.donut-legend{display:flex;flex-direction:column;gap:10px;justify-content:center}.donut-item{display:flex;align-items:center;gap:8px;font-size:12.5px}.donut-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.profit-line{height:60px;display:flex;align-items:flex-end;gap:3px;padding:0 4px}.profit-bar{flex:1;border-radius:2px 2px 0 0;cursor:pointer;transition:opacity .2s}.profit-bar:hover{opacity:.8}.branch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .2s}.branch-card:hover{border-color:var(--border-bright)}.branch-card.main-branch{border-color:var(--accent-teal);background:linear-gradient(135deg,var(--bg-card),#00d4aa08)}.branch-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.branch-status-dot.live{background:var(--accent-green);box-shadow:0 0 8px var(--accent-green)}.branch-status-dot.offline{background:var(--text-muted)}.role-pill{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid transparent}.role-pill.admin{background:#ef444418;border-color:#ef444430;color:#f87171}.role-pill.manager{background:var(--accent-blue-dim);border-color:#2b7fff30;color:#60a5fa}.role-pill.pharmacist{background:var(--accent-teal-dim);border-color:#00d4aa30;color:var(--accent-teal)}.role-pill.cashier{background:var(--accent-amber-dim);border-color:#f59e0b30;color:var(--accent-amber)}.permission-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.perm-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-elevated);border-radius:6px;font-size:12.5px}.perm-toggle{width:28px;height:16px;border-radius:8px;background:var(--border);position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.perm-toggle.on{background:var(--accent-teal)}.perm-toggle:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:left .2s}.perm-toggle.on:after{left:14px}.rx-check-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.rx-validation-row{padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.rx-validation-row:last-child{border-bottom:none}.rx-val-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.check-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.check-icon.pass{background:var(--accent-green-dim);color:var(--accent-green)}.check-icon.fail{background:var(--accent-red-dim);color:#f87171}.check-icon.warn{background:var(--accent-amber-dim);color:var(--accent-amber)}.audit-row{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);font-size:12.5px}.audit-row:last-child{border-bottom:none}.audit-time{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted);flex-shrink:0;width:80px}.einvoice-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.qr-mock{width:80px;height:80px;background:repeating-linear-gradient(0deg,var(--border) 0px,var(--border) 2px,var(--bg-elevated) 2px,var(--bg-elevated) 6px),repeating-linear-gradient(90deg,var(--border) 0px,var(--border) 2px,var(--bg-elevated) 2px,var(--bg-elevated) 6px);border-radius:6px;flex-shrink:0}.return-step{padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;gap:14px;align-items:flex-start;transition:all .2s}.return-step.active-step{border-color:var(--accent-teal);background:var(--accent-teal-dim)}.return-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;background:var(--bg-elevated);color:var(--text-secondary)}.return-step.active-step .return-step-num{background:var(--accent-teal);color:#000}.return-item{padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.reason-btn{padding:8px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .18s;font-family:DM Sans,sans-serif}.reason-btn.selected{border-color:var(--accent-teal);color:var(--accent-teal);background:var(--accent-teal-dim)}.zone-lane{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.zone-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.zone-title{font-family:Syne,sans-serif;font-size:13px;font-weight:700;flex:1}.zone-count{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:800}.zone-item{padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .18s}.zone-item:hover{background:var(--bg-elevated)}.zone-item:last-child{border-bottom:none}.days-ring{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;flex-shrink:0;border:2px solid transparent}.days-ring.critical{border-color:var(--accent-red);color:#f87171;background:var(--accent-red-dim)}.days-ring.watch{border-color:var(--accent-amber);color:var(--accent-amber);background:var(--accent-amber-dim)}.days-ring.monitor{border-color:var(--accent-blue);color:#60a5fa;background:var(--accent-blue-dim)}.move-btn{padding:5px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;color:var(--text-secondary);white-space:nowrap;transition:all .18s;font-family:DM Sans,sans-serif}.move-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.discount-badge{background:var(--accent-orange-dim);color:var(--accent-orange);border:1px solid #ff6b2b30;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}.promo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.promo-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.promo-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.promo-card.active-promo:before{background:linear-gradient(90deg,var(--accent-teal),var(--accent-blue))}.promo-card.expiring-promo:before{background:linear-gradient(90deg,var(--accent-amber),var(--accent-orange))}.promo-card.inactive-promo:before{background:var(--border)}.promo-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-size:22px;font-weight:800;font-family:Syne,sans-serif}.scheme-table td{vertical-align:middle}.grn-line{background:var(--bg-elevated);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;border:1px solid var(--border)}.grn-line-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.diff-tag{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;padding:2px 8px;border-radius:4px}.diff-tag.ok{background:var(--accent-green-dim);color:var(--accent-green)}.diff-tag.over{background:var(--accent-amber-dim);color:var(--accent-amber)}.diff-tag.short{background:var(--accent-red-dim);color:#f87171}.page-nav-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-size:11.5px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:DM Sans,sans-serif;transition:all .18s;white-space:nowrap}.page-nav-btn:hover{border-color:var(--border-bright);color:var(--text-primary)}.page-nav-btn.active{background:var(--accent-teal-dim);border-color:var(--accent-teal);color:var(--accent-teal)}.page{padding-top:44px}app-inventory,app-inventory *{--bg: var(--bg-deep);--card: var(--bg-card);--el: var(--bg-elevated);--hover: var(--bg-hover);--hdr: var(--bg-card);--bord: var(--border);--bord2: var(--border-bright);--shadow: 0 4px 24px rgba(0,0,0,.3);--text: var(--text-primary);--t2: var(--text-secondary);--t3: var(--text-muted);--teal: var(--accent-teal);--teal-dim: var(--accent-teal-dim);--green: var(--accent-green);--green-dim: var(--accent-green-dim);--red: var(--accent-red);--red-dim: var(--accent-red-dim);--amber: var(--accent-amber);--amber-dim: var(--accent-amber-dim);--orange: var(--accent-orange);--blue: var(--accent-blue);--blue-dim: var(--accent-blue-dim);--purple: var(--accent-purple);--purple-dim: var(--accent-purple-dim);--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--font-display: "Syne", sans-serif;--r: var(--radius);--rs: var(--radius-sm);--rxs: 6px}app-inventory{display:flex;flex-direction:column;height:100%;overflow:hidden}app-expiry,app-expiry *{--bg: var(--bg-deep);--bg-el: var(--bg-elevated);--border-b: var(--border-bright);--text: var(--text-primary);--text2: var(--text-secondary);--text3: var(--text-muted);--teal: var(--accent-teal);--teal-d: var(--accent-teal-dim);--green: var(--accent-green);--green-d: var(--accent-green-dim);--red: var(--accent-red);--red-d: var(--accent-red-dim);--amber: var(--accent-amber);--amber-d: var(--accent-amber-dim);--orange: var(--accent-orange);--orange-d: var(--accent-orange-dim);--blue: var(--accent-blue);--blue-d: var(--accent-blue-dim);--purple: var(--accent-purple);--purple-d: var(--accent-purple-dim);--r: var(--radius);--rs: var(--radius-sm)}app-expiry{display:flex;flex-direction:column;height:100%;overflow:hidden}.modal{display:none;position:fixed;inset:0;background:#0009;z-index:1000;align-items:center;justify-content:center;padding:20px}.modal.open{display:flex}.mbox{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.mhdr{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.mhdr h2{font-family:Syne,sans-serif;font-size:16px;font-weight:700;flex:1;margin:0}.mcls{background:none;border:none;color:var(--text-secondary);font-size:22px;cursor:pointer;line-height:1;padding:0 4px;transition:color .15s}.mcls:hover{color:var(--text-primary)}.mbody{flex:1;overflow-y:auto;padding:20px}.mftr{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.pr{background:var(--accent-red-dim);color:#f87171;border:1px solid #ef444430}.pa{background:var(--accent-amber-dim);color:var(--accent-amber);border:1px solid #f59e0b30}.pg{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid #22c55e30}.pt{background:var(--accent-teal-dim);color:var(--accent-teal);border:1px solid #00d4aa30}.pb{background:var(--accent-blue-dim);color:#60a5fa;border:1px solid #2b7fff30}.pp{background:var(--accent-purple-dim);color:var(--accent-purple);border:1px solid #a855f730}.po{background:var(--accent-orange-dim);color:var(--accent-orange);border:1px solid #ff6b2b30}.psk{background:#06b6d418;color:#22d3ee;border:1px solid #06b6d430}.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:10.5px;font-weight:700;letter-spacing:.4px}.tag-sch{background:var(--accent-purple-dim);color:var(--accent-purple);border:1px solid #a855f730}.tag-otc{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid #22c55e30}.tag-nar{background:var(--accent-red-dim);color:#f87171;border:1px solid #ef444430}.tag-rack{background:var(--accent-blue-dim);color:#60a5fa;border:1px solid #2b7fff30}.tag-catalog{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;font-weight:800;letter-spacing:.5px}.tag-gsn{background:var(--accent-teal-dim);color:var(--accent-teal);border:1px solid #00d4aa30}.input-field{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;color:var(--text-primary);font-size:13px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .2s}.input-field:focus{border-color:var(--accent-teal)}.input-field::placeholder{color:var(--text-muted)}.input-field option{background:var(--bg-elevated)}.form-row{display:flex;gap:12px;margin-bottom:12px}.form-row>*{flex:1}.form-label{font-size:11.5px;font-weight:600;color:var(--text-secondary);display:block;margin-bottom:5px}.divider{border:none;border-top:1px solid var(--border);margin:14px 0}.section-label{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:8px}.empty-ic{font-size:40px}.empty-txt{font-size:14px;color:var(--text-secondary);font-weight:600}.toasts{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;animation:fadeUp .25s ease;max-width:360px}.toast.s{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid #22c55e30}.toast.w{background:var(--accent-amber-dim);color:var(--accent-amber);border:1px solid #f59e0b30}.toast.e{background:var(--accent-red-dim);color:#f87171;border:1px solid #ef444430}.alerts{display:flex;gap:8px;padding:12px 26px;overflow-x:auto;flex-shrink:0;border-bottom:1px solid var(--border)}.alert-chip{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:40px;font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;border:1px solid transparent;transition:all .2s}.ac-r{background:var(--accent-red-dim);border-color:#ef444430;color:#f87171}.ac-a{background:var(--accent-amber-dim);border-color:#f59e0b30;color:var(--accent-amber)}.ac-t{background:var(--accent-teal-dim);border-color:#00d4aa30;color:var(--accent-teal)}.ac-p{background:var(--accent-purple-dim);border-color:#a855f730;color:var(--accent-purple)}.alert-chip.active{transform:scale(1.04);box-shadow:0 2px 12px #0003}.stock-warning{background:var(--accent-amber-dim);border:1px solid #f59e0b30;border-radius:var(--radius-sm);padding:12px 14px;font-size:12.5px;color:var(--accent-amber);margin-top:12px}.batch-table{width:100%;border-collapse:collapse;font-size:12.5px}.batch-table th{padding:8px 12px;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border);text-align:left}.batch-table td{padding:9px 12px;border-bottom:1px solid var(--border)}.batch-table tr:last-child td{border-bottom:none}.sub-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);margin-bottom:8px;cursor:pointer;transition:background .15s}.sub-row:hover{background:var(--bg-hover)}.mtabs{display:flex;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto}.mtab{padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary);border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s}.mtab:hover{color:var(--text-primary)}.mtab.act{color:var(--accent-teal);border-bottom-color:var(--accent-teal)}.btn{display:inline-flex;align-items:center;gap:6px;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-weight:600;cursor:pointer;transition:all .18s;border:1px solid transparent}.btn-teal{background:var(--accent-teal);color:#000;border-color:var(--accent-teal);padding:8px 16px;font-size:13px}.btn-ghost{background:none;color:var(--text-secondary);border-color:var(--border);padding:8px 16px;font-size:13px}.btn-red{background:var(--accent-red-dim);color:#f87171;border-color:#ef444430;padding:8px 16px;font-size:13px}.btn-amb{background:var(--accent-amber-dim);color:var(--accent-amber);border-color:#f59e0b30;padding:8px 16px;font-size:13px}.btn-grn{background:var(--accent-green-dim);color:var(--accent-green);border-color:#22c55e30;padding:8px 16px;font-size:13px}.btn-sm{padding:6px 12px;font-size:12px}.btn-xs{padding:4px 8px;font-size:11px}.wa-btn{background:#25d36618;color:#25d366;border:1px solid #25d36630;border-radius:var(--radius-sm);padding:7px 13px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .18s;display:inline-flex;align-items:center;gap:6px}.wa-btn:hover{background:#25d36628}app-posbilling{display:block;width:100%}.app-toast .toasts{z-index:9999}.modal-overlay{z-index:1100}.analytics-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}.analytics-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.period-btn{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:none;font-size:12.5px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:DM Sans,sans-serif;transition:all .18s}.period-btn:hover{border-color:var(--border-bright);color:var(--text-primary)}.period-btn.active{background:var(--accent-teal-dim);border-color:var(--accent-teal);color:var(--accent-teal)}.date-input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);font-size:12.5px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .2s;color-scheme:dark}.date-input:focus{border-color:var(--accent-teal)}.date-sep{font-size:12px;color:var(--text-muted)}.export-wrap{position:relative}.export-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:1000;min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px #00000059;padding:4px 0;overflow:hidden}.export-menu.open{display:block}.export-opt{padding:9px 16px;font-size:13px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .15s;font-family:DM Sans,sans-serif}.export-opt:hover{background:var(--bg-elevated);color:var(--text-primary)}.export-divider{height:1px;background:var(--border);margin:4px 0}:root[data-theme=light] .date-input{color-scheme:light;background:#fff;border-color:var(--border)}:root[data-theme=light] .export-menu{box-shadow:0 8px 32px #0000001f}.page-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:20px 24px 0}.header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;line-height:1;padding:0 4px;transition:color .15s}.fi{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text-primary);font-size:12.5px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .2s}.itab-row{display:flex;gap:3px;padding:3px;background:var(--bg-deep);border-radius:var(--radius-sm);margin-bottom:18px;flex-wrap:wrap}.itab{padding:6px 13px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .18s;white-space:nowrap;-webkit-user-select:none;user-select:none}.itab.active{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.itab:hover:not(.active){color:var(--text-primary)}.ent-tab-bar{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;margin-bottom:22px;width:fit-content}.etab{padding:8px 20px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;gap:7px;white-space:nowrap;-webkit-user-select:none;user-select:none}.etab:hover{color:var(--text-primary)}.etab.active{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);box-shadow:0 1px 4px #0000004d}.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;transition:all .2s;cursor:default}.kpi:hover{border-color:var(--border-bright);transform:translateY(-2px)}.kpi:after{content:"";position:absolute;bottom:-10px;right:-10px;width:70px;height:70px;border-radius:50%;opacity:.07}.kpi.teal:after{background:var(--accent-teal)}.kpi.blue:after{background:var(--accent-blue)}.kpi.orange:after{background:var(--accent-orange)}.kpi.green:after{background:var(--accent-green)}.kpi.red:after{background:var(--accent-red)}.kpi.purple:after{background:var(--accent-purple)}.kpi.amber:after{background:var(--accent-amber)}.kpi.cyan:after{background:var(--accent-cyan)}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.kpi-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}.ki-teal{background:var(--accent-teal-dim)}.ki-blue{background:var(--accent-blue-dim)}.ki-orange{background:var(--accent-orange-dim)}.ki-green{background:var(--accent-green-dim)}.ki-red{background:var(--accent-red-dim)}.ki-purple{background:var(--accent-purple-dim)}.ki-amber{background:var(--accent-amber-dim)}.ki-cyan{background:var(--accent-cyan-dim)}.kpi-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px}.kpi-val{font-family:Syne,sans-serif;font-size:24px;font-weight:800;line-height:1;margin-bottom:3px}.kpi-label{font-size:12px;color:var(--text-secondary)}.kpi-sub{font-size:10.5px;color:var(--text-muted);margin-top:7px;padding-top:7px;border-top:1px solid var(--border);font-family:JetBrains Mono,monospace}.staff-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s;position:relative}.staff-card:hover{border-color:var(--border-bright)}.ava{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0;color:#fff}.ring-on{box-shadow:0 0 0 3px var(--bg-card),0 0 0 5px var(--accent-green)}.ring-away{box-shadow:0 0 0 3px var(--bg-card),0 0 0 5px var(--accent-amber)}.ring-off{box-shadow:0 0 0 3px var(--bg-card),0 0 0 5px var(--text-muted)}.role-pill{padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px}.rp-admin{background:#ef444418;border:1px solid #ef444430;color:#f87171}.rp-mgr{background:var(--accent-blue-dim);border:1px solid #2b7fff30;color:#60a5fa}.rp-ph{background:var(--accent-teal-dim);border:1px solid #00d4aa30;color:var(--accent-teal)}.rp-cash{background:var(--accent-amber-dim);border:1px solid #f59e0b30;color:var(--accent-amber)}.rp-pur{background:var(--accent-purple-dim);border:1px solid #a855f730;color:var(--accent-purple)}.rp-del{background:var(--accent-orange-dim);border:1px solid #ff6b2b30;color:var(--accent-orange)}.branch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:all .2s;cursor:pointer;position:relative;overflow:hidden}.branch-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.branch-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.bc-hq:before{background:linear-gradient(90deg,var(--accent-teal),var(--accent-blue))}.bc-b:before{background:linear-gradient(90deg,var(--accent-blue),var(--accent-purple))}.bc-c:before{background:linear-gradient(90deg,var(--accent-orange),var(--accent-amber))}.bc-d:before{background:linear-gradient(90deg,var(--accent-purple),var(--accent-cyan))}.bst{width:8px;height:8px;border-radius:50%;flex-shrink:0}.bst.live{background:var(--accent-green);box-shadow:0 0 7px var(--accent-green)}.bst.sync{background:var(--accent-amber)}.bst.off{background:var(--text-muted)}.bm-val{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700}.bm-lbl{font-size:10px;color:var(--text-muted)}.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-title{font-family:Syne,sans-serif;font-size:13.5px;font-weight:700;flex:1}.tw{overflow-x:auto}table{width:100%;border-collapse:collapse}th{padding:9px 14px;font-size:10.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);text-align:left;background:var(--bg-deep);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 14px;font-size:12.5px;border-bottom:1px solid var(--border);transition:background .18s;vertical-align:middle}tr:hover td{background:var(--bg-elevated)}tr:last-child td{border-bottom:none}.pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.pill.green{background:var(--accent-green-dim);color:var(--accent-green)}.pill.red{background:var(--accent-red-dim);color:#f87171}.pill.amber{background:var(--accent-amber-dim);color:var(--accent-amber)}.pill.blue{background:var(--accent-blue-dim);color:#60a5fa}.pill.purple{background:var(--accent-purple-dim);color:var(--accent-purple)}.pill.orange{background:var(--accent-orange-dim);color:var(--accent-orange)}.pill.teal{background:var(--accent-teal-dim);color:var(--accent-teal)}.pill.cyan{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.mono{font-family:JetBrains Mono,monospace}.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.prog{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.prog-fill{height:100%;border-radius:3px}.prog-lg{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.prog-fill-lg{height:100%;border-radius:4px}.sel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text-primary);font-size:12px;font-family:DM Sans,sans-serif;outline:none}.sel:focus{border-color:var(--accent-teal)}.inp{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;padding:6px 11px;color:var(--text-primary);font-size:12px;font-family:DM Sans,sans-serif;outline:none}.inp:focus{border-color:var(--accent-teal)}.inp::placeholder{color:var(--text-muted)}.btn-primary{background:var(--accent-teal);color:#000;border:none;border-radius:var(--radius-sm);padding:7px 15px;font-size:12.5px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .18s;font-family:DM Sans,sans-serif;white-space:nowrap}.btn-primary:hover{background:#00bfa0;transform:translateY(-1px)}.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 13px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:DM Sans,sans-serif;transition:all .18s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.btn-ghost:hover{border-color:var(--border-bright);color:var(--text-primary)}.btn-danger{background:var(--accent-red-dim);color:#f87171;border:1px solid #ef444430;border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;display:inline-flex;align-items:center;gap:5px}.btn-danger:hover{background:#ef444425}.btn-amber{background:var(--accent-amber-dim);color:var(--accent-amber);border:1px solid #f59e0b30;border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;display:inline-flex;align-items:center;gap:5px}.btn-sm{padding:4px 10px!important;font-size:11px!important}.att-row{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.att-row:last-child{border-bottom:none}.att-bar-bg{flex:1;height:20px;background:var(--bg-deep);border-radius:4px;overflow:hidden}.att-bar-fill{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:8px;font-size:10px;font-weight:700;color:#000000b3;transition:width .6s ease;white-space:nowrap}.sync-row{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.sync-row:last-child{border-bottom:none}.sync-pulse{width:10px;height:10px;border-radius:50%;flex-shrink:0}.temp-row{padding:9px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.temp-row:last-child{border-bottom:none}.temp-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.temp-val{font-family:JetBrains Mono,monospace;font-size:16px;font-weight:800}.tx-row{padding:11px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);transition:background .18s}.tx-row:hover{background:var(--bg-elevated)}.tx-row:last-child{border-bottom:none}.tx-arrow{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}.rack-map-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px 18px}.rack-cell{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;padding:8px 6px;text-align:center;cursor:pointer;transition:all .2s}.rack-cell:hover{border-color:var(--border-bright);transform:scale(1.04)}.rack-cell.high{border-top:3px solid var(--accent-teal)}.rack-cell.med{border-top:3px solid var(--accent-amber)}.rack-cell.low{border-top:3px solid var(--accent-red)}.rack-cell.empty{border-top:3px solid var(--text-muted);opacity:.6}.rack-cell-code{font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.rack-cell-pct{font-size:10px;color:var(--text-muted);margin-top:2px}.staff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.staff-card.add-card{background:var(--bg-deep);border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;min-height:180px;border-radius:var(--radius);transition:border-color .2s}.staff-card.add-card:hover{border-color:var(--accent-teal)}.payroll-row{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;padding:6px 0;border-bottom:1px solid var(--border)}.payroll-row:last-child{border-bottom:none;font-weight:700;padding-top:8px}.bio-row{padding:11px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.bio-row:last-child{border-bottom:none}.grievance-row{padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);transition:background .18s}.grievance-row:hover{background:var(--bg-elevated)}.grievance-row:last-child{border-bottom:none}.notif-row{padding:11px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.notif-row:last-child{border-bottom:none}.session-row{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);font-size:12.5px}.session-row:last-child{border-bottom:none}.session-row.current{background:var(--accent-teal-dim)}.training-row{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.training-row:last-child{border-bottom:none}.check-item{padding:11px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);transition:background .18s}.check-item:hover{background:var(--bg-elevated)}.check-item:last-child{border-bottom:none}.ci{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.ci.pass{background:var(--accent-green-dim);color:var(--accent-green)}.ci.fail{background:var(--accent-red-dim);color:#f87171}.ci.warn{background:var(--accent-amber-dim);color:var(--accent-amber)}.lic-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;display:flex;align-items:center;gap:14px;margin-bottom:10px}.lic-card.expiring{border-color:#f59e0b30;background:#f59e0b06}.lic-days{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:800;line-height:1}.sch-badge{padding:1px 6px;border-radius:3px;font-size:10px;font-weight:800}.score-ring{width:90px;height:90px;position:relative;flex-shrink:0;display:inline-flex}.score-ring svg{transform:rotate(-90deg)}.score-ring .st{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-ring .sn{font-family:Syne,sans-serif;font-size:20px;font-weight:800;line-height:1}.score-ring .sl{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.recall-step{padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;gap:12px;align-items:flex-start;margin-bottom:8px}.recall-step.active{border-color:var(--accent-teal);background:var(--accent-teal-dim)}.recall-step.done{border-color:var(--accent-green);background:var(--accent-green-dim)}.rs-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.rs-num.done{background:var(--accent-green);color:#000}.rs-num.active{background:var(--accent-teal);color:#000}.rs-num.pending{background:var(--bg-elevated);color:var(--text-muted);border:2px solid var(--border)}.ab{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:12.5px}.ab.red{background:var(--accent-red-dim);border:1px solid #ef444330;color:#f87171}.ab.amber{background:var(--accent-amber-dim);border:1px solid #f59e0b30;color:var(--accent-amber)}.ab.green{background:var(--accent-green-dim);border:1px solid #22c55e30;color:var(--accent-green)}.ab.blue{background:var(--accent-blue-dim);border:1px solid #2b7fff30;color:#60a5fa}.pl-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:12.5px}.pl-row:last-child{border-bottom:none;font-weight:700;padding-top:10px}.pl-row.highlight{background:var(--accent-green-dim);padding:8px 6px;border-radius:4px;margin-top:4px}.pl-row.total{font-size:14px;border-top:2px solid var(--border);padding-top:12px}.pl-section{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);padding:10px 0 4px}.cmp-track{height:34px;background:var(--bg-deep);border-radius:6px;overflow:hidden;display:flex}.cmp-seg{height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#ffffffd9;transition:width .8s ease;border-right:2px solid var(--bg-card)}.cmp-seg:last-child{border-right:none}.bar-chart{display:flex;align-items:flex-end;gap:5px}.bw{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.bb{width:100%;border-radius:3px 3px 0 0;min-height:3px;transition:opacity .2s;cursor:pointer}.bb:hover{opacity:.75}.bl{font-size:9.5px;color:var(--text-muted);text-align:center}.map-placeholder{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);position:relative;overflow:hidden}.map-grid{position:absolute;inset:0;background:repeating-linear-gradient(0deg,var(--border) 0,var(--border) 1px,transparent 1px,transparent 40px),repeating-linear-gradient(90deg,var(--border) 0,var(--border) 1px,transparent 1px,transparent 40px);opacity:.3}.map-pin-marker{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .2s}.map-pin-marker:hover{transform:scale(1.15)}.mpm-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4)}.mpm-label{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700;white-space:nowrap}.slip-hdr{background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));color:#000;padding:20px;text-align:center}.slip-body{padding:20px}.slip-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:12.5px}.slip-row:last-child{border-bottom:none}.slip-total{background:var(--accent-teal-dim);border:1px solid #00d4aa30;border-radius:var(--radius-sm);padding:12px 16px;margin-top:12px;display:flex;justify-content:space-between;align-items:center}.integ-opt{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:10px;cursor:pointer;text-align:center;transition:all .2s}.integ-opt:hover{border-color:var(--accent-teal)}.integ-opt-icon{font-size:22px;margin-bottom:4px}.integ-opt-name{font-size:11.5px;font-weight:600}.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.perm-item{display:flex;align-items:center;gap:8px;padding:8px 11px;background:var(--bg-elevated);border-radius:6px;font-size:12px}.toggle{width:30px;height:17px;border-radius:9px;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s;border:none;outline:none}.toggle.on{background:var(--accent-teal)}.toggle.off{background:var(--border)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:13px;height:13px;border-radius:50%;background:#fff;transition:left .18s}.toggle.on:after{left:15px}.leave-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.lc-day{text-align:center;padding:5px 2px;border-radius:5px;font-size:11px}.lc-hdr{color:var(--text-muted);font-weight:600;font-size:10px}.lc-avail{background:var(--accent-green-dim);color:var(--accent-green)}.lc-leave{background:var(--accent-red-dim);color:#f87171}.lc-half{background:var(--accent-amber-dim);color:var(--accent-amber)}.lc-off{background:var(--bg-elevated);color:var(--text-muted)}.lc-today{border:1px solid var(--accent-teal)!important}.backup-row-faded{opacity:.5}.modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:500;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px);padding:20px}.modal-overlay.open{display:flex}.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:520px;max-width:95vw;max-height:90vh;overflow-y:auto}.modal-box.wide{width:700px}.modal-hdr{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-card);z-index:2}.modal-title{font-family:Syne,sans-serif;font-size:15px;font-weight:700}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px}.modal-ftr{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.fg{margin-bottom:14px}.fl{font-size:11.5px;color:var(--text-secondary);margin-bottom:5px;display:block;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.fi{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text-primary);font-size:12.5px;font-family:DM Sans,sans-serif;outline:none}.fi:focus{border-color:var(--accent-teal)}.fi::placeholder{color:var(--text-muted)}.fi option{background:var(--bg-elevated)}textarea.fi{resize:vertical;min-height:80px}.fr{display:flex;gap:12px}.fr>.fg{flex:1}@keyframes pulse{0%,to{box-shadow:0 0 #22c55e99}50%{box-shadow:0 0 0 5px #22c55e00}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.up{background:var(--accent-green-dim);color:var(--accent-green)}.down{background:var(--accent-red-dim);color:var(--accent-red)}.warn{background:var(--accent-amber-dim);color:var(--accent-amber)}
