@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg:#F0FDF4;--bg2:#F8FAFB;--white:#fff;--surface:#fff;--g50:#F0FDF4;--g100:#DCFCE7;--g200:#BBF7D0;--g300:#86EFAC;--g400:#4ADE80;--g500:#22C55E;--g600:#16A34A;--g700:#15803D;--g800:#166534;--orange:#F97316;--orange-bg:#FFF7ED;--orange-l:#FED7AA;--blue:#3B82F6;--blue-bg:#EFF6FF;--blue-l:#BFDBFE;--amber:#F59E0B;--amber-bg:#FFFBEB;--amber-l:#FDE68A;--red:#EF4444;--red-bg:#FEF2F2;--red-l:#FECACA;--purple:#8B5CF6;--purple-bg:#F5F3FF;--border:#E5E7EB;--border2:#D1D5DB;--text:#111827;--text2:#374151;--text3:#6B7280;--text4:#9CA3AF;--sh:0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(22,163,74,.07);--sh2:0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);--sh3:0 20px 60px rgba(0,0,0,.15);--sidebar-w:232px;--r:12px;--mono:"JetBrains Mono",monospace}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:Plus Jakarta Sans,sans-serif;background:var(--bg);color:var(--text);overflow:auto}.mono{font-family:JetBrains Mono,monospace}.app{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative}.sidebar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(0deg,var(--g50),transparent);pointer-events:none}.sb-logo{padding:20px 18px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.sb-logo-mark{width:38px;height:38px;background:linear-gradient(135deg,var(--g500),var(--g700));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:900;flex-shrink:0;box-shadow:0 4px 12px #22c55e59}.sb-brand{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.3px}.sb-code{font-size:10px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:1px}.sb-nav{flex:1;padding:10px;overflow-y:auto;overflow-x:hidden}.sb-nav::-webkit-scrollbar{width:0}.sb-section{font-size:9px;font-weight:700;color:var(--text4);letter-spacing:1.4px;text-transform:uppercase;padding:10px 8px 5px}.sb-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text3);transition:all .15s;position:relative;white-space:nowrap;text-decoration:none}.sb-item:hover{background:var(--g50);color:var(--g600)}.sb-item.active{background:var(--g100);color:var(--g700);font-weight:600}.sb-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--g500);border-radius:0 3px 3px 0}.sb-icon{width:22px;text-align:center;font-size:15px;flex-shrink:0}.sb-badge{margin-left:auto;background:var(--g500);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:20px;font-family:JetBrains Mono,monospace}.sb-badge.red{background:var(--red)}.sb-badge.amber{background:var(--amber)}.sb-footer{padding:14px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;position:relative;z-index:1}.sb-avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--g400),var(--g700));display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:800;flex-shrink:0}.sb-user-name{font-size:12px;font-weight:700}.sb-user-sub{font-size:10px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:1px}.live-pill{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:9px;font-weight:600;color:var(--g600);font-family:JetBrains Mono,monospace}.live-dot{width:6px;height:6px;background:var(--g500);border-radius:50%;animation:blink 2s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.app.app--collapsed .main{margin-left:0}.topbar{height:58px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px;flex-shrink:0}.topbar-title{font-size:16px;font-weight:800;letter-spacing:-.3px}.topbar-sub{font-size:11px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:1px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.topbar-toggle{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:16px;color:var(--text3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s;margin-right:4px}.topbar-toggle:hover{background:var(--g50);border-color:var(--g300);color:var(--g700)}.search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:7px 12px;width:210px}.search-wrap input{background:none;border:none;outline:none;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;color:var(--text);width:100%}.search-wrap input::placeholder{color:var(--text4)}.search-icon{color:var(--text4);font-size:14px;flex-shrink:0}.btn{padding:8px 16px;border-radius:9px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.btn-green{background:var(--g600);color:#fff}.btn-green:hover{background:var(--g700);box-shadow:0 4px 12px #16a34a4d}.btn-outline{background:var(--white);color:var(--text2);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--g300);background:var(--g50)}.btn-sm{padding:5px 11px;font-size:11px}.btn-red{background:var(--red);color:#fff}.btn-amber{background:var(--amber);color:#fff}.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 24px}.content::-webkit-scrollbar{width:4px}.content::-webkit-scrollbar-thumb{background:var(--g200);border-radius:4px}.view{animation:fadein .18s ease}@keyframes fadein{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--sh)}.card-sm{padding:14px 16px}.card-title{font-size:13px;font-weight:700;letter-spacing:-.2px}.card-sub{font-size:11px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:2px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:18px;position:relative;overflow:hidden;box-shadow:var(--sh);cursor:default;transition:box-shadow .15s}.kpi-card:hover{box-shadow:var(--sh2)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r) var(--r) 0 0}.kpi-g:before{background:linear-gradient(90deg,var(--g500),var(--g300))}.kpi-o:before{background:linear-gradient(90deg,var(--orange),#FDBA74)}.kpi-b:before{background:linear-gradient(90deg,var(--blue),#93C5FD)}.kpi-p:before{background:linear-gradient(90deg,var(--purple),#C4B5FD)}.kpi-label{font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.kpi-value{font-size:26px;font-weight:800;font-family:JetBrains Mono,monospace;letter-spacing:-1px;line-height:1}.kpi-delta{font-size:11px;font-family:JetBrains Mono,monospace;margin-top:5px;display:flex;align-items:center;gap:4px}.kpi-delta.up{color:var(--g600)}.kpi-delta.dn{color:var(--red)}.kpi-delta.na{color:var(--text4)}.kpi-icon{position:absolute;top:16px;right:16px;font-size:22px;opacity:.7}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}thead th{background:var(--g50);padding:9px 12px;text-align:left;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;border-bottom:1px solid var(--border);white-space:nowrap}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:hover{background:var(--g50)}tbody td{padding:9px 12px;color:var(--text);vertical-align:middle}.td-mono{font-family:JetBrains Mono,monospace}.td-muted{color:var(--text3)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;font-family:JetBrains Mono,monospace;white-space:nowrap}.bg-green{background:var(--g100);color:var(--g700)}.bg-orange{background:var(--orange-bg);color:var(--orange)}.bg-red{background:var(--red-bg);color:var(--red)}.bg-blue{background:var(--blue-bg);color:var(--blue)}.bg-amber{background:var(--amber-bg);color:var(--amber)}.bg-purple{background:var(--purple-bg);color:var(--purple)}.bg-gray{background:var(--bg);color:var(--text3)}.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sh-title{font-size:14px;font-weight:800;letter-spacing:-.3px}.sh-meta{font-size:11px;color:var(--text4);font-family:JetBrains Mono,monospace}.sbar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}.sbar-label{font-size:11px;font-weight:500;width:170px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sbar-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.sbar-fill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.sbar-val{font-size:11px;font-family:JetBrains Mono,monospace;color:var(--text4);width:40px;text-align:right;flex-shrink:0}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.g21{display:grid;grid-template-columns:2fr 1fr;gap:14px}.g12{display:grid;grid-template-columns:1fr 2fr;gap:14px}.mb14{margin-bottom:14px}.mb18{margin-bottom:18px}.mb20{margin-bottom:20px}.pipeline-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.pipeline-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.pipeline-header h2{font-size:14px;font-weight:800;letter-spacing:-.3px}.pipeline-header p{font-size:11px;color:var(--text4);margin-top:2px}.pipeline-legend{display:flex;gap:14px;font-size:11px;color:var(--text3);align-items:center}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pipeline-svg-wrap{padding:20px 20px 16px;overflow-x:auto;min-height:360px}.pipeline-svg-wrap svg{min-width:900px;max-width:100%;display:block}.pn-bg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.08));cursor:pointer;transition:opacity .15s}.pn-bg:hover rect.pn-card{stroke:#22c55e;stroke-width:2}.pn-group{cursor:pointer}.pn-group:hover .pn-card-rect{stroke:var(--g500)!important;stroke-width:2}.flow-edge{fill:none;stroke-dasharray:8 5}.particle{r:4}.heatmap-wrap{overflow-x:auto}.heatmap-table{min-width:700px;width:100%}.hm-header{display:flex;gap:2px;margin-bottom:4px;padding-left:172px}.hm-month{flex:1;min-width:0;text-align:center;font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.5px;padding:3px 0}.hm-row{display:flex;align-items:center;gap:2px;margin-bottom:2px}.hm-prod-label{width:168px;flex-shrink:0;font-size:11px;font-weight:500;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px;text-align:right}.hm-cell{flex:1;min-width:0;height:26px;border-radius:4px;cursor:pointer;transition:transform .1s,filter .1s;position:relative;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#ffffffd9}.hm-cell:hover{transform:scale(1.15);z-index:5;filter:brightness(1.1)}.hm-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:5px 9px;border-radius:7px;font-size:10px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .1s;z-index:100;font-family:JetBrains Mono,monospace}.hm-cell:hover .hm-tooltip{opacity:1}.autoship-legend{display:flex;gap:16px;font-size:11px;color:var(--text3);flex-wrap:wrap;margin-bottom:14px}.al-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.as-table{min-width:900px;width:100%}.as-row{display:flex;align-items:center;gap:0;border-bottom:1px solid var(--border);padding:8px 0}.as-row:hover{background:var(--g50)}.as-consumer{width:200px;flex-shrink:0;padding:0 12px;font-size:12px;font-weight:600}.as-id{width:120px;flex-shrink:0;font-size:10px;font-family:JetBrains Mono,monospace;color:var(--text3);padding:0 8px}.as-etailer{width:160px;flex-shrink:0;font-size:11px;color:var(--text3);padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.as-months{display:flex;gap:3px;padding:0 8px;flex:1}.as-month-cell{width:44px;height:26px;border-radius:5px;font-size:10px;font-weight:700;font-family:JetBrains Mono,monospace;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid transparent}.as-month-paid{background:var(--g100);color:var(--g700);border-color:var(--g200)}.as-month-free{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-l)}.as-month-upcoming{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-l)}.as-month-empty{background:var(--bg);color:var(--text4);border-color:var(--border)}.as-mrp{width:80px;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;color:var(--g700);padding:0 8px;text-align:right}.as-header{background:var(--g50);border-bottom:2px solid var(--g200)}.as-header .as-consumer,.as-header .as-id,.as-header .as-etailer,.as-header .as-mrp{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.7px}.as-header .as-month-cell{background:none;border:none;font-size:9px;color:var(--text4)}.audit-diff-pos{color:var(--red);font-weight:700}.audit-diff-zero{color:var(--g600);font-weight:600}.audit-diff-pen{color:var(--amber);font-weight:600}.audit-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.audit-stat{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center}.audit-stat-val{font-size:24px;font-weight:800;font-family:JetBrains Mono,monospace;margin-bottom:4px}.audit-stat-label{font-size:11px;color:var(--text4)}.network-container{display:grid;grid-template-columns:340px 1fr;gap:16px;height:calc(100vh - 120px)}.tree-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow-y:auto;box-shadow:var(--sh)}.tree-panel::-webkit-scrollbar{width:3px}.tree-panel::-webkit-scrollbar-thumb{background:var(--g200);border-radius:3px}.tp-header{padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--white);z-index:2}.tp-header-title{font-size:13px;font-weight:800}.tp-header-sub{font-size:10px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:2px}.tp-search{margin:10px 12px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;color:var(--text);background:var(--bg);outline:none;width:calc(100% - 24px)}.tp-search:focus{border-color:var(--g300)}.leader-group{border-bottom:1px solid var(--border)}.leader-header{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.leader-header:hover,.leader-header.open{background:var(--g50)}.leader-header.selected{box-shadow:inset 3px 0 0 var(--g400)}.lh-chevron{font-size:12px;color:var(--text4);transition:transform .2s;flex-shrink:0}.leader-header.open .lh-chevron{transform:rotate(90deg)}.lh-avatar{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--g400),var(--g700));display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:800;flex-shrink:0}.lh-name{font-size:12px;font-weight:700;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lh-count{background:var(--g100);color:var(--g700);font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px;font-family:JetBrains Mono,monospace;flex-shrink:0}.leader-members{display:none;padding-left:0}.leader-members.open{display:block}.member-row{display:flex;align-items:center;gap:10px;padding:9px 14px 9px 48px;cursor:pointer;transition:background .1s;border-top:1px solid var(--g50)}.member-row:hover{background:var(--g50)}.member-row.selected{background:var(--g100)}.mr-avatar{width:26px;height:26px;border-radius:7px;background:var(--g100);display:flex;align-items:center;justify-content:center;color:var(--g700);font-size:10px;font-weight:800;flex-shrink:0}.mr-name{font-size:12px;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mr-city{font-size:10px;color:var(--text4);flex-shrink:0}.profile-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow-y:auto;box-shadow:var(--sh)}.profile-panel::-webkit-scrollbar{width:3px}.profile-panel::-webkit-scrollbar-thumb{background:var(--g200);border-radius:3px}.pp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text4)}.pp-empty-icon{font-size:40px;margin-bottom:12px}.pp-empty-text{font-size:13px}.pp-content{padding:24px}.pp-hero{display:flex;align-items:center;gap:14px;margin-bottom:20px}.pp-avatar{width:56px;height:56px;border-radius:14px;flex-shrink:0;background:linear-gradient(135deg,var(--g400),var(--g700));display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:800}.pp-name{font-size:18px;font-weight:800;letter-spacing:-.3px}.pp-id{font-size:11px;font-family:JetBrains Mono,monospace;color:var(--text4);margin-top:2px}.pp-meta{font-size:11px;color:var(--text3);margin-top:4px}.pp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}.pp-stat{background:var(--g50);border:1px solid var(--g100);border-radius:10px;padding:12px;text-align:center}.pp-stat-val{font-size:20px;font-weight:800;font-family:JetBrains Mono,monospace;color:var(--g700)}.pp-stat-label{font-size:10px;color:var(--text4);margin-top:2px}.pp-section-title{font-size:12px;font-weight:700;margin-bottom:10px;color:var(--text2)}.pp-chart-wrap{height:120px;margin-bottom:16px}.pp-prod-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}.pp-prod-name{font-size:11px;flex:1}.pp-prod-bar-track{width:80px;height:5px;background:var(--border);border-radius:3px;overflow:hidden}.pp-prod-bar{height:100%;background:var(--g400);border-radius:3px}.pp-tx-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg);border-radius:8px;margin-bottom:6px}.pp-tx-date{font-size:10px;font-family:JetBrains Mono,monospace;color:var(--text4);width:70px;flex-shrink:0}.pp-tx-items{font-size:11px;flex:1;color:var(--text2)}.pp-tx-amt{font-size:12px;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--g600);flex-shrink:0}.billing-layout{display:grid;grid-template-columns:1fr 380px;gap:0;height:calc(100vh - 64px);background:var(--bg2)}.bill-left{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border);background:var(--bg2)}.bill-right{display:flex;flex-direction:column;overflow:hidden;background:var(--white)}.bill-topstrip{display:flex;gap:0;align-items:stretch;background:var(--white);border-bottom:2px solid var(--border);flex-shrink:0}.bts-section{display:flex;flex-direction:column;padding:10px 14px;border-right:1px solid var(--border);gap:6px}.bts-label{font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:1px}.bts-tabs{display:flex;gap:4px}.bts-tab{padding:5px 12px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text3);transition:all .12s;white-space:nowrap}.bts-tab.active{background:var(--g600);color:#fff;border-color:var(--g600);box-shadow:0 2px 8px #16a34a4d}.bts-pay{display:flex;gap:4px;flex-wrap:wrap}.bts-pay-btn{padding:5px 10px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text3);transition:all .12s}.bts-pay-btn.active{background:var(--g700);color:#fff;border-color:var(--g700)}.bill-cust-strip{display:flex;align-items:center;gap:0;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}.bcs-field{display:flex;flex-direction:column;padding:10px 14px;border-right:1px solid var(--border);flex:1;gap:3px}.bcs-label{font-size:9px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.8px}.bcs-input{border:none;outline:none;background:transparent;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;color:var(--text);padding:0;width:100%}.bcs-input::placeholder{color:var(--text4)}.bcs-selected{font-size:12px;font-weight:700;color:var(--g700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bcs-sub{font-size:10px;color:var(--text4);font-family:var(--mono)}.bill-prods{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:0}.bill-search-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}.bill-search-bar input{flex:1;border:none;outline:none;background:transparent;font-size:13px;font-family:Plus Jakarta Sans,sans-serif;color:var(--text)}.bill-search-bar input::placeholder{color:var(--text4)}.prod-cats{display:flex;gap:5px;flex-wrap:nowrap;overflow-x:auto;padding:8px 12px;flex-shrink:0;background:var(--bg2)}.prod-cats::-webkit-scrollbar{height:0}.cat-pill{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;border:1px solid var(--border);background:var(--white);color:var(--text3);transition:all .12s}.cat-pill.active,.cat-pill:hover{background:var(--g600);color:#fff;border-color:var(--g600)}.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px;overflow-y:auto;padding:10px 12px;flex:1;align-content:start}.prod-grid::-webkit-scrollbar{width:4px}.prod-grid::-webkit-scrollbar-thumb{background:var(--g200);border-radius:4px}.prod-tile{background:var(--white);border:2px solid var(--border);border-radius:10px;padding:12px;cursor:pointer;transition:all .12s;position:relative;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;gap:2px}.prod-tile:hover{border-color:var(--g300);box-shadow:0 2px 8px #16a34a1a;transform:translateY(-1px)}.prod-tile.selected{border-color:var(--g500);background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.prod-tile.selected:hover{border-color:var(--g600)}.prod-tile.oos{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.pt-name{font-size:12px;font-weight:700;line-height:1.3;color:var(--text);margin-bottom:2px}.pt-price{font-size:16px;font-weight:800;color:var(--g700);font-family:JetBrains Mono,monospace}.pt-stock{font-size:10px;color:var(--text4)}.pt-qty-badge{position:absolute;top:-7px;right:-7px;background:var(--g600);color:#fff;font-size:10px;font-weight:800;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:JetBrains Mono,monospace;box-shadow:0 2px 6px #16a34a66}.bill-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.bill-panel-head{padding:14px 16px;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0}.bill-panel-items{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:6px;background:var(--bg)}.bill-panel-items::-webkit-scrollbar{width:3px}.bill-panel-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text4);gap:8px;background:var(--bg);padding:20px}.bill-panel-foot{padding:12px 16px;border-top:2px solid var(--border);background:var(--white);flex-shrink:0}.bill-item-row{display:flex;align-items:center;gap:8px;background:var(--white);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.bi-name{flex:1;font-size:12px;font-weight:600;min-width:0}.qty-ctrl{display:flex;align-items:center;gap:3px}.qty-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .1s}.qty-btn:hover{border-color:var(--g400);color:var(--g600);background:var(--g50)}.qty-num{font-family:JetBrains Mono,monospace;font-size:13px;width:26px;text-align:center;font-weight:700}.bi-price{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--g700);font-weight:700;width:64px;text-align:right}.bi-del{cursor:pointer;color:var(--text4);font-size:16px;line-height:1;padding:2px 4px;flex-shrink:0}.bi-del:hover{color:var(--red)}.bill-totals{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.bt-row{display:flex;justify-content:space-between;font-size:12px}.bt-label{color:var(--text3)}.bt-val{font-family:JetBrains Mono,monospace;font-weight:600}.bt-final{font-size:18px;font-weight:800;color:var(--g700)}.bt-final-val{font-size:18px;font-weight:800;font-family:JetBrains Mono,monospace;color:var(--g700)}.cust-card{background:var(--g50);border:1px solid var(--g200);border-radius:9px;padding:10px 14px;display:flex;align-items:center;gap:10px}.cust-init{width:36px;height:36px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,var(--g500),var(--g700));color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center}.cust-disc-badge{margin-left:auto;background:var(--g700);color:#fff;font-size:14px;font-weight:800;padding:4px 10px;border-radius:8px;font-family:JetBrains Mono,monospace}.form-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;display:block;margin-bottom:5px}.form-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:9px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--g400);background:var(--white)}.form-select{width:100%;padding:9px 32px 9px 12px;border:1px solid var(--border);border-radius:9px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;color:var(--text);background:var(--bg);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239CA3AF' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.branch-tabs{display:flex;gap:6px;margin-bottom:16px}.branch-tab{padding:8px 20px;border-radius:9px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--white);color:var(--text3);transition:all .15s;display:flex;align-items:center;gap:7px}.branch-tab.active{background:var(--g600);color:#fff;border-color:var(--g600);box-shadow:0 4px 12px #16a34a40}.branch-tab-dot{width:8px;height:8px;border-radius:50%}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.client-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--sh);transition:box-shadow .15s}.client-card:hover{box-shadow:var(--sh2)}.cc-type{margin-bottom:10px}.cc-name{font-size:14px;font-weight:700;margin-bottom:6px}.cc-note{font-size:11px;color:var(--text4)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--white);border-radius:16px;box-shadow:var(--sh3);max-height:90vh;overflow-y:auto;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal::-webkit-scrollbar{width:4px}.modal::-webkit-scrollbar-thumb{background:var(--g200);border-radius:4px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:var(--white);z-index:5}.modal-title{font-size:16px;font-weight:800;letter-spacing:-.3px}.modal-sub{font-size:11px;color:var(--text4);font-family:JetBrains Mono,monospace;margin-top:2px}.modal-close{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:16px;color:var(--text3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}.modal-close:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-l)}.modal-body{padding:20px 24px}.modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.ms-item{background:var(--g50);border:1px solid var(--g100);border-radius:10px;padding:12px;text-align:center}.ms-val{font-size:20px;font-weight:800;font-family:JetBrains Mono,monospace;color:var(--g700)}.ms-label{font-size:10px;color:var(--text4);margin-top:2px}.modal-chart-wrap{height:180px;margin-bottom:20px}.thermal-wrap{width:300px;background:#fff;font-family:JetBrains Mono,monospace}.th-header{text-align:center;padding:16px 12px 10px;border-bottom:2px dashed #ccc}.th-logo{font-size:22px;font-weight:900;color:#111;letter-spacing:3px}.th-sub{font-size:9px;color:#666;margin-top:3px}.th-info{padding:8px 12px;border-bottom:1px dashed #ccc;font-size:10px;color:#333}.th-info-row{display:flex;justify-content:space-between;margin-bottom:3px}.th-items{padding:8px 12px}.th-item-row{display:flex;font-size:10px;margin-bottom:3px;gap:4px}.th-item-name{flex:1}.th-item-qty{width:25px;text-align:center}.th-item-price{width:55px;text-align:right}.th-divider{border:none;border-top:1px dashed #ccc;margin:6px 0}.th-totals{padding:6px 12px;font-size:10px}.th-total-row{display:flex;justify-content:space-between;margin-bottom:3px}.th-grand{font-size:13px;font-weight:900;border-top:2px solid #111;padding-top:5px;margin-top:3px}.th-footer{text-align:center;padding:10px 12px 16px;font-size:9px;color:#888;border-top:1px dashed #ccc}.loading-spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--g100);border-top-color:var(--g500);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;min-height:200px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--text4);gap:8px}.error-state-icon{font-size:32px}.error-state-text{font-size:13px;font-weight:600;color:var(--red)}.error-state-sub{font-size:11px}.skeleton{background:linear-gradient(90deg,var(--g50) 25%,var(--g100) 50%,var(--g50) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px}@keyframes shimmer{to{background-position:-200% 0}}
