@import "https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,400&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.ledger-root{color:#1a1a1a;background:#f4f3f0;min-height:100vh;font-family:DM Mono,monospace}.ledger-header{z-index:100;background:#fff;border-bottom:1px solid #e8e6e1;position:sticky;top:0}.ledger-header-inner{justify-content:space-between;align-items:center;max-width:1100px;height:56px;margin:0 auto;padding:0 24px;display:flex}.ledger-wordmark{letter-spacing:-.5px;color:#185fa5;font-family:Fraunces,serif;font-size:22px;font-weight:700}.ledger-header-actions{align-items:center;gap:10px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#185fa5;border:none;border-radius:6px;padding:8px 16px;font-family:DM Mono,monospace;font-size:13px;transition:background .15s}.btn-primary:hover{background:#12508a}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{color:#555;cursor:pointer;background:0 0;border:1px solid #d8d6d1;border-radius:6px;padding:8px 16px;font-family:DM Mono,monospace;font-size:13px;transition:border-color .15s,color .15s}.btn-ghost:hover{color:#185fa5;border-color:#185fa5}.btn-ghost.full-width{justify-content:center;width:100%}.ledger-main{flex-direction:column;gap:32px;max-width:1100px;margin:0 auto;padding:32px 24px 80px;display:flex}.ledger-error{color:#991b1b;background:#fee2e2;border-radius:8px;padding:12px 16px;font-size:13px}.ledger-loading{text-align:center;color:#777;padding:48px;font-size:14px}.dashboard{flex-direction:column;gap:20px;display:flex}.stat-cards{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.stat-card{background:#fff;border:1px solid #e8e6e1;border-radius:12px;padding:24px}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:8px;font-size:11px}.stat-value{color:#1a1a1a;font-family:Fraunces,serif;font-size:30px;font-weight:600;line-height:1}.charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-card{background:#fff;border:1px solid #e8e6e1;border-radius:12px;padding:20px 20px 16px}.chart-title{text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:16px;font-size:11px}.cat-bars{flex-direction:column;gap:10px;display:flex}.cat-bar-row{grid-template-columns:80px 1fr 72px;align-items:center;gap:10px;display:grid}.cat-bar-label{color:#555;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.cat-bar-track{background:#f0eee9;border-radius:3px;height:8px;overflow:hidden}.cat-bar-fill{border-radius:3px;height:100%;transition:width .4s}.cat-bar-amount{color:#333;text-align:right;font-size:12px}.chart-tooltip{color:#fff;background:#1a1a1a;border-radius:6px;padding:8px 12px;font-family:DM Mono,monospace;font-size:12px}.chart-tooltip-label{color:#aaa;margin-bottom:2px}.chart-tooltip-value{font-weight:500}.ledger-section{flex-direction:column;gap:16px;display:flex}.ledger-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.ledger-section-title{margin:0;font-family:Fraunces,serif;font-size:20px;font-weight:600}.ledger-filters{flex-wrap:wrap;gap:6px;display:flex}.filter-pill{color:#555;cursor:pointer;background:#fff;border:1px solid #d8d6d1;border-radius:20px;padding:5px 14px;font-family:DM Mono,monospace;font-size:12px;transition:all .15s}.filter-pill:hover{color:#185fa5;border-color:#185fa5}.filter-pill.active{color:#fff;background:#185fa5;border-color:#185fa5}.table-wrap{background:#fff;border:1px solid #e8e6e1;border-radius:12px;overflow:hidden}.table-empty{text-align:center;color:#888;background:#fff;border:1px solid #e8e6e1;border-radius:12px;padding:48px;font-size:14px}.expense-table{border-collapse:collapse;width:100%}.expense-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:#888;border-bottom:1px solid #e8e6e1;padding:12px 16px;font-size:11px;font-weight:400}.expense-table td{vertical-align:middle;border-bottom:1px solid #f0eee9;padding:13px 16px;font-size:13px}.expense-table tbody tr:last-child td{border-bottom:none}.expense-table tbody tr.hovered td{background:#fafaf8}.expense-table tfoot td{border-top:2px solid #e8e6e1;padding:12px 16px;font-size:13px;font-weight:500}.text-right{text-align:right!important}.cell-date{color:#777;white-space:nowrap}.cell-desc{max-width:240px}.cell-user{color:#555;white-space:nowrap}.cell-amount{white-space:nowrap;font-family:Fraunces,serif;font-size:14px}.table-total-label{color:#888;text-transform:uppercase;letter-spacing:.07em;font-size:12px}.table-total-amount{font-family:Fraunces,serif;font-size:16px}.cat-badge{white-space:nowrap;border:1.5px solid;border-radius:20px;padding:2px 9px;font-size:11px}.receipt-btn{color:#185fa5;cursor:pointer;background:0 0;border:1px solid #d8d6d1;border-radius:4px;padding:3px 10px;font-family:DM Mono,monospace;font-size:11px}.receipt-btn:hover{background:#eff6ff}.receipt-none{color:#ccc}.cell-actions{width:120px}.row-actions{opacity:0;gap:6px;transition:opacity .15s;display:flex}.row-actions.visible{opacity:1}.action-btn{cursor:pointer;background:0 0;border:1px solid #d8d6d1;border-radius:4px;padding:3px 10px;font-family:DM Mono,monospace;font-size:11px}.edit-btn{color:#185fa5}.edit-btn:hover{background:#eff6ff;border-color:#185fa5}.delete-btn{color:#b5404a}.delete-btn:hover{background:#fee2e2;border-color:#b5404a}.receipt-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.receipt-preview{background:#fff;border-radius:12px;max-width:480px;max-height:80vh;padding:16px;position:relative;overflow:auto}.receipt-preview img{border-radius:6px;width:100%;display:block}.receipt-close{cursor:pointer;background:#fff;border:1px solid #e8e6e1;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:flex;position:absolute;top:8px;right:8px}.modal-overlay{z-index:150;background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:14px;width:100%;max-width:460px;overflow:hidden;box-shadow:0 20px 60px #00000026}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-title{margin:0;font-family:Fraunces,serif;font-size:20px;font-weight:600}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;line-height:1}.modal-close:hover{color:#333}.modal-receipt-preview{background:#f4f3f0;border-radius:8px;max-height:160px;margin:16px 24px 0;overflow:hidden}.modal-receipt-preview img{object-fit:cover;width:100%;max-height:160px;display:block}.modal-form{flex-direction:column;gap:14px;padding:20px 24px 24px;display:flex}.form-row{flex-direction:column;gap:5px;display:flex}.form-row label{text-transform:uppercase;letter-spacing:.07em;color:#888;font-size:11px}.form-row input,.form-row select{color:#1a1a1a;background:#fafaf8;border:1px solid #d8d6d1;border-radius:6px;outline:none;padding:9px 12px;font-family:DM Mono,monospace;font-size:14px;transition:border-color .15s}.form-row input:focus,.form-row select:focus{background:#fff;border-color:#185fa5}.modal-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.upload-modal{padding-bottom:24px}.drop-zone{text-align:center;cursor:pointer;border:2px dashed #d8d6d1;border-radius:10px;margin:20px 24px 0;padding:40px 24px;transition:border-color .2s,background .2s}.drop-zone:hover{background:#eff6ff;border-color:#185fa5}.drop-icon{margin-bottom:12px;font-size:32px}.drop-label{color:#333;margin:0 0 4px;font-size:14px}.drop-sub{color:#888;margin:0;font-size:12px}.scan-status{flex-direction:column;align-items:center;gap:12px;display:flex}.scan-spinner{border:3px solid #e8e6e1;border-top-color:#185fa5;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.scan-status p{color:#555;margin:0;font-size:13px}.scan-error{color:#991b1b;margin-top:12px;padding:0 24px;font-size:13px}.upload-divider{color:#bbb;align-items:center;gap:12px;margin:16px 24px;font-size:12px;display:flex}.upload-divider:before,.upload-divider:after{content:"";background:#e8e6e1;flex:1;height:1px}.upload-divider .btn-ghost.full-width{margin:0 24px;display:block}.upload-modal .btn-ghost.full-width{box-sizing:border-box;width:calc(100% - 48px);margin:0 24px;display:block}@media (width<=700px){.stat-cards,.charts-row{grid-template-columns:1fr}.ledger-section-header{flex-direction:column;align-items:flex-start}.expense-table th:nth-child(4),.expense-table td:nth-child(4){display:none}}
