@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#090b10;--bg-sidebar:#0c0e14;--bg-panel:#11141c;--bg-hover:#161a24;--border:#ffffff0f;--border-subtle:#ffffff0a;--text:#e8eaed;--text-secondary:#8b919d;--text-tertiary:#5c6370;--accent:#4ade80;--accent-dim:#4ade801f;--blue:#60a5fa;--purple:#a78bfa;--amber:#fbbf24;--rose:#f87171;--orange:#fb923c;--radius:10px;--radius-sm:6px;--sidebar-w:168px;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:12px;line-height:1.4}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);min-height:100vh;color:var(--text);overflow-x:hidden}.mono{font-family:JetBrains Mono,monospace}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;padding:14px 10px;display:flex;position:sticky;top:0}.brand{letter-spacing:-.02em;color:var(--text);padding:4px 8px 16px;font-size:13px;font-weight:700}.nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 8px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item.active{color:var(--blue);background:#60a5fa1a}.sidebar-footer{border-top:1px solid var(--border);margin-top:8px;padding-top:12px}.year-select{background:var(--bg-panel);border:1px solid var(--border);width:100%;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;padding:6px 8px;font-family:inherit;font-size:11px}.year-select:focus{border-color:#60a5fa66;outline:none}.main{flex:1;min-width:0;padding:14px 16px 24px}.hero-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px;display:flex}.hero-metric .label{color:var(--text-tertiary);margin-bottom:2px;font-size:11px;font-weight:500}.hero-metric .value{letter-spacing:-.03em;font-size:26px;font-weight:700;line-height:1.1}.hero-metric .delta{color:var(--text-secondary);margin-top:3px;font-size:11px}.hero-metric .delta.positive{color:var(--accent)}.hero-metric .delta.warning{color:var(--amber)}.hero-stats{flex-wrap:wrap;gap:20px;display:flex}.hero-stat{text-align:right}.hero-stat .label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:10px}.hero-stat .value{letter-spacing:-.01em;font-size:14px;font-weight:600}.hero-stat .value.accent{color:var(--accent)}.hero-stat .value.blue{color:var(--blue)}.hero-stat .value.amber{color:var(--amber)}.grid-2{grid-template-columns:1.6fr 1fr;gap:10px;margin-bottom:10px;display:grid}.grid-2-equal{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (width<=1100px){.grid-2,.grid-2-equal{grid-template-columns:1fr}}@media (width<=700px){.shell{flex-direction:column}.sidebar{flex-flow:wrap;align-items:center;gap:6px;width:100%;height:auto;padding:10px;position:static}.brand{padding:0 8px}.nav{flex-direction:row;flex:1}.sidebar-footer{border:none;margin:0;padding:0}.year-select{width:auto}}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.panel-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.panel-title{color:var(--text-secondary);letter-spacing:.01em;font-size:11px;font-weight:600}.panel-sub{color:var(--text-tertiary);font-size:10px}.budget-bars{flex-direction:column;gap:8px;display:flex}.budget-bar-item label{color:var(--text-secondary);justify-content:space-between;margin-bottom:3px;font-size:11px;display:flex}.budget-bar-track{background:#ffffff0d;border-radius:99px;height:4px;overflow:hidden}.budget-bar-fill{border-radius:99px;height:100%;transition:width .5s}.budget-bar-fill.needs{background:var(--accent)}.budget-bar-fill.wants{background:var(--purple)}.budget-bar-fill.savings{background:var(--blue)}.budget-bar-fill.spent{background:var(--rose)}.bills-table-wrap{margin:-4px -4px 0;overflow-x:auto}.bills-table{border-collapse:collapse;width:100%;font-size:11px}.bills-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;padding:6px 8px;font-size:10px;font-weight:500}.bills-table td{border-bottom:1px solid var(--border-subtle);white-space:nowrap;padding:5px 8px}.bills-table tr:hover td{background:var(--bg-hover)}.bill-name{color:var(--text);font-size:11px;font-weight:600}.bill-meta{color:var(--text-tertiary);font-size:10px}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:600;display:inline-block}.badge.paid{background:var(--accent-dim);color:var(--accent)}.badge.due{color:var(--amber);background:#fbbf241f}.badge.empty{color:var(--text-tertiary);background:#ffffff0a}.amount-cell{font-family:JetBrains Mono,monospace;font-size:10px}.amount-cell.has-value{color:var(--text)}.amount-cell.zero{color:var(--text-tertiary)}.amount-cell.editable{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:3px;width:100%;padding:2px 4px;font-family:JetBrains Mono,monospace;font-size:10px;transition:background .1s}.amount-cell.editable:hover{color:var(--blue);background:#60a5fa1a}.amount-cell.editable.saving{opacity:.5}.cell-input{background:var(--bg);border:1px solid var(--blue);width:72px;color:var(--text);border-radius:3px;outline:none;padding:2px 4px;font-size:10px}.badge-btn{cursor:pointer;border:none;font-family:inherit}.badge-btn:hover{filter:brightness(1.15)}.table-hint{color:var(--text-tertiary);margin-bottom:8px;font-size:10px}.bills-table .col-current{background:#60a5fa0a}.bills-table th.col-current,.bills-table td.col-current{box-shadow:inset 0 2px 0 var(--blue)}.total-row td{border-top:1px solid var(--border);background:#ffffff05;font-size:10px;font-weight:600}.cat-list{flex-direction:column;gap:6px;display:flex}.cat-row{align-items:center;gap:8px;font-size:11px;display:flex}.cat-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.cat-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.cat-bar-wrap{background:#ffffff0d;border-radius:99px;width:60px;height:3px;overflow:hidden}.cat-bar{border-radius:99px;height:100%}.cat-amt{color:var(--text-tertiary);text-align:right;min-width:52px;font-family:JetBrains Mono,monospace;font-size:10px}.history-list{flex-direction:column;gap:4px;max-height:280px;display:flex;overflow-y:auto}.history-item{border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:6px 8px;font-size:11px;display:flex}.history-item:hover{background:var(--bg-hover)}.history-item .bill{font-weight:500}.history-item .change{color:var(--text-tertiary);margin-top:1px;font-family:JetBrains Mono,monospace;font-size:10px}.history-item .time{color:var(--text-tertiary);font-size:10px}.empty-state{color:var(--text-tertiary);padding:12px 0;font-size:11px}.due-strip{flex-direction:column;gap:4px;display:flex}.due-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:5px 0;font-size:11px;display:flex}.due-item:last-child{border-bottom:none}.due-item .name{font-weight:500}.due-item .date{color:var(--text-tertiary);font-size:10px}.loading{min-height:100vh;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:11px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{color:var(--rose);border-radius:var(--radius-sm);background:#f8717114;border:1px solid #f8717133;margin-bottom:10px;padding:8px 12px;font-size:11px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#ffffff0a!important}.recharts-text{fill:var(--text-tertiary)!important;font-size:10px!important}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:10px!important}
