:root{--bg: #f5f7f9;--surface: #ffffff;--border: #e9eef2;--border-2: #eef2f6;--text: #0f172a;--text-2: #1e293b;--muted: #64748b;--muted-2: #94a3b8;--primary: #0f766e;--primary-dk: #0e6b63;--primary-lt: #ecfdf5;--primary-bd: #d1fae5;--primary-ink: #ffffff;--danger: #e11d48;--danger-lt: #fff1f2;--danger-bd: #fecdd3;--warn-lt: #fffbeb;--warn-bd: #fde68a;--warn-text: #92400e;--radius: 12px;--radius-lg: 16px;--sidebar-w: 236px;--sidebar-collapsed-w: 56px;--shadow-sm: 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 12px rgba(15,23,42,.08);font-family:IBM Plex Sans,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0 0 1rem}h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin:0}h3{font-size:1rem;font-weight:700;letter-spacing:-.01em;margin:0}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background-clip:padding-box}.mono{font-family:IBM Plex Mono,monospace}.auth{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.2rem;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-md)}.auth-title{margin:0;font-size:1.4rem;color:var(--primary);font-weight:700}.auth-sub{margin:0 0 .5rem;color:var(--muted);font-size:.9rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;color:var(--muted);font-weight:600;letter-spacing:.02em}.auth-card input{padding:.65rem .8rem;border:1px solid var(--border);border-radius:10px;color:var(--text);background:#f8fafc}.auth-card input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #0f766e1a;outline:none}.auth-card button{margin-top:.4rem;padding:.7rem;border:none;border-radius:10px;background:var(--primary);color:var(--primary-ink);font-weight:600;box-shadow:0 1px 2px #0f766e40}.auth-card button:disabled{opacity:.6;cursor:default}.auth-error{color:var(--danger);font-size:.85rem;margin:0}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns .22s ease}.shell.sidebar-collapsed{grid-template-columns:var(--sidebar-collapsed-w) 1fr}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:22px 14px;display:flex;flex-direction:column;gap:2px;transition:padding .22s ease;overflow:hidden;position:sticky;top:0;height:100vh}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:4px 6px 20px;min-height:2.8rem}.sidebar-logo{display:flex;align-items:center;gap:11px}.sidebar-logo-mark{width:34px;height:34px;border-radius:9px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0}.sidebar-logo-text{line-height:1.1}.sidebar-logo-text .brand{font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--text);padding:0}.sidebar-logo-text .brand-sub{font-size:10px;color:var(--muted-2);font-weight:500;letter-spacing:.06em;text-transform:uppercase}.collapse-btn{background:none;border:1px solid var(--border);border-radius:7px;color:var(--muted);font-size:.85rem;line-height:1;padding:.22rem .5rem;cursor:pointer;flex-shrink:0;transition:background .15s}.collapse-btn:hover{background:var(--bg)}.shell.sidebar-collapsed .sidebar{padding:22px 8px}.shell.sidebar-collapsed .sidebar-header{justify-content:center;padding-bottom:20px}.shell.sidebar-collapsed .sidebar-logo-text{display:none}.shell.sidebar-collapsed .sidebar-logo{gap:0}.nav-list{display:flex;flex-direction:column;gap:2px;flex:1}.nav{text-decoration:none;color:var(--muted);padding:9px 12px;border-radius:9px;font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:9px;transition:background .12s,color .12s}.nav:hover{background:var(--bg);color:var(--text)}.nav.active{background:var(--primary-lt);color:var(--primary);font-weight:600;box-shadow:inset 2px 0 0 var(--primary)}.nav-icon{font-size:1rem;flex-shrink:0;line-height:1}.nav-label{white-space:nowrap;overflow:hidden}.nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;line-height:1;color:#fff;background:var(--danger);border-radius:999px}.nav-badge-dot{position:absolute;top:-4px;right:-6px;min-width:8px;width:8px;height:8px;padding:0;margin:0}.shell.sidebar-collapsed .nav{justify-content:center;padding:10px 0;box-shadow:none}.shell.sidebar-collapsed .nav.active{background:var(--primary-lt)}.sidebar-footer{padding:14px 6px 2px;border-top:1px solid var(--border-2);margin-top:auto;display:flex;flex-direction:column;gap:12px}.net-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);flex-wrap:wrap}.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.dot.online{background:#10b981}.dot.offline{background:#f59e0b}.offline-note{color:var(--warn-text);font-weight:600}.chip{font-size:.75rem;padding:.2rem .55rem;border-radius:999px;background:var(--bg);border:1px solid var(--border);color:var(--muted)}.chip-warn{background:var(--warn-lt);border-color:var(--warn-bd);color:var(--warn-text)}.chip-danger{background:var(--danger-lt);border-color:var(--danger-bd);color:#991b1b}.chip-ok{background:var(--primary-lt);border-color:var(--primary-bd);color:#166534}.sidebar-user{display:flex;align-items:center;gap:10px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--text-2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.sidebar-user-info{line-height:1.2;min-width:0;flex:1}.sidebar-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11.5px;color:var(--muted-2)}.collapse-logout{background:none;border:none;color:var(--muted);font-size:1.05rem;padding:.4rem;cursor:pointer;align-self:center}.collapse-logout:hover{color:var(--danger)}.link{background:none;border:none;color:var(--primary);padding:.3rem 0;text-align:left;font-size:12px;font-weight:600}.content{padding:28px 34px 48px;min-width:0}.muted{color:var(--muted)}.error{color:var(--danger);font-size:.875rem}.loading{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.small{font-size:.8rem}.topbar{display:none}.hamburger{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text);padding:.2rem .4rem}.drawer-backdrop{display:none}@media (max-width: 720px){.shell,.shell.sidebar-collapsed{grid-template-columns:1fr}.topbar{display:flex;align-items:center;gap:.7rem;position:sticky;top:0;z-index:40;background:var(--surface);border-bottom:1px solid var(--border);padding:.6rem .9rem}.topbar .brand{flex:1;font-size:1.05rem;font-weight:700;color:var(--text)}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;width:78%;max-width:280px;padding:22px 14px!important;transform:translate(-100%);transition:transform .22s ease;box-shadow:0 0 30px #0f172a2e;height:100vh}.sidebar.open{transform:translate(0)}.shell.sidebar-collapsed .nav{justify-content:flex-start;padding:9px 12px;box-shadow:none}.shell.sidebar-collapsed .nav.active{box-shadow:inset 2px 0 0 var(--primary)}.sidebar-logo-text{display:flex!important}.collapse-btn{display:none}.drawer-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f172a73}.content{padding:1.2rem}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:24px}.page-title{font-size:25px;font-weight:700;letter-spacing:-.02em;margin:0}.page-sub{font-size:13.5px;color:var(--muted);margin:5px 0 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.4rem 1.6rem}.card.warn{border-color:var(--warn-bd);background:var(--warn-lt)}.card.danger{border-color:var(--danger-bd);background:var(--danger-lt)}.cards{display:flex;gap:1rem;flex-wrap:wrap;margin:0 0 1.4rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.4rem;min-width:140px;display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow-sm)}.stat-card.warn{border-color:var(--warn-bd);background:var(--warn-lt)}.stat-card.danger{border-color:var(--danger-bd);background:var(--danger-lt)}.stat-card.highlight{border-color:var(--primary);background:#f0fdf9}.card-value{font-size:1.9rem;font-weight:700;letter-spacing:-.02em;font-family:IBM Plex Mono,monospace}.card-label{font-size:.8rem;color:var(--muted);font-weight:500}.card-info{font-size:.75rem;color:var(--muted-2)}.section-range{font-size:.8rem;color:var(--muted-2);font-weight:400}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border:none;border-radius:10px;background:var(--primary);color:var(--primary-ink);font-weight:600;font-size:13.5px;cursor:pointer;box-shadow:0 1px 2px #0f766e40;transition:background .15s}.btn:hover{background:var(--primary-dk)}.btn:disabled{opacity:.6;cursor:default}.btn.ghost{background:transparent;color:var(--primary);border:1px solid var(--primary-bd);box-shadow:none}.btn.ghost:hover{background:var(--primary-lt)}.btn.danger-btn{background:var(--danger);box-shadow:none}.btn-sm{padding:5px 11px;font-size:.8rem;border-radius:8px}.filters{display:flex;gap:.6rem;margin:0 0 1rem;flex-wrap:wrap}.input{padding:10px 14px;border:1px solid var(--border);border-radius:10px;color:var(--text);background:#f8fafc;min-width:0;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #0f766e1a;outline:none}.filters .input:first-child{flex:1;min-width:200px}.alert-bar{display:flex;gap:.5rem;margin:0 0 1rem;flex-wrap:wrap}.table-wrap{overflow-x:auto;max-width:100%;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm)}.report-grid>*,.pos>*,.cust-layout>*{min-width:0}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th{text-align:left;padding:11px 18px;font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--muted-2);text-transform:uppercase;background:#f8fafc;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2)}.table td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--border-2);font-size:13.5px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#fafbfc}.table .num{text-align:right;font-family:IBM Plex Mono,monospace}.table td.num{font-size:13px}.cell-actions{display:flex;gap:1rem;justify-content:flex-end}.tag{display:inline-block;margin-left:.4rem;font-size:.68rem;padding:.1rem .4rem;border-radius:4px;vertical-align:middle;font-weight:600}.tag-controlled{background:#ede9fe;color:#5b21b6}.tag-warn{background:var(--warn-lt);color:var(--warn-text)}.pagination{display:flex;align-items:center;justify-content:center;gap:.9rem;margin-top:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:grid;place-items:center;padding:1rem;z-index:50}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:580px;max-height:90vh;overflow:auto;box-shadow:0 20px 40px #0f172a2e}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:1.1rem;font-weight:700}.icon-btn{background:none;border:none;font-size:1.4rem;line-height:1;color:var(--muted);padding:.2rem;border-radius:6px}.icon-btn:hover{background:var(--bg)}.modal-body{padding:1.4rem}.form{display:flex;flex-direction:column;gap:1rem}.field{display:flex;flex-direction:column;gap:.35rem}.field>span,.field>label{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.02em}.field .input{width:100%}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.checkbox,.radio-row label{display:flex;align-items:center;gap:.45rem;font-size:.88rem;color:var(--text);cursor:pointer}.radio-row{display:flex;gap:1.2rem}.form-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:.4rem}@media (max-width: 560px){.grid2{grid-template-columns:1fr}}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;justify-content:flex-end;z-index:60}.drawer{width:100%;max-width:600px;height:100%;overflow-y:auto;background:var(--surface);box-shadow:-10px 0 40px #0f172a26;padding:1.6rem 1.8rem}.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}.drawer-head h2{margin:0}.drawer-actions{display:flex;gap:.5rem;flex-shrink:0}.print-head{margin-bottom:.8rem}.drawer-totals{margin-top:1rem;display:flex;flex-direction:column;gap:.3rem}.drawer-totals>div{display:flex;justify-content:space-between;font-size:.95rem}.drawer-totals .grand{font-weight:700;font-size:1.05rem;border-top:1px solid var(--border);padding-top:.4rem;margin-top:.2rem}.drawer-totals .status-line{justify-content:flex-start;gap:.5rem;align-items:center;margin-top:.4rem}.drawer-pay{margin-top:1.4rem;border-top:1px solid var(--border);padding-top:1rem}.drawer-pay h3{margin:0 0 .6rem;font-size:.95rem}.pay-row{display:flex;gap:.6rem}.pay-row .input{flex:1}.pay-quick{display:flex;gap:.6rem;margin-top:.6rem}.row-click{cursor:pointer}.row-click:hover{background:var(--bg)}.cust-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:26px;align-items:start}@media (max-width: 820px){.cust-layout{grid-template-columns:1fr}}.party-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px;position:sticky;top:24px}.party-search-wrap{position:relative;margin-bottom:12px}.party-search-wrap .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted-2);font-size:14px;pointer-events:none}.party-search{width:100%;padding:10px 14px 10px 32px;border:1px solid var(--border);border-radius:10px;font-size:13.5px;color:var(--text);background:#f8fafc}.party-search:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #0f766e1a;outline:none}.party-list{display:flex;flex-direction:column;gap:6px;max-height:calc(100vh - 220px);overflow-y:auto;padding-right:2px}.party-card{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;border:1px solid var(--border-2);background:var(--surface);cursor:pointer;transition:background .12s,border-color .12s;text-align:left;width:100%}.party-card:hover{background:var(--bg)}.party-card.active{border-color:#99f6e4;background:#f0fdfa;box-shadow:inset 3px 0 0 var(--primary)}.party-avatar{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;background:#eef2f6;color:#475569}.party-card.active .party-avatar{background:var(--primary);color:#fff}.party-name{font-size:14px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.party-card.active .party-name{color:var(--primary)}.party-phone{font-size:12px;color:var(--muted-2);font-family:IBM Plex Mono,monospace;margin-top:2px}.party-pill{font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:7px;white-space:nowrap;font-family:IBM Plex Mono,monospace;flex-shrink:0}.party-pill.owes{color:var(--danger);background:var(--danger-lt)}.party-pill.settled{color:var(--primary);background:var(--primary-lt)}.detail-stack{display:flex;flex-direction:column;gap:20px}.detail-empty{text-align:center;color:var(--muted);padding:3rem 1rem}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.profile-avatar{width:58px;height:58px;border-radius:14px;flex-shrink:0;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700}.profile-name{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.profile-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.profile-meta span{font-size:13px;color:#475569}.profile-balance-block{text-align:right;padding-left:22px;border-left:1px solid var(--border-2)}.profile-balance-label{font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2)}.profile-balance-value{font-size:28px;font-weight:700;letter-spacing:-.02em;font-family:IBM Plex Mono,monospace;margin-top:4px}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.section-card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:18px 24px 14px;flex-wrap:wrap}.section-card-head h3{font-size:15px;font-weight:700}.section-card-body{padding:20px 24px}.ledger-wrap{overflow-x:auto}.ledger-table{width:100%;border-collapse:collapse;min-width:520px}.ledger-table th{text-align:left;padding:10px 18px;font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--muted-2);text-transform:uppercase;background:#f8fafc;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2)}.ledger-table td{padding:13px 18px;border-bottom:1px solid #f1f5f9;font-size:13.5px;vertical-align:middle}.ledger-table tr:hover td{background:#fafbfc}.ledger-icon{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.ledger-closing{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:14px 24px;background:#f8fafc;border-top:1px solid var(--border-2)}.record-pay-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px 24px}.record-pay-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.record-pay-row .field{flex:1;min-width:140px}.adjust-box{margin-top:14px;padding:16px;background:#f8fafc;border:1px dashed #d8e0e6;border-radius:12px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.adjust-box .field{flex:1;min-width:120px}.invoice-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 16px;border:1px solid var(--border-2);border-radius:11px;transition:border-color .12s,background .12s;cursor:pointer}.invoice-row:hover{border-color:var(--primary-bd);background:#fafdfc}.invoice-no{font-size:14px;font-weight:700;font-family:IBM Plex Mono,monospace}.invoice-meta{font-size:12.5px;color:var(--muted-2)}.invoice-badge{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:6px}.invoice-badge.paid{background:var(--primary-lt);color:var(--primary)}.invoice-badge.credit{background:var(--warn-lt);color:var(--warn-text)}.invoice-amount{font-size:15px;font-weight:700;font-family:IBM Plex Mono,monospace;white-space:nowrap}.pos{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:start}.pos-search{position:relative}.pos-search .input{width:100%;font-size:1rem;padding:.7rem .8rem}.pos-results,.dropdown{list-style:none;margin:.3rem 0 0;padding:0;border:1px solid var(--border);border-radius:10px;background:var(--surface);max-height:320px;overflow:auto;box-shadow:var(--shadow-md)}.pos-results li button,.dropdown li button{width:100%;text-align:left;background:none;border:none;padding:.6rem .8rem;display:flex;justify-content:space-between;align-items:center;gap:.6rem;border-bottom:1px solid var(--border-2);font-size:13.5px}.pos-results li:last-child button,.dropdown li:last-child button{border-bottom:none}.pos-results li button:hover:not(:disabled),.dropdown li button:hover{background:var(--bg)}.pos-results li button:disabled{opacity:.45;cursor:not-allowed}.pos-cart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.2rem;box-shadow:var(--shadow-sm)}.pos-cart .table-wrap{border:none;border-radius:0;box-shadow:none}.qty{width:60px;text-align:right;padding:.3rem .4rem;border:1px solid var(--border);border-radius:6px;font-family:IBM Plex Mono,monospace}.pos-checkout{margin-top:1rem;display:flex;flex-direction:column;gap:.8rem}.totals,.receipt-totals{display:flex;flex-direction:column;gap:.25rem;font-size:.92rem}.totals>div,.receipt-totals>div{display:flex;justify-content:space-between}.totals .grand,.receipt-totals .grand{font-weight:700;font-size:1.05rem;border-top:1px solid var(--border);padding-top:.3rem;margin-top:.2rem}.change{padding:.55rem .7rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);font-weight:600;font-family:IBM Plex Mono,monospace}.checkout-btn{padding:.8rem;font-size:1rem}.cust-picker{position:relative}.cust-selected{display:flex;justify-content:space-between;align-items:center;padding:.5rem .7rem;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.cust-add{display:flex;gap:.4rem;flex-wrap:wrap}.cust-add .input{flex:1;min-width:120px}@media (max-width: 860px){.pos{grid-template-columns:1fr}}.receipt{font-size:.9rem}.receipt-head{text-align:center;margin-bottom:.8rem}.receipt-items{width:100%;border-collapse:collapse;margin-bottom:.6rem}.receipt-items td{padding:.2rem 0;border-bottom:1px dashed var(--border)}.receipt-status-badge{display:inline-block;margin-top:.4rem;padding:.15rem .6rem;border-radius:6px;font-weight:700;font-size:.8rem;letter-spacing:.03em}.receipt-status-badge.paid{background:var(--primary-lt);color:#166534;border:1px solid var(--primary-bd)}.receipt-status-badge.credit{background:var(--danger-lt);color:#991b1b;border:1px solid var(--danger-bd)}.print-only{display:none}@media print{body *{visibility:hidden}.receipt,.receipt *,.print-area,.print-area *{visibility:visible}.receipt,.print-area{position:absolute;top:0;left:0;width:100%}.no-print{display:none}.print-only{display:block}}.section-title{font-size:1rem;font-weight:700;margin:1.4rem 0 .6rem;color:var(--text-2)}.chart{display:flex;align-items:flex-end;gap:4px;height:180px;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow-x:auto}.bar-col{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-width:26px;height:100%;gap:4px}.bar{width:16px;background:var(--primary);border-radius:3px 3px 0 0;min-height:2px;transition:height .3s ease}.bar-label{font-size:.62rem;color:var(--muted);white-space:nowrap}.bar-val{font-size:.58rem;color:var(--muted-2);white-space:nowrap;font-family:IBM Plex Mono,monospace;display:none}.bar-col:hover .bar-val{display:block}.dash-chart-wrap{display:flex;gap:1.2rem;align-items:flex-start}.dash-chart{flex:1;height:200px;gap:8px}.dash-chart .bar{width:22px}.week-totals{display:flex;flex-direction:column;gap:1rem;justify-content:center;min-width:140px}.week-stat{display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.2rem}.week-stat-val{font-size:1.4rem;font-weight:700;font-family:IBM Plex Mono,monospace;color:var(--primary)}.week-stat-lbl{font-size:.78rem;color:var(--muted)}.card-link{font-size:.75rem;color:var(--primary);text-decoration:none;margin-top:2px}.card-link:hover{text-decoration:underline}.dash-cta{margin-top:2rem;display:flex;justify-content:center}@media (max-width: 700px){.dash-chart-wrap{flex-direction:column}.week-totals{flex-direction:row}}.report-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.2rem;align-items:start;margin-top:.5rem}@media (max-width: 900px){.report-grid{grid-template-columns:1fr}}.cust-history{margin-top:.9rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:1rem}.cust-history-head{font-weight:600;font-size:.9rem;margin-bottom:.5rem}.reorder-filter{width:100%;margin-bottom:.5rem;font-size:.85rem;padding:.4rem .6rem}.reorder-list{list-style:none;margin:0 0 .5rem;padding:0;display:flex;flex-direction:column;gap:.35rem;max-height:220px;overflow:auto}.reorder-list li{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.reorder-name{font-size:.86rem}.cust-bills{margin-top:.5rem;display:flex;flex-direction:column;gap:.4rem}.cust-bills summary{display:flex;justify-content:space-between;gap:.6rem;cursor:pointer;padding:.3rem 0;list-style:none}.cust-bills details{border-top:1px solid var(--border)}.mini-table{width:100%;border-collapse:collapse;font-size:.82rem}.mini-table td{padding:.2rem 0;border-bottom:1px dashed var(--border)}.last-paid{display:inline-block;margin-top:.15rem;color:var(--primary)}.scroll-list{max-height:calc(100vh - 220px);min-height:120px;overflow-y:auto}.list-row{display:block;width:100%;text-align:left;padding:.7rem 1rem;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer}.list-row:hover{background:var(--bg)}.list-row.active{background:var(--primary-lt)}.ledger-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.8rem}.ledger-actions{display:flex;align-items:center;gap:.6rem}.ledger-closing{text-align:right;margin-top:.6rem}.ledger-record{margin-top:1.2rem;border-top:1px solid var(--border);padding-top:1rem}.ledger-record h4{margin:0 0 .6rem;font-size:.95rem;font-weight:700}.ledger-record-row{display:flex;gap:.6rem;flex-wrap:wrap}.ledger-record-row .input{flex:1;min-width:110px}.ledger-adjust{margin-top:.8rem}.settings-wrap{max-width:760px}.qty.wide{width:110px;text-align:left}.qty.price{width:80px}
