:root{--P:#16a34a;--PD:#15803d;--PL:#dcfce7;--G:#10b981;--GD:#059669;--GL:#d1fae5;--R:#ef4444;--RD:#dc2626;--RL:#fee2e2;--Y:#f59e0b;--YD:#d97706;--YL:#fef3c7;--B:#3b82f6;--BL:#dbeafe;--V:#8b5cf6;--VL:#ede9fe;--T:#14b8a6;--TL:#ccfbf1;--bg:#f6f8fb;--card:#fff;--bdr:#e2e8f0;--txt:#1e293b;--t2:#64748b;--t3:#94a3b8}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--txt);font-size:14px}button{font-family:inherit;cursor:pointer;border:none;border-radius:8px;padding:9px 16px;font-size:14px;font-weight:600}.btn-p{background:var(--P);color:#fff}.btn-p:hover{background:var(--PD)}.btn-g{background:#fff;color:var(--txt);border:1px solid var(--bdr)}.btn-g:hover{background:var(--bg)}.btn-r{background:var(--R);color:#fff}.btn-r:hover{background:var(--RD)}input,select,textarea{font-family:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--bdr);border-radius:8px;width:100%;background:#fff;color:var(--txt)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--P);box-shadow:0 0 0 3px var(--PL)}label{display:block;font-size:12px;font-weight:600;color:var(--t2);margin:0 0 5px}.shell{display:flex;min-height:100vh}.side{width:210px;background:#fff;border-right:1px solid var(--bdr);padding:14px 12px;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;transition:width .18s ease}.side-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:2px 4px 4px;min-height:34px}.brand{min-width:0}.brand img{height:30px;width:auto;max-width:150px;display:block}.brand .fallback{color:#16a34a;font-size:18px;font-weight:800;font-style:italic}.collapse-btn{background:none;border:none;color:var(--t3);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;flex-shrink:0}.collapse-btn svg{width:18px;height:18px}.collapse-btn:hover{background:var(--bg);color:var(--t2)}.side-scroll{flex:1;overflow-y:auto;margin-top:8px;display:flex;flex-direction:column;gap:1px}.nav{display:flex;flex-direction:column;gap:1px}.nav a{display:flex;align-items:center;gap:10px;color:var(--txt);text-decoration:none;padding:7px 11px;border-radius:9px;font-weight:600;font-size:13px;white-space:nowrap}.nav a svg{width:18px;height:18px;flex-shrink:0;color:var(--t2)}.nav a:hover{background:#f3f5f9}.nav a.on{background:var(--PL);color:var(--PD)}.nav a.on svg{color:var(--PD)}.nav-group{margin-top:7px}.nav-label{font-size:10px;letter-spacing:.9px;text-transform:uppercase;color:var(--t3);font-weight:700;padding:1px 11px 4px}.side-foot{margin-top:8px;padding-top:12px;border-top:1px solid var(--bdr);display:flex;align-items:center;gap:8px;font-size:12px;color:var(--t2)}.side-foot .av{width:28px;height:28px;border-radius:50%;background:#e7f8ef;color:#0f9d58;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.side-foot .nm{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-foot .so{background:none;border:none;color:var(--t3);cursor:pointer;padding:5px;width:auto;flex-shrink:0;border-radius:7px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.side-foot .so svg{width:18px;height:18px}.side-foot .so:hover{color:var(--RD);background:var(--RL)}.main{flex:1;padding:26px 32px;max-width:100%;overflow:auto;min-width:0}.shell.collapsed .side{width:64px}.shell.collapsed .brand{display:none}.shell.collapsed .side-top{justify-content:center}.shell.collapsed .nav-label{display:none}.shell.collapsed .nav a{justify-content:center;padding:9px}.shell.collapsed .nav a .lbl{display:none}.shell.collapsed .side-foot{flex-direction:column;gap:8px;justify-content:center}.shell.collapsed .side-foot .nm,.mobile-bar,.side-backdrop{display:none}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:12px;flex-wrap:wrap}.topbar h1{margin:0;font-size:22px;font-weight:800}.topbar h1 small{display:block;font-size:12px;font-weight:500;color:var(--t2)}.card{background:var(--card);border:1px solid var(--bdr);border-radius:14px;box-shadow:0 1px 3px #0000000a}.toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.toolbar .grow{flex:1;min-width:180px}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--t2);padding:9px 13px;border-bottom:1px solid var(--bdr);background:#fafbff}td{padding:9px 13px;border-bottom:1px solid var(--bdr);font-size:13.5px}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg)}.pill{display:inline-block;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700}.pill.Client{background:var(--GL);color:var(--GD)}.pill.Vendor{background:var(--RL);color:var(--RD)}.pill.Supplier{background:#ffedd5;color:#c2410c}.pill.Staff{background:var(--YL);color:var(--YD)}.pill.Tax,.pill.Government{background:var(--BL);color:var(--B)}.pill.Partner{background:var(--VL);color:var(--V)}.pill.InterBank{background:var(--TL);color:var(--T)}.pill.Others{background:#f1f5f9;color:var(--t2)}.chip{display:inline-block;padding:3px 9px;border-radius:7px;background:#eef2f6;color:var(--t2);font-size:12px;font-weight:600;white-space:nowrap}.tbl-scroll{overflow:auto;max-height:calc(100vh - 250px)}.daterange-btn{width:100%;text-align:left;background:#fff;border:1px solid var(--bdr);border-radius:7px;padding:5px 9px;font-size:12px;font-weight:600;color:var(--t2);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.daterange-btn:hover{border-color:var(--P)}.popover-bd{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60}.popover{position:fixed;z-index:61;background:#fff;border:1px solid var(--bdr);border-radius:10px;box-shadow:0 12px 34px #0003;padding:13px;width:215px}.tabs{display:inline-flex;background:#eef2f6;border-radius:10px;padding:3px;gap:2px}.tabs button{background:none;border:none;padding:6px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--t2)}.tabs button.on{background:#fff;color:var(--txt);box-shadow:0 1px 2px #0000001a}.tabs button span{color:var(--t3);font-size:11px;margin-left:5px}.tabs button.on span{color:var(--P)}.actions{display:flex;gap:6px}.icon-btn{padding:6px 10px;font-size:12px;border-radius:7px}.ov{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto}.modal{background:#fff;border-radius:16px;width:100%;max-width:620px;box-shadow:0 20px 60px #00000040}.modal-h{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--bdr)}.modal-h h3{margin:0;font-size:17px}.modal-b{padding:22px}.modal-f{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--bdr)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid2 .full{grid-column:1/-1}.x{background:none;border:none;font-size:22px;color:var(--t3);padding:0 4px;line-height:1}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(175deg,#312e81,#1e1b4b)}.auth-card{background:#fff;border-radius:18px;padding:34px 30px;width:340px;box-shadow:0 20px 60px #0000004d}.auth-card h2{margin:0 0 4px;font-size:20px}.auth-card p{margin:0 0 22px;color:var(--t2);font-size:13px}.auth-card .field{margin-bottom:14px}.auth-card button{width:100%;margin-top:6px}.err{color:var(--RD);font-size:12px;margin-top:10px}.muted{color:var(--t3);font-size:13px;padding:30px;text-align:center}.count{color:var(--t2);font-size:12px;margin-left:auto}.toast-wrap{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:200}.toast{background:#1e293b;color:#fff;padding:11px 18px;border-radius:9px;font-size:13px;font-weight:600;box-shadow:0 8px 24px #00000038;animation:toastIn .18s ease}.toast.success{background:var(--GD)}.toast.error{background:var(--RD)}.toast.info{background:var(--PD)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}thead tr:first-child th{position:sticky;top:0;z-index:5}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}.kpi{background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:15px 17px}.kpi .l{font-size:12px;color:var(--t2);font-weight:600;margin-bottom:6px}.kpi .v{font-size:21px;font-weight:800}.dash-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}button{transition:background .15s ease,color .15s ease,box-shadow .15s ease,transform .05s ease}button:active{transform:translateY(1px)}.nav a,.nav-label{transition:background .15s ease,color .15s ease}input,select,textarea{transition:border-color .15s ease,box-shadow .15s ease}table{font-variant-numeric:tabular-nums}a:focus-visible,button:focus-visible{outline:2px solid var(--P);outline-offset:1px}.btn-p:hover,.btn-r:hover{box-shadow:0 2px 8px #0000001f}.card{transition:box-shadow .15s ease}.side-scroll::-webkit-scrollbar,.main::-webkit-scrollbar,.modal::-webkit-scrollbar,.modal-b::-webkit-scrollbar{width:9px;height:9px}.side-scroll::-webkit-scrollbar-thumb,.main::-webkit-scrollbar-thumb,.modal::-webkit-scrollbar-thumb,.modal-b::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px;border:2px solid transparent;background-clip:content-box}.side-scroll::-webkit-scrollbar-thumb:hover,.main::-webkit-scrollbar-thumb:hover{background:#94a3b8;background-clip:content-box}.side-scroll::-webkit-scrollbar-track,.main::-webkit-scrollbar-track{background:transparent}@media (max-width:820px){body{zoom:1}.shell{display:block;min-height:100vh}.mobile-bar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--bdr);padding:9px 14px}.mobile-bar .ham{background:none;border:none;padding:5px;color:var(--txt);display:flex;border-radius:8px}.mobile-bar .ham svg{width:24px;height:24px}.mobile-logo{height:26px;width:auto}.side{position:fixed;top:0;left:0;height:100vh;width:252px!important;transform:translate(-100%);transition:transform .2s ease;z-index:60;box-shadow:0 12px 50px #00000047}.side.open{transform:none}.shell.collapsed .side{width:252px}.shell.collapsed .brand,.shell.collapsed .nav-label{display:block}.shell.collapsed .nav a{justify-content:flex-start;padding:9px 11px}.shell.collapsed .nav a .lbl{display:inline}.shell.collapsed .side-foot{flex-direction:row;justify-content:flex-start}.shell.collapsed .side-foot .nm{display:block}.collapse-btn{display:none}.side-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:55}.main{padding:16px 14px}.topbar{flex-direction:column;align-items:stretch;gap:12px}.grid2,.dash-2col{grid-template-columns:1fr}.kpis{grid-template-columns:1fr 1fr;gap:10px}.card:has(table){overflow-x:auto}.ov{padding:16px 12px}.modal-b{padding:16px}}@media print{html,body{zoom:1!important}.no-print,.mobile-bar{display:none!important}body:has(.print-host) *{visibility:hidden}body:has(.print-host) .print-host,body:has(.print-host) .print-host *{visibility:visible}body:has(.print-host) .print-host{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;padding:0;display:block}body:has(.print-host) .print-host .invoice-doc{box-shadow:none;border-radius:0;width:100%;max-width:100%}body:not(:has(.print-host)) .side{display:none!important}body:not(:has(.print-host)) .main{padding:0!important}body:not(:has(.print-host)) .toolbar{display:none!important}.card{break-inside:avoid}}
