*,:before,:after{box-sizing:border-box}:root{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#21263a;--border:#2e3347;--text:#e2e8f0;--text-muted:#8892aa;--accent:#6c8ef5;--green:#4ade80;--yellow:#facc15;--red:#f87171;--radius:10px;--radius-sm:6px}body{background:var(--bg);color:var(--text);margin:0;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.6}#root{min-height:100vh}h1,h2,h3{color:var(--text);margin:0}p{margin:0}input,select,textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);outline:none;padding:.4rem .6rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}input:focus,select:focus{border-color:var(--accent)}button{cursor:pointer;border-radius:var(--radius-sm);border:none;padding:.4rem .85rem;font-family:inherit;font-size:.85rem;transition:opacity .15s,background .15s}button:hover{opacity:.9}.btn-primary{background:var(--accent);color:#fff;font-weight:600}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-danger{color:var(--red);border:1px solid var(--red);background:0 0}.btn-icon{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:.2rem .4rem;font-size:.9rem}.btn-icon:hover{color:var(--text);background:var(--surface-hover)}.btn-icon--danger{color:var(--text-muted)}.btn-icon--danger:hover{color:var(--red);background:0 0}.btn-sm{padding:.25rem .6rem;font-size:.8rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.text-danger{color:var(--red)}.section-hint{color:var(--text-muted);margin:.25rem 0 .75rem;font-size:.82rem;line-height:1.5}.month-nav{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.month-nav__controls{align-items:center;gap:1rem;display:flex}.month-nav__controls button{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);background:0 0;padding:.25rem .6rem;font-size:1rem;transition:background .15s}.month-nav__controls button:hover{background:var(--surface-hover)}.month-nav__label{text-align:center;min-width:12ch;font-size:1.1rem;font-weight:600}.month-nav__actions{gap:.5rem;display:flex}.income-section h2{margin:0 0 1rem}.income-list{flex-direction:column;gap:.4rem;margin:0 0 1rem;padding:0;list-style:none;display:flex}.income-list__empty{color:var(--text-muted);font-size:.9rem;font-style:italic}.income-row{align-items:center;gap:.5rem;display:flex}.income-row input{flex:1}.income-row__name{flex:1;font-weight:500}.income-row__amount{text-align:right;font-variant-numeric:tabular-nums;min-width:7rem}.income-form{flex-wrap:wrap;gap:.5rem;display:flex}.income-form input{flex:1;min-width:8rem}.income-total{text-align:right;color:var(--text-muted);margin-top:1rem;font-size:.95rem}.income-total strong{color:var(--text);font-size:1rem}.left-to-assign{border-radius:var(--radius);background:var(--surface);border:2px solid var(--green);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;padding:1.5rem;display:flex}.left-to-assign--over{border-color:var(--red)}.left-to-assign--zero{border-color:var(--green);background:color-mix(in srgb, var(--green) 8%, var(--surface))}.lta-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:.8rem;font-weight:600}.lta-amount{font-variant-numeric:tabular-nums;font-size:2.25rem;font-weight:700;line-height:1}.left-to-assign--over .lta-amount{color:var(--red)}.left-to-assign--zero .lta-amount{color:var(--green)}.lta-hint{color:var(--text-muted);font-size:.75rem;line-height:1.4}.lta-warning{color:var(--red);font-size:.8rem;font-weight:600}.lta-success{color:var(--green);font-size:.8rem;font-weight:600}.transaction-list{border-top:1px solid var(--border);flex-direction:column;gap:.25rem;margin:.25rem 0 0;padding:.5rem 0 0;list-style:none;display:flex}.transaction-row{align-items:center;gap:.5rem;font-size:.85rem;display:flex}.tx-date{color:var(--text-muted);flex-shrink:0;min-width:6rem}.tx-desc{flex:1}.tx-amount{font-variant-numeric:tabular-nums;text-align:right;min-width:5rem;font-weight:500}.category-card{flex-direction:column;gap:.75rem;display:flex}.category-card__header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.category-card__header h3{cursor:pointer;margin:0;font-size:1rem}.category-card__header h3:hover{color:var(--accent)}.category-card__name-edit{flex:1;align-items:center;gap:.25rem;display:flex}.category-card__name-edit input{flex:1;font-size:1rem;font-weight:600}.category-card__amounts{flex-wrap:wrap;gap:1rem;display:flex}.category-card__stat{flex-direction:column;flex:1;gap:.15rem;min-width:6rem;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem}.stat-value{font-variant-numeric:tabular-nums;font-size:1rem;font-weight:600}.stat-value.clickable{cursor:pointer;border-bottom:1px dashed var(--border);width:fit-content}.stat-value.clickable:hover{color:var(--accent)}.stat-edit{align-items:center;gap:.25rem;display:flex}.stat-edit input{width:7rem;font-size:.9rem}.progress-bar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.progress-bar__fill{border-radius:3px;height:100%;transition:width .3s}.bar--ok{background:var(--green)}.bar--warning{background:var(--yellow)}.bar--over{background:var(--red)}.quick-add{flex-wrap:wrap;gap:.4rem;display:flex}.quick-add input{flex:1;min-width:6rem;padding:.3rem .5rem;font-size:.85rem}.btn-link{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-size:.85rem}.btn-link:hover{text-decoration:underline}.transaction-form h2{margin:0 0 1rem}.transaction-form form{flex-direction:column;gap:.75rem;display:flex}.form-row{flex-wrap:wrap;gap:.75rem;display:flex}.form-field{flex-direction:column;gap:.3rem;min-width:10rem;display:flex}.form-field--grow{flex:1}.form-field label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.8rem;font-weight:600}.form-field select,.form-field input{width:100%}.app{max-width:1100px;margin:0 auto;padding:0 1rem 3rem}.app-header{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding:1.5rem 0 1rem}.app-title{letter-spacing:-.02em;margin-bottom:.1rem;font-size:1.75rem;font-weight:700}.app-subtitle{color:var(--text-muted);margin-bottom:.75rem;font-size:.9rem}.app-steps{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.5rem;margin:0;padding:.6rem .85rem;font-size:.82rem;list-style:none;display:flex}.step-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;margin-right:.3rem;font-size:.7rem;font-weight:700;display:inline-flex}.step-arrow{color:var(--border);font-size:.9rem}.categories-header{align-items:flex-start}.app-main{flex-direction:column;gap:1.5rem;display:flex}.app-top{grid-template-columns:1fr auto;align-items:start;gap:1.5rem;display:grid}@media (width<=640px){.app-top{grid-template-columns:1fr}}.categories-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.categories-header h2{font-size:1.1rem}.add-category-form{gap:.5rem;display:flex}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}
