*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg2: #161820;--bg3: #1e2028;--bg4: #252730;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.12);--text: #e8e9ed;--text2: #9499a8;--text3: #5a5f70;--amber: #f5a623;--amber-dim: rgba(245,166,35,.12);--amber-dim2: rgba(245,166,35,.06);--green: oklch(.72 .15 150);--green-dim: oklch(.72 .15 150 / .12);--red: oklch(.65 .18 20);--red-dim: oklch(.65 .18 20 / .12);--blue: oklch(.72 .12 240);--sidebar-w: 200px;--radius: 10px;--font-mono: "DM Mono", monospace;--font-sans: "DM Sans", sans-serif}body.light{--bg: #f4f3ef;--bg2: #eceae4;--bg3: #e3e1da;--bg4: #d8d5cd;--border: rgba(0,0,0,.08);--border2: rgba(0,0,0,.13);--text: #1c1b18;--text2: #5c5a52;--text3: #9a9890;--green: oklch(.48 .14 150);--green-dim: oklch(.48 .14 150 / .12);--red: oklch(.48 .16 20);--red-dim: oklch(.48 .16 20 / .1)}body.light .input,body.light .select{color-scheme:light}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5;overflow:hidden}.fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--amber);color:#111;border:none;font-size:24px;line-height:1;cursor:pointer;z-index:500;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000059;transition:transform .15s,box-shadow .15s}.fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #00000073}.app{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar.collapsed{width:52px}.sidebar-brand{padding:0 20px 8px;display:flex;flex-direction:column;gap:10px;overflow:hidden}.sidebar-brand-text{font-size:20px;font-weight:700;letter-spacing:-1px;color:var(--amber);white-space:nowrap;transition:opacity .18s,max-height .18s;line-height:1}.sidebar-brand-text em{font-style:normal;color:var(--text3);font-weight:300;letter-spacing:0;font-size:17px}.sidebar-brand-sub{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--text3);white-space:nowrap;transition:opacity .18s;margin-top:-6px;padding-left:2px}.sidebar.collapsed .sidebar-brand-text{opacity:0;pointer-events:none;max-height:0}.sidebar.collapsed .sidebar-brand-sub{opacity:0}.sidebar.collapsed .sidebar-brand{padding-left:0;padding-right:0;align-items:center}.collapse-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px 6px;border-radius:5px;font-size:13px;line-height:1;align-self:flex-start;flex-shrink:0;transition:color .15s,background .15s;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.collapse-btn:hover{color:var(--text);background:var(--bg4)}.sidebar.collapsed .collapse-btn{align-self:center;margin-bottom:16px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 17px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;border-left:2px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden}.nav-item:hover{color:var(--text);background:#ffffff08}.nav-item.active{color:var(--amber);border-left-color:var(--amber);background:var(--amber-dim2)}.nav-icon{font-size:16px;width:18px;text-align:center;flex-shrink:0}.nav-label{transition:opacity .15s}.sidebar.collapsed .nav-label{opacity:0}.sidebar-bottom{margin-top:auto;padding:0 12px}.main{flex:1;overflow:hidden;display:flex;flex-direction:column}.page{flex:1;overflow-y:auto;padding:32px}.page::-webkit-scrollbar{width:6px}.page::-webkit-scrollbar-track{background:transparent}.page::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}.page-header{margin-bottom:28px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.5px}.page-subtitle{color:var(--text2);font-size:13px;margin-top:4px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;min-width:0}.card-title{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-value{font-family:var(--font-mono);font-size:28px;font-weight:500;letter-spacing:-1px;color:var(--amber)}.stat-label{font-size:11px;color:var(--text3);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}.input-row{display:flex;gap:10px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:120px}.field label{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text3)}.input,.select{background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:8px 12px;color:var(--text);font-family:var(--font-sans);font-size:14px;outline:none;transition:border .15s;width:100%}.input:focus,.select:focus{border-color:var(--amber)}.input::placeholder{color:var(--text3)}.select option{background:var(--bg3)}.input[type=number]{font-family:var(--font-mono)}.input[type=date]{font-family:var(--font-mono);color-scheme:dark}.btn{padding:8px 16px;border-radius:7px;font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--amber);color:#111}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--text2)}.btn-ghost:hover{color:var(--text);border-color:var(--border2);background:var(--bg4)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid transparent}.btn-danger:hover{background:#e8576033}.btn-sm{padding:5px 10px;font-size:12px}.tag{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;cursor:default;-webkit-user-select:none;user-select:none}.tag-remove{cursor:pointer;opacity:.6;font-size:10px}.tag-remove:hover{opacity:1}.tag-picker{position:relative;flex:1}.tag-picker-input{background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:6px 12px;color:var(--text);font-family:var(--font-sans);font-size:13px;cursor:pointer;display:flex;flex-wrap:wrap;gap:5px;align-items:center;min-height:38px}.tag-picker-input:focus-within{border-color:var(--amber)}.tag-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;z-index:100;overflow:hidden;box-shadow:0 8px 24px #0006}.tag-option{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;transition:background .1s}.tag-option:hover{background:var(--bg4)}.tag-option.selected{opacity:.5}.del-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px 6px;border-radius:4px;font-size:14px}.del-btn:hover{color:var(--red);background:var(--red-dim)}.expense-list{display:flex;flex-direction:column}.month-divider{padding:10px 16px 6px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border)}.day-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px 4px;font-size:12px;font-weight:500;color:var(--text2);background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1}.day-header-total{font-family:var(--font-mono);font-size:12px;color:var(--text3)}.swipe-wrap{position:relative;overflow:hidden}.swipe-delete-btn{position:absolute;right:0;top:0;bottom:0;width:72px;background:var(--red);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:18px}.swipe-content{will-change:transform;background:var(--bg2)}.expense-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .12s}.expense-row:last-child{border-bottom:none}.expense-row:hover{background:#ffffff08}.expense-row-left{flex:1;min-width:0}.expense-row-place{font-weight:500;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-row-meta{display:flex;gap:6px;align-items:center;margin-top:3px;flex-wrap:wrap}.expense-row-card{font-size:11px;color:var(--text3)}.expense-row-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.expense-row-amount{font-family:var(--font-mono);font-size:14px;color:var(--amber);font-weight:500}.empty{text-align:center;padding:48px;color:var(--text3)}.empty-icon{font-size:32px;margin-bottom:12px}.empty-text{font-size:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:28px;width:480px;max-width:95vw;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}.modal-title{font-size:16px;font-weight:600;margin-bottom:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.add-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.form-title{font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:14px}.chart-wrap{position:relative;height:200px}.chart-wrap-tall{position:relative;height:240px}.section-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:12px;margin-top:24px;display:flex;align-items:center;gap:8px}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.budget-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;min-width:0}.budget-row-freq{font-size:11px;color:var(--text3);padding:2px 7px;background:var(--bg4);border-radius:4px;white-space:nowrap}.net-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:24px}.net-bar{height:8px;background:var(--bg4);border-radius:4px;margin:16px 0;overflow:hidden}.net-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.color-grid{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.color-swatch{width:28px;height:28px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:transform .1s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:#fff}.row-actions{display:flex;gap:6px;align-items:center}.inline-form{display:flex;gap:8px;align-items:flex-start;padding:12px 14px;background:var(--bg3);border:1px dashed var(--border2);border-radius:8px;margin-bottom:8px;flex-wrap:wrap}.filter-bar{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.filter-bar-top{display:flex;gap:8px;align-items:center;width:100%}.filter-tags-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.filter-tag{padding:4px 10px;border-radius:5px;font-size:12px;cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:var(--bg3);transition:all .12s;white-space:nowrap}.filter-tag.active{border-color:var(--amber);color:var(--amber);background:var(--amber-dim)}.search-input{background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:6px 12px;color:var(--text);font-family:var(--font-sans);font-size:13px;outline:none;flex:1 1 auto;min-width:0;width:100%}.search-input:focus{border-color:var(--amber)}.search-input::placeholder{color:var(--text3)}.spinner{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text3);font-size:13px}@media (max-width: 640px){.filter-tags-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.filter-tags-row::-webkit-scrollbar{display:none}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:300;transition:width .22s cubic-bezier(.4,0,.2,1),box-shadow .22s}.sidebar:not(.collapsed){box-shadow:6px 0 32px #00000080}.main{margin-left:52px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .18s ease}.page{padding:16px 14px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.input-row{flex-direction:column}.inline-form{flex-direction:column;align-items:stretch}.field{max-width:none!important;min-width:0!important}.budget-row{gap:8px}.budget-row-freq{display:none}.chart-wrap{height:160px}.chart-wrap-tall{height:180px}.modal{width:calc(100vw - 24px)!important;padding:20px 16px}.fab{right:14px;bottom:20px}.net-summary-grid{display:grid!important;grid-template-columns:1fr 1fr;gap:12px!important;justify-content:unset!important}.donut-row{flex-direction:column!important}.donut-chart-wrap{width:100%!important;height:180px}.page-title{font-size:18px}}
