: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;--sat: env(safe-area-inset-top, 0px);--sab: env(safe-area-inset-bottom, 0px);--sal: env(safe-area-inset-left, 0px);--sar: env(safe-area-inset-right, 0px);--rad-sm:10px;--rad-md:14px;--rad-lg:18px;--rad-xl:22px;--shadow-sm:0 1px 3px rgba(0,0,0,.04);--shadow-md:0 2px 8px rgba(0,0,0,.06);--shadow-lg:0 8px 24px rgba(0,0,0,.08)}*{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:9px;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,.bottom-nav{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:var(--rad-md);box-shadow:var(--shadow-sm)}.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 10px;border-radius:99px;font-size:10.5px;font-weight:700;letter-spacing:.2px}.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}.pill-g{display:inline-block;padding:3px 10px;border-radius:99px;font-size:10.5px;font-weight:700;background:var(--GL);color:var(--GD)}.pill-a{display:inline-block;padding:3px 10px;border-radius:99px;font-size:10.5px;font-weight:700;background:var(--YL);color:var(--YD)}.pill-r{display:inline-block;padding:3px 10px;border-radius:99px;font-size:10.5px;font-weight:700;background:var(--RL);color:var(--RD)}table.mini{font-size:12px}table.mini th,table.mini td{padding:5px 9px}table.mini th{font-size:10px}.tbl-scroll{overflow:auto;max-height:calc(100vh - 250px)}.tbl-scroll tbody td:first-child{position:sticky;left:0;background:#fff;z-index:3}.tbl-scroll thead th:first-child{position:sticky;left:0;z-index:6}.tbl-scroll tbody tr:hover td:first-child{background:var(--bg)}.skel{height:13px;border-radius:6px;background:linear-gradient(90deg,#eef1f5 25%,#e2e8f0 37%,#eef1f5 63%);background-size:400% 100%;animation:shimmer 1.3s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.empty-state{padding:40px 20px;text-align:center}.empty-state svg{width:34px;height:34px;color:var(--t3);opacity:.6;margin-bottom:8px}.empty-state .t{font-weight:600;color:var(--t2);font-size:14px}.empty-state .s{color:var(--t3);font-size:12.5px;margin-top:3px}.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)}.avatar{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;letter-spacing:.3px;flex-shrink:0;background:var(--PL);color:var(--P)}.avatar.sm{width:38px;height:38px;border-radius:12px;font-size:13px}.avatar.Client{background:var(--GL);color:var(--GD)}.avatar.Vendor{background:var(--RL);color:var(--RD)}.avatar.Supplier{background:#ffedd5;color:#c2410c}.avatar.Staff{background:var(--YL);color:var(--YD)}.avatar.Tax,.avatar.Government{background:var(--BL);color:var(--B)}.avatar.Partner{background:var(--VL);color:var(--V)}.avatar.InterBank{background:var(--TL);color:var(--T)}.txn-row{background:var(--card);border:1px solid var(--bdr);border-radius:var(--rad-md);padding:11px 14px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}.txn-row .ic{width:38px;height:38px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.txn-row .ic.in{background:var(--GL);color:var(--PD)}.txn-row .ic.out{background:var(--RL);color:var(--RD)}.txn-row .body{flex:1;min-width:0}.txn-row .desc{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.txn-row .sub{font-size:11px;color:var(--t3);margin-top:1.5px}.txn-row .amt{text-align:right;flex-shrink:0}.txn-row .amt .v{font-size:14px;font-weight:800}.txn-row .amt .v.in{color:var(--P)}.txn-row .amt .v.out{color:var(--R)}.txn-row .amt .cat{font-size:10px;color:var(--t3);margin-top:1px}.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:var(--rad-lg);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:var(--rad-md);padding:15px 17px;box-shadow:var(--shadow-sm);transition:box-shadow .15s ease}.kpi .l{font-size:12px;color:var(--t2);font-weight:600;margin-bottom:6px}.kpi .v{font-size:21px;font-weight:800;letter-spacing:-.3px}.kpi .d{font-size:10.5px;font-weight:600;margin-top:5px}.kpi .d.up{color:var(--P)}.kpi .d.down{color:var(--R)}.dash-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.hero{position:relative;overflow:hidden;border-radius:var(--rad-xl);color:#fff;background:linear-gradient(138deg,#1a7a3e,#16a34a 45%,#0d9488);padding:22px 22px 20px;box-shadow:0 10px 32px #16a34a47}.hero:before{content:"";position:absolute;right:-30px;top:-30px;width:110px;height:110px;border-radius:99px;background:#ffffff12}.hero:after{content:"";position:absolute;right:30px;bottom:-40px;width:80px;height:80px;border-radius:99px;background:#ffffff0d}.hero-label{font-size:11px;font-weight:600;opacity:.7;letter-spacing:.5px;position:relative}.hero-value{font-size:32px;font-weight:800;letter-spacing:-1.2px;margin:6px 0 16px;position:relative}.hero-split{display:flex;position:relative}.hero-split>div{flex:1}.hero-split>div:first-child{border-right:1px solid rgba(255,255,255,.2);padding-right:16px}.hero-split>div:last-child{padding-left:16px}.hero-split .hl{font-size:9.5px;opacity:.65;font-weight:700;letter-spacing:.5px;margin-bottom:3px}.hero-split .hv{font-size:15px;font-weight:800;display:flex;align-items:center;gap:4px}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;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}.shell{display:block;min-height:100vh}.mobile-bar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:40;background:#fff;padding:calc(10px + var(--sat)) 14px 10px;height:calc(56px + var(--sat));box-shadow:0 1px 0 var(--bdr)}.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;padding-top:calc(14px + var(--sat));box-shadow:4px 0 30px #0000002e}.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;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);transition:opacity .2s ease}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:#fff;border-top:1px solid var(--bdr);padding:8px 0 calc(8px + var(--sab));box-shadow:0 -4px 20px #00000012}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--t3);font-size:10px;font-weight:600;padding:4px 0;border-radius:10px;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav a svg{width:22px;height:22px;stroke-width:1.8}.bottom-nav a.on{color:var(--P)}.bottom-nav a.on svg{stroke:var(--P)}body:has(.bottom-nav) .main{padding-bottom:calc(80px + var(--sab))}.main{padding:16px 14px;-webkit-overflow-scrolling:touch;min-height:calc(100vh - 56px - var(--sat))}.topbar{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:16px}.topbar h1{font-size:20px}.grid2,.dash-2col{grid-template-columns:1fr}.kpis{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.kpi{padding:13px 14px;border-radius:var(--rad-sm)}.kpi .v{font-size:18px}.card{border-radius:var(--rad-lg);border:none;box-shadow:var(--shadow-lg)}.tbl-scroll{max-height:none;overflow:visible}.tbl-scroll table,.tbl-scroll thead,.tbl-scroll tbody,.tbl-scroll tr,.tbl-scroll td,.tbl-scroll tfoot{display:block;width:100%}.tbl-scroll thead{display:none}.tbl-scroll tbody tr{border:none;border-radius:var(--rad-md);margin:0 0 10px;padding:8px 4px;background:#fff;box-shadow:var(--shadow-md);overflow:hidden;transition:transform .1s ease,box-shadow .1s ease}.tbl-scroll tbody tr:active{transform:scale(.985);box-shadow:0 1px 4px #00000014}.tbl-scroll tbody td{border:none!important;padding:4px 14px;text-align:left!important}.tbl-scroll tbody td:first-child{position:static;font-size:15px;font-weight:700;color:var(--txt);padding-top:12px;padding-bottom:2px}.tbl-scroll tbody td:last-child{padding-bottom:12px}.tbl-scroll tbody td .actions{justify-content:flex-start;margin-top:6px}.tbl-scroll tfoot tr{border:2px solid var(--bdr);border-radius:var(--rad-md);background:#fafbff;font-weight:700}.tbl-scroll tbody td[data-label]:before{content:attr(data-label);display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-bottom:2px}.toolbar{flex-direction:column;gap:8px}.toolbar .grow{min-width:0}.toolbar>*:not(.grow){align-self:flex-start}button,.icon-btn{min-height:40px;min-width:40px}.btn-p,.btn-r{min-height:44px;border-radius:var(--rad-sm);font-size:15px}input,select,textarea{min-height:44px;font-size:16px!important;border-radius:var(--rad-sm)}.pill{padding:4px 10px;font-size:11.5px}.avatar{border-radius:13px}.ov{align-items:flex-end;padding:60px 0 0}.modal{border-radius:var(--rad-xl) var(--rad-xl) 0 0;max-width:100%;width:100%;padding-bottom:var(--sab);animation:sheetUp .22s cubic-bezier(.32,.72,0,1)}.modal:before{content:"";display:block;width:36px;height:4px;background:var(--bdr);border-radius:2px;margin:12px auto -4px}.modal-h{padding:14px 20px}.modal-b{padding:16px 20px;max-height:70vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-f{padding:12px 20px;gap:8px}.modal-f button{flex:1}@keyframes sheetUp{0%{transform:translateY(100%);opacity:.6}to{transform:translateY(0);opacity:1}}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;max-width:100%;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.toast-wrap{right:50%;left:auto;bottom:calc(72px + var(--sab));transform:translate(50%);width:calc(100vw - 32px);max-width:400px}.toast{text-align:center;border-radius:var(--rad-sm)}.auth-wrap{align-items:flex-end;padding:0}.auth-card{width:100%;border-radius:var(--rad-xl) var(--rad-xl) 0 0;padding:28px 22px calc(28px + var(--sab));box-shadow:0 -8px 40px #0003;animation:sheetUp .25s cubic-bezier(.32,.72,0,1)}.empty-state{padding:60px 20px}.daterange-btn{width:100%}.popover{position:fixed;bottom:calc(70px + var(--sab));left:12px;right:12px;width:auto;border-radius:var(--rad-md)}.hero{padding:18px 18px 16px;border-radius:var(--rad-lg)}.hero-value{font-size:28px}}@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}}
