@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg:#0a0a0a;--surface:#111;--surface-2:#171717;--border:#1e1e1e;--border-mid:#2a2a2a;--text:#f0f0f0;--text-2:#a0a0a0;--text-3:#555;--green:#22c55e;--green-dim:#22c55e1f;--red:#ef4444;--red-dim:#ef44441f;--white:#fff;--sidebar-w:220px;--radius:8px;--font:"Inter", system-ui, sans-serif;--mono:"JetBrains Mono", monospace;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}.shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;padding:24px 0;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);margin-bottom:16px;padding:0 20px 24px}.sidebar-logo h1{color:var(--white);letter-spacing:-.2px;font-size:15px;font-weight:700;line-height:1.3}.sidebar-logo p{color:var(--text-3);font-size:11px;font-family:var(--mono);margin-top:3px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:0 10px;display:flex}.sidebar-nav-item{border-radius:var(--radius);color:var(--text-2);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;text-align:left;width:100%;transition:color var(--transition), background var(--transition);background:0 0;border:none;align-items:center;gap:10px;padding:9px 12px;display:flex}.sidebar-nav-item:hover{background:var(--surface-2);color:var(--text)}.sidebar-nav-item.active{background:var(--surface-2);color:var(--white);border:1px solid var(--border-mid)}.sidebar-nav-item .nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:16px 20px 0}.theme-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-2);cursor:pointer;width:100%;font-size:12px;font-family:var(--font);transition:all var(--transition);background:0 0;padding:7px 12px}.theme-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-mid)}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.main-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 32px 0;display:flex}.main-header h2{color:var(--white);letter-spacing:-.3px;font-size:20px;font-weight:700}.main-header-sub{color:var(--text-3);font-size:12px;font-family:var(--mono);margin-top:2px}.main-content{flex:1;padding:0 32px 32px}.fab{background:var(--white);color:#000;border-radius:var(--radius);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:8px;padding:8px 16px;display:flex}.fab:hover{background:#e5e5e5;transform:translateY(-1px)}.fab-icon{font-size:18px;line-height:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.metric-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;padding:20px;display:flex}.metric-box-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.metric-box-value{font-family:var(--mono);letter-spacing:-.5px;color:var(--text);font-size:26px;font-weight:600}.metric-box-value.green{color:var(--green)}.metric-box-value.red{color:var(--red)}.metric-box-value.white{color:var(--white)}.progress-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:16px 20px}.progress-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.progress-label{color:var(--text-2);font-size:12px;font-weight:500}.progress-pct{font-family:var(--mono);color:var(--green);font-size:13px;font-weight:600}.progress-track{background:var(--border-mid);border-radius:2px;height:3px;overflow:hidden}.progress-fill{background:var(--green);border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 6px #22c55e66}.progress-footer{font-family:var(--mono);color:var(--text-3);justify-content:space-between;margin-top:8px;font-size:11px;display:flex}.entry-list{flex-direction:column;gap:1px;display:flex}.entry-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);align-items:center;gap:12px;padding:12px 16px;display:flex}.entry-row:hover{border-color:var(--border-mid)}.entry-row+.entry-row{margin-top:4px}.entry-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.entry-dot.saving{background:var(--green)}.entry-dot.expense{background:var(--red)}.entry-info{flex:1;min-width:0}.entry-desc{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.entry-date{color:var(--text-3);font-size:11px;font-family:var(--mono);margin-top:2px}.entry-amount{font-family:var(--mono);white-space:nowrap;font-size:14px;font-weight:600}.entry-amount.saving{color:var(--green)}.entry-amount.expense{color:var(--red)}.entry-del{color:var(--text-3);cursor:pointer;transition:color var(--transition), background var(--transition);box-shadow:none;background:0 0;border:none;border-radius:4px;padding:4px;font-size:16px;line-height:1}.entry-del:hover{color:var(--red);background:var(--red-dim)}.empty-state{text-align:center;color:var(--text-3);border:1px dashed var(--border);border-radius:var(--radius);padding:48px 0;font-size:13px}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border-mid);border-radius:var(--radius);width:460px;max-width:95vw;max-height:90vh;animation:.25s cubic-bezier(.4,0,.2,1) slideUp;overflow-y:auto;box-shadow:0 20px 60px #0009}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.modal-head h3{color:var(--white);letter-spacing:-.2px;font-size:15px;font-weight:600}.modal-close-btn{color:var(--text-3);cursor:pointer;transition:color var(--transition), background var(--transition);box-shadow:none;background:0 0;border:none;border-radius:4px;padding:4px;font-size:20px;line-height:1}.modal-close-btn:hover{color:var(--text);background:var(--surface-2)}.modal-body{padding:20px}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:11px;font-weight:600}.field input,.field textarea,.field select{background:var(--surface-2);border:1px solid var(--border-mid);border-radius:var(--radius);color:var(--text);font-family:var(--font);width:100%;transition:border-color var(--transition);padding:9px 12px;font-size:13px}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--text-3);outline:none}.field input::placeholder,.field textarea::placeholder{color:var(--text-3)}.type-toggle{gap:6px;display:flex}.type-btn{border:1px solid var(--border-mid);border-radius:var(--radius);color:var(--text-2);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--transition);box-shadow:none;background:0 0;flex:1;padding:9px}.type-btn.saving.active{background:var(--green-dim);color:var(--green);border-color:var(--green)}.type-btn.expense.active{background:var(--red-dim);color:var(--red);border-color:var(--red)}.type-btn:hover:not(.active){background:var(--surface-2);color:var(--text)}.btn-primary{background:var(--white);color:#000;border-radius:var(--radius);width:100%;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition);box-shadow:none;border:none;margin-top:4px;padding:10px}.btn-primary:hover{background:#e5e5e5}.btn-ghost{border:1px solid var(--border-mid);border-radius:var(--radius);color:var(--text-2);font-size:12px;font-family:var(--font);cursor:pointer;transition:all var(--transition);box-shadow:none;background:0 0;padding:7px 14px}.btn-ghost:hover{border-color:var(--text-3);color:var(--text)}.budget-metrics{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.category-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.cat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);flex-direction:column;gap:8px;min-height:120px;padding:20px;display:flex}.cat-card:hover{border-color:var(--border-mid);background:var(--surface-2)}.cat-card.selected{border-color:var(--green)}.cat-card.add-new{cursor:pointer;color:var(--text-3);border-style:dashed;justify-content:center;align-items:center;gap:6px;font-size:13px}.cat-card.add-new:hover{color:var(--text-2);border-color:var(--border-mid)}.cat-card.add-new .plus{font-size:28px;line-height:1}.cat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);font-size:11px;font-weight:600}.cat-name{color:var(--white);font-size:15px;font-weight:600}.cat-price{font-family:var(--mono);color:var(--green);margin-top:auto;font-size:20px;font-weight:600}.cat-empty{color:var(--text-3);margin-top:auto;font-size:12px}.model-list{flex-direction:column;gap:6px;display:flex}.model-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;padding:12px 14px;display:flex}.model-row:hover{border-color:var(--border-mid)}.model-row.selected{border-color:var(--green);background:var(--green-dim)}.model-info{flex:1}.model-name{color:var(--text);font-size:13px;font-weight:500}.model-chars{color:var(--text-3);margin-top:2px;font-size:11px}.model-price{font-family:var(--mono);color:var(--green);white-space:nowrap;font-size:14px;font-weight:600}.model-del{color:var(--text-3);cursor:pointer;transition:color var(--transition), background var(--transition);box-shadow:none;background:0 0;border:none;border-radius:4px;padding:4px;font-size:14px}.model-del:hover{color:var(--red);background:var(--red-dim)}.model-form-divider{background:var(--border);height:1px;margin:16px 0}.row-2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.loader{height:100%;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.loader-spinner{border:2px solid var(--border-mid);border-top-color:var(--text-2);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-bar{background:var(--red-dim);border:1px solid var(--red);color:var(--red);border-radius:var(--radius);margin-bottom:16px;padding:10px 14px;font-size:12px}.section-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}@media (width<=768px){.shell{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;width:100%;padding:0}.sidebar-logo,.sidebar-footer{display:none}.sidebar-nav{flex-direction:row;gap:4px;padding:8px}.sidebar-nav-item{padding:8px 12px}.main-content{padding:0 16px 24px}.main-header{padding:16px 16px 0}.budget-metrics{grid-template-columns:1fr}}
