:root{--ink: #0e1b2a;--ink-2: #1c2c3e;--teal: #0f766e;--teal-d: #0b5750;--teal-ink: #0b3a37;--amber: #f59e0b;--amber-d: #b45309;--bg: #e9edf0;--surface: #ffffff;--surface-2: #f4f6f8;--line: #d4dbe1;--line-strong: #b9c3cc;--ink-text: #0e1b2a;--muted: #5b6b7b;--ok: #15803d;--ok-bg: #dcfce7;--warn: #b45309;--warn-bg: #fef3c7;--err: #b91c1c;--err-bg: #fee2e2;--pending: #0369a1;--pending-bg: #e0f2fe;--radius: 12px;--radius-sm: 9px;--shadow: 0 1px 0 rgba(14,27,42,.04), 0 2px 8px rgba(14,27,42,.06);--sidebar-w: 232px;--font-display: "Barlow Semi Condensed", system-ui, sans-serif;--font-body: "Barlow", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-body);background:var(--bg);color:var(--ink-text);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.45}h1,h2,h3,h4{font-family:var(--font-display);margin:0;line-height:1.1;letter-spacing:.2px}.muted{color:var(--muted)}.small{font-size:13px}.num-display{font-family:var(--font-display);font-variant-numeric:tabular-nums}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--ink);color:#cfd8e3;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:18px 12px;gap:4px}.brand{display:flex;align-items:center;justify-content:center;padding:8px 8px 16px}.brand-logo{width:100%;max-width:178px;height:auto;display:block}.brand .mark{width:34px;height:34px;border-radius:8px;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:18px;box-shadow:inset 0 0 0 2px #ffffff1f}.brand .name{font-family:var(--font-display);font-weight:800;font-size:20px;letter-spacing:1.5px;color:#fff}.brand .sub{font-size:11px;color:#7f8ea0;letter-spacing:.5px;text-transform:uppercase}.nav{display:flex;flex-direction:column;gap:2px}.navitem{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-sm);color:#aebccb;font-weight:600;font-size:15px;background:none;border:0;width:100%;text-align:left;cursor:pointer;font-family:var(--font-body)}.navitem svg{width:20px;height:20px;flex:none}.navitem:hover{background:#ffffff0f;color:#fff}.navitem.active{background:var(--teal);color:#fff}.navitem.active svg{color:#fff}.sidebar-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.08);padding-top:12px}.acct{display:flex;align-items:center;gap:10px;padding:4px 8px}.avatar{width:34px;height:34px;border-radius:50%;flex:none;background:var(--amber);color:var(--ink);display:grid;place-items:center;font-family:var(--font-display);font-weight:800}.acct .who{min-width:0}.acct .who strong{color:#fff;font-weight:600;font-size:14px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acct .who span{font-size:11px;color:#7f8ea0;text-transform:uppercase;letter-spacing:.5px}.signout{margin-top:8px;width:100%}.main{display:flex;flex-direction:column;min-width:0}.appbar{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:60px;gap:12px}.appbar .title{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:.3px;text-transform:uppercase}.appbar-right{display:flex;align-items:center;gap:10px}.content{padding:22px;max-width:1080px;width:100%;margin:0 auto}@media (min-width: 1200px){.content{padding:28px 32px}}.mobilebar,.bottomnav{display:none}.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}.seg button{border:0;background:var(--surface);color:var(--muted);padding:7px 16px;font-weight:700;font-size:13px;cursor:pointer}.seg button+button{border-left:1px solid var(--line)}.seg button.active{background:var(--teal);color:#fff}.todo-card .growcol,.todo-card input,.todo-card textarea{width:100%}.todo-note{margin-top:10px}.todo-note textarea{min-height:46px}.todo-checks{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.todo-checks label{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:13px;cursor:pointer;text-transform:uppercase;letter-spacing:.3px;color:var(--ink-text)}.todo-checks input{width:18px;height:18px;accent-color:var(--teal)}.gldetail{margin:1px 0 9px 14px;border-left:2px solid var(--line)}.gldetail-row{display:grid;grid-template-columns:84px 1fr auto;gap:10px;align-items:baseline;padding:3px 10px;font-size:12.5px;color:var(--muted)}.gldetail-row:nth-child(2n){background:var(--surface-2)}.gldetail-date{white-space:nowrap;font-variant-numeric:tabular-nums}.gldetail-desc{white-space:pre-wrap;word-break:break-word}.gldetail-amt{color:var(--ink-text);white-space:nowrap}.tablewrap{overflow-x:auto}.invtable{width:100%;border-collapse:collapse;min-width:600px}.invtable th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;padding:2px 10px 10px;border-bottom:1px solid var(--line)}.invtable td{padding:11px 10px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}.invtable tbody tr:last-child td{border-bottom:0}.invtable tbody tr:hover{background:var(--surface-2)}.inv-overdue{color:var(--err);font-weight:700}.pill--overdue{background:var(--err-bg);color:var(--err)}.search{padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;min-width:160px;flex:1;max-width:320px;background:var(--surface);color:var(--ink-text)}.invfilters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.invfilters input[type=date]{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:var(--surface);color:var(--ink-text)}.invfilters .muted{margin-left:auto}.rangedate{padding:9px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:var(--surface);color:var(--ink-text)}.dashgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}@media (max-width: 760px){.dashgrid{grid-template-columns:1fr}}.chart{display:block;margin-top:8px}.chart-legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-top:4px}.chart-legend i,.donut-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;vertical-align:middle}.donutwrap{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-top:6px}.donut-legend{list-style:none;margin:0;padding:0;flex:1;min-width:160px}.donut-legend li{display:flex;align-items:center;gap:6px;font-size:12.5px;padding:2.5px 0}.donut-legend .dl-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:6px 12px 6px 10px;background:var(--surface-2);font-size:13px;font-weight:600;cursor:pointer;color:var(--ink-text)}.sync .dot{width:9px;height:9px;border-radius:50%;background:var(--ok)}.sync.is-pending .dot{background:var(--amber)}.sync.is-syncing .dot{background:var(--pending);animation:pulse 1s infinite}.sync.is-offline .dot{background:var(--muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:18px}.card>h2{font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}.card>h2+.muted{margin-top:2px}.card h3{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;background:var(--teal);color:#fff;font-family:var(--font-body);font-weight:700;font-size:15px;padding:13px 18px;border-radius:var(--radius-sm);width:100%;letter-spacing:.2px;transition:background .12s ease}.btn:hover{background:var(--teal-d)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:default}.btn--accent{background:var(--amber);color:var(--ink);width:auto;padding:15px 30px;border-radius:999px}.btn--accent:hover{background:var(--amber-d);color:#fff}.btn--ghost{width:auto;background:#fff;color:var(--teal);border:1.5px solid var(--line-strong);padding:10px 16px;font-size:14px}.btn--ghost:hover{background:var(--surface-2);border-color:var(--teal)}.btn--ghost:active{transform:translateY(1px)}.linkbtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;color:var(--teal);font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;padding:12px 0 0;width:100%}.linkbtn:hover{text-decoration:underline}.form{display:flex;flex-direction:column;gap:14px;margin-top:16px}.field{display:flex;flex-direction:column;gap:6px}.field>span{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.field input,.field select,.editrow input,.lineitems input,.filterdate input{font-family:var(--font-body);font-size:16px;padding:12px 14px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);background:#fff;color:var(--ink-text)}.field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%235b6b7b' stroke-width='2' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.field input:focus,.field select:focus,.lineitems input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #0f766e26}.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.checkrow{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;padding:12px 0}.checkrow input,.lineitems input[type=checkbox]{width:auto}.alert{background:var(--err-bg);color:var(--err);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:11px 13px;font-size:14px;font-weight:500}.breakdown{display:flex;justify-content:space-between;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;flex-wrap:wrap}.breakdown span{display:flex;flex-direction:column;gap:3px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.breakdown strong{color:var(--ink-text);font-family:var(--font-display);font-size:19px;font-weight:800}.list{list-style:none;padding:0;margin:14px 0 0}.listrow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 2px;border-top:1px solid var(--line)}.listrow:first-child{border-top:none}.listrow strong{font-weight:600;font-size:15px}.growcol{flex:1;min-width:0}.rowend{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:none;text-align:right}.rowend .num-display{font-size:17px;font-weight:800}.rowbtns{display:flex;align-items:center;gap:8px;flex:none}.rowbtns .linkbtn{width:auto;padding:0;color:var(--err)}.rowbtns a.btn--ghost,.paylink a.btn--ghost{text-decoration:none;display:inline-flex;align-items:center}.rowbtns select{font-family:var(--font-body);font-size:13px;padding:7px 9px;border:1.5px solid var(--line-strong);border-radius:8px;background:#fff}.editrow{display:flex;flex-direction:column;gap:8px;width:100%}.filters{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.filtersel{font-family:var(--font-body);font-size:13px;padding:8px 11px;border:1.5px solid var(--line-strong);border-radius:8px;background:#fff;font-weight:600}.filterdate{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.filterdate input{font-size:13px;padding:7px 9px}.pill{font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-body);display:inline-block}.pill--ok{background:var(--ok-bg);color:var(--ok)}.pill--warn{background:var(--warn-bg);color:var(--warn)}.pill--pending{background:var(--pending-bg);color:var(--pending)}.pill--draft{background:#eef1f4;color:#475569}.pill--sent{background:var(--pending-bg);color:var(--pending)}.pill--paid{background:var(--ok-bg);color:var(--ok)}.pill--void{background:var(--err-bg);color:var(--err)}.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--teal)}.stat.accent:before{background:var(--amber)}.stat.ok:before{background:var(--ok)}.stat .label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.stat .value{font-family:var(--font-display);font-weight:800;font-size:34px;line-height:1.05;margin-top:6px;font-variant-numeric:tabular-nums}.stat .meta{font-size:13px;color:var(--muted);margin-top:4px}.quickrow{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.quickrow .btn,.quickrow .btn--ghost{width:auto;flex:1 1 auto;min-width:140px;text-align:center;justify-content:center}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar .btn--accent{width:auto}.formcard{border-left:4px solid var(--amber);animation:slidein .14s ease}@keyframes slidein{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.formcard-head{display:flex;align-items:center;justify-content:space-between}.formcard-head h3{font-size:17px}.closex{width:auto!important;padding:0 6px!important;color:var(--muted);font-size:20px;line-height:1}.backbtn{width:auto}@media (max-width: 899px){.toolbar{flex-direction:column;align-items:stretch}.toolbar .btn--accent{width:100%}}.shell{max-width:460px;margin:0 auto;padding:24px 16px;min-height:100vh}.shell .topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 4px 24px}.shell .topbar h1{color:var(--teal);font-size:30px;font-weight:800;letter-spacing:2px}.authwrap{display:grid;place-items:center;min-height:100vh;padding:20px;background:radial-gradient(1200px 500px at 50% -10%,rgba(15,118,110,.1),transparent 60%),var(--bg)}.qr{display:flex;justify-content:center;margin:16px 0;min-height:220px;align-items:center}.qr img{border-radius:var(--radius-sm);border:1px solid var(--line)}.secret{display:inline-block;margin-top:4px;font-size:15px;letter-spacing:2px;background:var(--surface-2);padding:7px 10px;border-radius:8px;word-break:break-all;font-family:var(--font-display)}.codes{list-style:none;padding:14px;margin:16px 0;background:var(--surface-2);border-radius:var(--radius-sm);display:grid;grid-template-columns:1fr 1fr;gap:8px;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:1px}.thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.thumb{position:relative;width:66px;height:66px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line-strong);background:var(--surface-2)}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb--ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:11px;color:var(--muted)}.thumb-x{position:absolute;top:2px;right:2px;width:20px;height:20px;line-height:18px;border:none;border-radius:50%;background:#0e1b2ac7;color:#fff;cursor:pointer;font-size:14px;padding:0}.thumb-badge{position:absolute;bottom:0;left:0;right:0;font-size:9px;text-align:center;background:#b45309eb;color:#fff;font-weight:700;text-transform:uppercase}.photobtn{display:inline-block;text-align:center;cursor:pointer}.lineitems{width:100%;border-collapse:collapse;font-size:14px}.lineitems th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:6px 4px;border-bottom:2px solid var(--line);font-family:var(--font-body);font-weight:800}.lineitems td{padding:5px 4px;border-bottom:1px solid var(--line);vertical-align:middle}.lineitems input{width:100%;font-size:14px;padding:7px 9px}.lineitems input.num{width:68px;text-align:right;font-variant-numeric:tabular-nums}.paybox{margin-top:16px}.paid-banner{background:var(--ok-bg);color:var(--ok);font-weight:800;padding:14px;border-radius:var(--radius-sm);text-align:center;text-transform:uppercase;letter-spacing:.5px}.paylink{display:flex;gap:8px;margin-top:10px;align-items:center}.paylink input{flex:1;min-width:0;font-size:13px;padding:11px 12px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface-2)}.status{display:flex;gap:12px;align-items:flex-start;padding:14px;border-radius:var(--radius-sm);background:var(--surface-2);margin:14px 0}.status .dot{width:12px;height:12px;border-radius:50%;margin-top:4px;flex:none}.status--ok .dot{background:var(--ok)}.status--degraded .dot,.status--offline .dot{background:var(--warn)}.status--error .dot{background:var(--err)}.status--loading .dot{background:var(--muted)}.empty{text-align:center;color:var(--muted);padding:28px 12px}.tabs{display:flex;flex-wrap:wrap;gap:4px}.tabbtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid var(--line-strong);background:#fff;color:var(--muted);font-family:var(--font-body);font-weight:700;font-size:13px;padding:8px 13px;border-radius:999px;cursor:pointer;white-space:nowrap}.tabbtn:hover{border-color:var(--teal);color:var(--teal)}.tabbtn.active{background:var(--teal);color:#fff;border-color:var(--teal)}.gltype{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--teal);border-bottom:2px solid var(--line);padding-bottom:4px;margin-bottom:2px}.glrow{display:flex;justify-content:space-between;gap:12px;padding:7px 2px;border-bottom:1px solid var(--line);font-size:14px}.glrow .num-display{font-variant-numeric:tabular-nums}.glrow--strong{font-weight:800;border-bottom:none;border-top:1px solid var(--line-strong)}.glnet{display:flex;justify-content:space-between;gap:12px;margin-top:12px;padding:12px 14px;background:var(--ink);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:800;font-size:18px}.glnet .num-display{font-variant-numeric:tabular-nums}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0e1b2a73;display:flex;justify-content:flex-end}.drawer{background:var(--surface);width:min(860px,100%);height:100%;overflow:auto;padding:20px;box-shadow:-4px 0 24px #0e1b2a33;animation:drawerin .16s ease}@keyframes drawerin{0%{transform:translate(24px);opacity:.6}to{transform:none;opacity:1}}.drawer .lineitems{margin-top:14px}.drawer .lineitems td{font-size:13px;vertical-align:top}.payedit{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 2px;border-bottom:1px solid var(--line)}.payedit>span{font-size:14px;color:var(--ink-text)}.payedit input.num{width:130px;text-align:right;font-variant-numeric:tabular-nums;padding:8px 10px;border:1.5px solid var(--line-strong);border-radius:8px;font-family:var(--font-body);font-size:14px}@media (max-width: 899px){.app{grid-template-columns:1fr}.sidebar,.appbar{display:none}.mobilebar{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20;background:var(--ink);color:#fff;padding:0 16px;height:56px}.mobilebar .name{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:1.5px;color:#fff}.mobilebar .brand-logo-sm{height:40px;width:auto;display:block}.mobilebar .sync{background:#ffffff1a;border-color:#ffffff2e;color:#fff}.content{padding:16px 14px 88px}.bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:30;background:var(--ink);border-top:1px solid rgba(255,255,255,.1);padding:6px 4px calc(6px + env(safe-area-inset-bottom))}.bottomnav .navitem{flex:1;min-width:0;flex-direction:column;gap:3px;align-items:center;justify-content:center;padding:6px 1px;border-radius:8px;font-size:10px;font-weight:700;color:#93a3b4;text-transform:uppercase;letter-spacing:.2px;white-space:nowrap}.bottomnav .navitem svg{width:22px;height:22px}.bottomnav .navitem.active{background:none;color:var(--amber)}.row2{grid-template-columns:1fr}.statgrid{grid-template-columns:1fr 1fr}.card>h2{font-size:18px}}@media (max-width: 420px){.codes{grid-template-columns:1fr}}.payresult{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 80% at 50% -10%,rgba(15,118,110,.1),transparent 60%),var(--bg)}.payresult-card{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 32px 32px;text-align:center}.payresult-logo{height:44px;width:auto;margin-bottom:26px}.payresult-badge{width:76px;height:76px;margin:0 auto 20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.payresult-badge svg{width:38px;height:38px}.payresult-badge.is-ok{background:var(--ok-bg);color:var(--ok)}.payresult-badge.is-cancel{background:var(--warn-bg);color:var(--warn)}.payresult h1{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:.3px;color:var(--ink-text);margin:0 0 10px}.payresult-sub{font-size:15px;line-height:1.5;color:var(--muted);margin:0 auto;max-width:340px}.payresult-dl{display:inline-flex;align-items:center;justify-content:center;margin-top:24px;text-decoration:none}.payresult-foot{margin:28px 0 0;padding-top:20px;border-top:1px solid var(--line);font-size:12.5px;line-height:1.6;color:var(--muted)}
