*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f1f5f9;--s:#fff;--s2:#f8fafc;--s3:#f1f5f9;--b:rgba(0,0,0,0.07);--b2:rgba(0,0,0,0.13);--t:#0f172a;--t2:#64748b;--t3:#94a3b8;--blue:#2563eb;--blue2:#1d4ed8;--bluebg:#eff6ff;--bluetxt:#1d4ed8;--green:#16a34a;--greenbg:#dcfce7;--greentxt:#15803d;--amber:#d97706;--amberbg:#fef3c7;--ambertxt:#92400e;--red:#dc2626;--redbg:#fee2e2;--redtxt:#991b1b;--purple:#7c3aed;--purplebg:#ede9fe;--purpletxt:#5b21b6;--r:14px;--rs:8px;--rxs:6px;--sh:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);--shm:0 4px 20px rgba(0,0,0,0.08);--shl:0 20px 60px rgba(0,0,0,0.12);--sw:240px}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:Geist,system-ui,sans-serif;background:var(--bg);color:var(--t);display:flex;min-height:100vh}.sidebar{width:var(--sw);background:var(--s);border-right:1px solid var(--b);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.slogo{gap:10px;padding:18px 16px;border-bottom:1px solid var(--b)}.slogo,.slogo-ic{display:flex;align-items:center}.slogo-ic{width:32px;height:32px;background:var(--blue);border-radius:8px;justify-content:center;flex-shrink:0}.slogo-t{font-size:14px;font-weight:600;letter-spacing:-.3px}.slogo-s{font-size:10px;color:var(--t3)}.snav{padding:10px 8px;flex:1 1}.ssec{font-size:9px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.9px;padding:12px 10px 4px}.si{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--rxs);color:var(--t2);font-size:13px;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit;transition:all .15s;margin-bottom:2px}.si svg{flex-shrink:0;opacity:.6}.si:hover{background:var(--s2);color:var(--t)}.si:hover svg{opacity:.9}.si.on{background:var(--bluebg);font-weight:500}.si.on,.si.on svg{color:var(--bluetxt)}.si.on svg{opacity:1}.sbadge{margin-left:auto;background:var(--redbg);color:var(--redtxt);font-size:9px;font-weight:600;padding:1px 6px;border-radius:20px}.sfoot{padding:14px 12px;border-top:1px solid var(--b)}.sdot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pulse 2s infinite;display:inline-block;margin-right:6px;vertical-align:middle}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.month-switcher{padding:8px 8px 4px}.month-label{font-size:9px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.9px;padding:8px 10px 6px}.month-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:3px;gap:3px;padding:0 4px}.mbtn{padding:5px 3px;border:1px solid var(--b2);border-radius:5px;background:var(--s2);color:var(--t2);font-size:10.5px;font-weight:500;cursor:pointer;text-align:center;transition:all .15s;font-family:inherit}.mbtn:hover{background:var(--bluebg);color:var(--bluetxt)}.mbtn.on,.mbtn:hover{border-color:var(--blue)}.mbtn.on{background:var(--blue);color:#fff}.main{margin-left:var(--sw);flex:1 1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:58px;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--b);display:flex;align-items:center;padding:0 24px;gap:10px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.ttl{font-size:15px;font-weight:600;letter-spacing:-.3px;flex:1 1}.tsub{font-size:11px;color:var(--t3);margin-top:1px}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--rxs);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--b2);background:var(--s);color:var(--t2);font-family:inherit;transition:all .15s;white-space:nowrap;text-decoration:none}.btn:hover{background:var(--s2);color:var(--t)}.btn.p{background:var(--blue);color:#fff;border-color:var(--blue)}.btn.p:hover{background:var(--blue2)}.content{padding:22px 24px;flex:1 1}.page{display:block;animation:fadeUp .2s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.mgrid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin-bottom:18px}.mc{background:var(--s);border-radius:var(--r);padding:18px 20px;border:1px solid var(--b);box-shadow:var(--sh);position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}.mc:hover{box-shadow:var(--shm);transform:translateY(-1px)}.mclbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.mclbl,.mcval{font-weight:600}.mcval{font-size:24px;letter-spacing:-.8px;line-height:1}.mcsub{margin-top:8px}.mcbar{position:absolute;bottom:0;left:0;right:0;height:3px}.mcprog{height:5px;background:var(--s3);margin-top:9px;overflow:hidden}.mcpf,.mcprog{border-radius:5px}.mcpf{height:100%;transition:width .9s cubic-bezier(.4,0,.2,1)}.mcdelta{font-size:11px;margin-top:6px;display:flex;gap:4px}.mcdelta,.pill{align-items:center}.pill{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:10.5px;font-weight:500}.pb{background:var(--bluebg);color:var(--bluetxt)}.pg{background:var(--greenbg);color:var(--greentxt)}.pa{background:var(--amberbg);color:var(--ambertxt)}.pr{background:var(--redbg);color:var(--redtxt)}.pp{background:var(--purplebg);color:var(--purpletxt)}.card{background:var(--s);border-radius:var(--r);border:1px solid var(--b);box-shadow:var(--sh);overflow:hidden;margin-bottom:18px}.ch{padding:16px 20px 14px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;gap:12px}.ct{font-size:13.5px;font-weight:600;letter-spacing:-.2px}.cs{font-size:11.5px;color:var(--t3);margin-top:2px}.cgrid2{grid-template-columns:1.6fr 1fr;grid-gap:14px}.cgrid2,.cgrid3{display:grid;gap:14px;margin-bottom:18px}.cgrid3{grid-template-columns:1fr 1fr 1fr;grid-gap:14px}.filters{display:flex;gap:8px;padding:14px 18px;border-bottom:1px solid var(--b);flex-wrap:wrap}.sw2{position:relative;flex:1 1;min-width:160px}.sw2 svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--t3);pointer-events:none}.sw2 input{width:100%;padding:7px 9px 7px 30px;border:1px solid var(--b2);border-radius:var(--rxs);background:var(--s2);color:var(--t);font-size:12.5px;font-family:inherit;outline:none;transition:border-color .15s}.sw2 input:focus{border-color:var(--blue);background:var(--s)}select{padding:7px 11px;border:1px solid var(--b2);border-radius:var(--rxs);background:var(--s2);color:var(--t);font-size:12.5px;font-family:inherit;outline:none;cursor:pointer}select:focus{border-color:var(--blue)}.tw{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{padding:10px 14px;text-align:left;font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;background:var(--s2);border-bottom:1px solid var(--b);white-space:nowrap;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}thead th:hover{color:var(--t)}tbody tr{border-bottom:1px solid var(--b);cursor:pointer;transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--s2)}tbody td{padding:11px 14px;white-space:nowrap;font-size:13px}.ltag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;background:var(--s3);border:1px solid var(--b2);color:var(--t2);font-size:11px;font-weight:500}.mono{font-family:Geist Mono,monospace;font-size:12.5px}.green{color:var(--greentxt)}.red{color:var(--redtxt)}.amber{color:var(--ambertxt)}.blue{color:var(--bluetxt)}.sbadge2{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}.sdot2{width:5px;height:5px;border-radius:50%;flex-shrink:0}.sp{background:var(--greenbg);color:var(--greentxt)}.spt{background:var(--amberbg);color:var(--ambertxt)}.sd{background:var(--redbg);color:var(--redtxt)}.pag{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--b);font-size:12px;color:var(--t3)}.pagbtns{display:flex;gap:4px}.pb2{padding:4px 10px;border:1px solid var(--b2);border-radius:var(--rxs);background:var(--s);color:var(--t2);font-size:12px;cursor:pointer;font-family:inherit;transition:all .15s}.pb2:hover:not(:disabled){background:var(--s2);color:var(--t)}.pb2.on{background:var(--blue);color:#fff;border-color:var(--blue)}.pb2:disabled{opacity:.3;cursor:not-allowed}.trend-table{width:100%;border-collapse:collapse;font-size:12px}.trend-table th{padding:8px 10px;text-align:center;font-size:9px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;background:var(--s2);border-bottom:1px solid var(--b);border-right:1px solid var(--b)}.trend-table th:first-child{text-align:left;width:160px}.trend-table td{padding:8px 10px;text-align:right;border-bottom:1px solid var(--b);border-right:1px solid var(--b);font-family:Geist Mono,monospace;font-size:11px}.trend-table td:first-child{text-align:left;font-family:Geist,sans-serif;font-weight:500;font-size:12px;color:var(--t)}.trend-table tr:last-child td{border-bottom:none}.trend-table .cur{background:var(--bluebg);font-weight:600;color:var(--bluetxt)}.trend-table .zero{color:var(--t3)}.trend-cell-bar{height:3px;border-radius:2px;margin-top:3px;background:var(--blue);opacity:.4}.lgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));grid-gap:12px;gap:12px}.lcard{background:var(--s);border-radius:var(--r);border:1px solid var(--b);box-shadow:var(--sh);padding:18px;transition:box-shadow .2s,transform .2s}.lcard:hover{box-shadow:var(--shm);transform:translateY(-1px)}.pbar{height:5px;background:var(--s3);overflow:hidden;margin-top:8px}.pbar,.pfill{border-radius:5px}.pfill{height:100%;transition:width .7s ease}.alert{display:flex;align-items:flex-start;gap:12px;padding:13px 16px;border-radius:var(--rxs);border:1px solid;margin-bottom:8px;cursor:pointer;transition:opacity .15s}.alert:hover{opacity:.82}.alert.hi{background:var(--redbg);border-color:rgba(220,38,38,.2)}.alert.la{background:var(--amberbg);border-color:rgba(217,119,6,.2)}.mbg{position:fixed;inset:0;background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .2s}.mbg.open{opacity:1;pointer-events:all}.modal{background:var(--s);border-radius:18px;box-shadow:var(--shl);width:100%;max-width:520px;padding:26px;transform:scale(.95) translateY(10px);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}.mbg.open .modal{transform:scale(1) translateY(0)}.mhd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.mtitle{font-size:17px;font-weight:600;letter-spacing:-.4px}.mclose{width:28px;height:28px;border-radius:50%;background:var(--s2);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--t2);transition:all .15s}.mclose:hover{background:var(--redbg);color:var(--redtxt)}.dgrid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:14px}.di{background:var(--s2);border-radius:var(--rxs);padding:12px 14px}.dlbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.dlbl,.dval{font-weight:600}.dval{font-size:15px;letter-spacing:-.3px;font-family:Geist Mono,monospace}.wa{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:11px;background:#25d366;color:#fff;border-radius:var(--rxs);font-size:13px;font-weight:500;text-decoration:none;margin-top:14px;transition:opacity .15s}.wa:hover{opacity:.9}.cfgwrap{max-width:580px}.cfgcard{background:var(--s);border-radius:var(--r);border:1px solid var(--b);box-shadow:var(--sh);overflow:hidden;margin-bottom:14px}.cfghd{padding:16px 20px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:10px}.cfgt{font-size:14px;font-weight:600}.cfgbody{padding:18px 20px}.flbl{display:block;font-size:10.5px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.finput{width:100%;padding:9px 12px;border:1px solid var(--b2);border-radius:var(--rxs);background:var(--s2);color:var(--t);font-size:13px;font-family:Geist Mono,monospace;outline:none;transition:border-color .15s;margin-bottom:14px}.finput:focus{border-color:var(--blue);background:var(--s)}.fhint{font-size:11px;color:var(--t3);margin-top:-10px;margin-bottom:14px;line-height:1.5}.steps{background:var(--s2);border-radius:var(--rxs);padding:14px;font-size:12.5px;color:var(--t2);line-height:2;margin-bottom:16px}.steps strong{color:var(--t)}.colref{background:var(--s2);padding:12px 14px;font-size:11px;font-family:Geist Mono,monospace;color:var(--t2);line-height:2;margin-top:14px;border-left:3px solid var(--blue)}.colref,.toast{border-radius:var(--rxs)}.toast{position:fixed;bottom:22px;right:22px;z-index:999;background:#0f172a;color:#fff;padding:11px 16px;font-size:13px;display:flex;align-items:center;gap:9px;box-shadow:var(--shl);transform:translateY(20px);opacity:0;transition:all .25s;pointer-events:none;max-width:320px}.toast.show{transform:translateY(0);opacity:1}.empty{text-align:center;padding:50px 20px;color:var(--t3)}.ledger-cell{padding:7px 10px;text-align:right;font-size:11px;font-family:Geist Mono,monospace;white-space:nowrap;border-right:1px solid var(--b)}.ledger-cell.paid{background:#f0fdf4;color:#15803d}.ledger-cell.partial{background:#fffbeb;color:#92400e}.ledger-cell.due{background:#fff5f5;color:#991b1b}.ledger-cell.nodata{background:var(--s2);color:var(--t3)}.ledger-cell.total-col{background:#eff6ff;color:#1d4ed8;font-weight:600}.ledger-hdr{padding:7px 10px;text-align:center;font-size:9px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;background:var(--s2);border-bottom:1px solid var(--b);border-right:1px solid var(--b);white-space:nowrap}.ledger-hdr.cur{background:var(--bluebg);color:var(--bluetxt)}.ledger-name{padding:10px 14px;font-size:12px;font-weight:500;left:0;border-right:2px solid var(--b2);min-width:200px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ledger-loc,.ledger-name{position:-webkit-sticky;position:sticky;background:var(--s);z-index:1}.ledger-loc{padding:10px;font-size:11px;left:220px;border-right:1px solid var(--b2);min-width:120px}tbody tr:hover .ledger-loc,tbody tr:hover .ledger-name{background:var(--s2)}.menu-btn{display:none;background:none;border:1px solid var(--b2);border-radius:var(--rxs);padding:6px 8px;cursor:pointer;color:var(--t);align-items:center;justify-content:center}.menu-btn svg{display:block}.sb-scrim{display:none}@media (max-width:1100px){.mgrid{grid-template-columns:1fr 1fr}.cgrid2{grid-template-columns:1fr}.cgrid3{grid-template-columns:1fr 1fr}}@media (max-width:768px){:root{--sw:0px}.sidebar{transform:translateX(-100%);transition:transform .22s ease;width:260px;box-shadow:var(--shl)}.sidebar.open{transform:translateX(0)}.sb-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99;opacity:0;pointer-events:none;transition:opacity .2s}.sb-scrim.on{opacity:1;pointer-events:auto}.main{margin-left:0}.menu-btn{display:inline-flex}.mgrid{grid-template-columns:1fr 1fr}.cgrid2,.cgrid3{grid-template-columns:1fr}.content{padding:14px}.topbar{padding:0 14px;gap:8px}.topbar .ttitle{font-size:14px}.topbar .tdate,.topbar .tmonth{display:none}.modal{width:calc(100vw - 24px);max-width:100%;max-height:90vh;overflow-y:auto}.form-grid-2{grid-template-columns:1fr}.tbl{font-size:12px}.tbl td,.tbl th{padding:8px 6px}.card{border-radius:var(--rs)}.cardh{padding:12px 14px;flex-wrap:wrap;gap:8px}}@media (max-width:480px){.mgrid{grid-template-columns:1fr}}@keyframes spin{to{transform:rotate(1turn)}}.login-wrap{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f1f5f9,#e2e8f0)}.login-card{background:var(--s);border-radius:16px;box-shadow:var(--shm);border:1px solid var(--b);padding:32px;width:100%;max-width:400px}.login-head{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--b)}.form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.form-row label{font-size:10.5px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.5px}.form-row input,.form-row select,.form-row textarea{padding:9px 12px;border:1px solid var(--b2);border-radius:var(--rxs);background:var(--s2);color:var(--t);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--blue);background:var(--s)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.form-err{color:var(--redtxt);font-size:12px;margin-top:6px}