@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600&family=Inter:wght@400;500;600&display=swap";:root{--paper:#f6f4ee;--card:#fff;--ink:#1c1a17;--ink-soft:#6b655c;--line:#e4dfd4;--accent:#1f6b4f;--accent-soft:#e6f0ea;--accent-ink:#134232;--danger:#b4452f;--warn:#b8862f;--radius:10px;--sidebar-w:232px;font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--ink);color:#d8d3c8;flex-direction:column;flex-shrink:0;height:100vh;padding:22px 14px;display:flex;position:sticky;top:0}.brand{color:#fff;letter-spacing:-.01em;align-items:baseline;gap:8px;padding:4px 10px 22px;font-family:Fraunces,serif;font-size:22px;font-weight:600;display:flex}.brand .dot{color:var(--accent)}.brand small{letter-spacing:.08em;text-transform:uppercase;color:#8c857a;font-family:Inter,sans-serif;font-size:10px;font-weight:500}.nav{flex-direction:column;gap:2px;display:flex}.nav a{color:#cfc9bd;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav a:hover{color:#fff;background:#2a2722}.nav a.active{background:var(--accent);color:#fff}.nav a .ic{text-align:center;opacity:.85;width:16px}.sidebar .foot{color:#7e776c;border-top:1px solid #2c2924;margin-top:auto;padding:12px 10px 0;font-size:11px}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--line);background:var(--card);z-index:5;justify-content:space-between;align-items:center;height:60px;padding:0 28px;display:flex;position:sticky;top:0}.topbar h1{letter-spacing:-.01em;margin:0;font-family:Fraunces,serif;font-size:19px;font-weight:600}.topbar .count-pill{color:var(--accent-ink);background:var(--accent-soft);border:1px solid #cfe2d7;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.content{width:100%;max-width:1100px;padding:28px}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.search{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);flex:1;align-items:center;gap:8px;min-width:220px;padding:9px 14px;display:flex}.search input{width:100%;color:var(--ink);background:0 0;border:none;outline:none;font-size:14px}.search .ic{color:var(--ink-soft)}.btn{border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:var(--radius);cursor:pointer;padding:9px 16px;font-family:inherit;font-size:13.5px;font-weight:600;transition:background .12s,border-color .12s}.btn:hover{border-color:#cfc9bd}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:#1a5b43}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);border-bottom:1px solid var(--line);background:#faf8f3;padding:12px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid #f0ece3;padding:12px 16px;font-size:13.5px}tr:last-child td{border-bottom:none}tbody tr:hover{background:#faf9f5}.name-cell{font-weight:500}.tag{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.tag.gst{background:var(--accent-soft);color:var(--accent-ink)}.tag.nogst{color:var(--ink-soft);background:#f0ece3}.num{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-soft)}.empty,.loading{text-align:center;color:var(--ink-soft);padding:60px 20px}.empty .big{color:var(--ink);margin-bottom:6px;font-family:Fraunces,serif;font-size:18px}.errbar{color:var(--danger);border-radius:var(--radius);background:#fae9e4;border:1px solid #e8c4b9;margin-bottom:16px;padding:10px 14px;font-size:13px}.overlay{z-index:50;background:#1c1a1773;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:14px;width:460px;max-width:92vw;padding:24px;box-shadow:0 20px 60px #00000040}.modal h2{margin:0 0 6px;font-family:Fraunces,serif;font-size:19px}.modal p.sub{color:var(--ink-soft);margin:0 0 18px;font-size:13px}.dropzone{border:1.5px dashed var(--line);border-radius:var(--radius);text-align:center;color:var(--ink-soft);cursor:pointer;padding:22px;transition:border-color .12s,background .12s}.dropzone:hover{border-color:var(--accent);background:var(--accent-soft)}.dropzone.has-file{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.modal .row{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.result-box{border:1px solid var(--line);border-radius:var(--radius);background:#faf8f3;margin-top:14px;padding:14px;font-size:13px}.result-box .line{justify-content:space-between;padding:3px 0;display:flex}.result-box .line b{font-variant-numeric:tabular-nums}@media (prefers-reduced-motion:reduce){*{transition:none!important}}.pager{justify-content:space-between;align-items:center;gap:12px;margin-top:16px;display:flex}.pager-info{color:var(--ink-soft);font-size:12.5px}.okbar{background:var(--accent-soft);color:var(--accent-ink);border-radius:var(--radius);border:1px solid #cfe2d7;margin-bottom:16px;padding:10px 14px;font-size:13px}.purchase-head{flex-wrap:wrap;gap:16px;margin-bottom:18px;display:flex}.field{flex-direction:column;gap:6px;min-width:240px;display:flex}.field label{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.field input,.field select{border:1px solid var(--line);border-radius:var(--radius);background:var(--card);color:var(--ink);padding:9px 12px;font-family:inherit;font-size:14px}.add-row{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.dropdown{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);z-index:20;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.dd-item{cursor:pointer;padding:9px 14px;font-size:13.5px}.dd-item:hover{background:var(--accent-soft)}.cell-in{border:1px solid var(--line);text-align:right;font-variant-numeric:tabular-nums;border-radius:6px;width:80px;padding:5px 8px;font-family:inherit;font-size:13px}.link-del{color:var(--danger);cursor:pointer;background:0 0;border:none;font-size:14px}.totals{flex-direction:column;align-items:flex-end;gap:8px;margin-top:18px;display:flex}.t-line{justify-content:space-between;gap:24px;min-width:280px;font-size:14px;display:flex}.t-line b{font-variant-numeric:tabular-nums}.t-line.grand{border-top:1px solid var(--line);padding-top:8px;font-family:Fraunces,serif;font-size:17px}.section-h{margin:32px 0 14px;font-family:Fraunces,serif;font-size:17px;font-weight:600}.form-grid{flex-direction:column;gap:12px;display:flex}.form-grid label{color:var(--ink-soft);flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.form-grid input{border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);padding:8px 11px;font-family:inherit;font-size:14px;font-weight:400}.pos-wrap{align-items:flex-start;gap:24px;max-width:1200px;display:flex}.pos-left{flex:1;min-width:0}.pos-right{flex:0 0 320px;position:sticky;top:88px}.pos-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:16px;padding:18px;display:flex}.dd-item{justify-content:space-between;align-items:center;gap:10px;display:flex}.dd-meta{color:var(--ink-soft);white-space:nowrap;font-size:11.5px}.warn-pill{color:#9a5b12;background:#fbeed2;border:1px solid #f0d8a8;border-radius:6px;margin-left:8px;padding:1px 7px;font-size:10.5px;font-weight:600;display:inline-block}.tot-block{border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-direction:column;gap:8px;padding:14px 0;display:flex}.tot-block .t-line{min-width:0}.pay-methods{grid-template-columns:1fr 1fr;gap:8px;display:grid}.pay-btn{border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;border-radius:8px;padding:9px;font-family:inherit;font-size:13px;font-weight:600}.pay-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.bal-note{color:var(--warn);font-size:13px;font-weight:600}.big-btn{padding:14px;font-size:15px}.link-print{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px}.link-print:hover{color:var(--accent-ink)}.rpt-wrap{align-items:flex-start;gap:22px;max-width:1200px;display:flex}.rpt-menu{flex-direction:column;flex:0 0 210px;gap:14px;display:flex;position:sticky;top:88px}.rpt-group-h{text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);padding:0 8px 4px;font-size:11px;font-weight:700}.rpt-item{text-align:left;width:100%;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:7px 10px;font-family:inherit;font-size:13px;display:block}.rpt-item:hover{background:#ece8df}.rpt-item.active{background:var(--accent);color:#fff;font-weight:600}.rpt-main{flex:1;min-width:0}.rpt-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.rpt-title{font-family:Fraunces,serif;font-size:18px;font-weight:600}.rpt-controls{align-items:center;gap:8px;display:flex}.rpt-controls input[type=date]{border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-family:inherit;font-size:13px}.rpt-summary{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.sum-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);min-width:140px;padding:12px 16px}.sum-label{text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-size:11px;font-weight:600}.sum-val{margin-top:2px;font-family:Fraunces,serif;font-size:22px;font-weight:600}.chart-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;padding:16px 12px}
