:root{--bg-start: #f4f7ff;--bg-end: #eef8f2;--surface: rgba(255, 255, 255, .92);--line: #d7deeb;--text: #132238;--muted: #5f6f86;--accent: #1f8f74;--accent-2: #146d58;--danger: #aa3131;font-family:Segoe UI,Trebuchet MS,sans-serif;color:var(--text);line-height:1.4;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at top left,var(--bg-start),var(--bg-end))}#root{min-height:100vh}.app-shell,.auth-shell{min-height:100vh;padding:24px}.auth-shell{display:grid;place-items:center}.auth-card{width:min(520px,100%);padding:32px;border-radius:16px;background:#ffffffeb;border:1px solid var(--line);box-shadow:0 14px 30px #1c3e661a}.brand-kicker{margin:0;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2);font-weight:700;font-size:.75rem}h1,h2,h3{margin:8px 0 10px}.subtle{color:var(--muted);margin:4px 0}.error{color:var(--danger);font-weight:600}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.ghost-btn,.primary-btn,.toggle-btn{border:1px solid var(--line);border-radius:10px;padding:10px 14px;background:#fff;color:var(--text);font-weight:600;cursor:pointer}.primary-btn{border:none;background:var(--accent);color:#fff}.primary-btn:hover{background:var(--accent-2)}.toggle-row{display:flex;gap:8px}.toggle-btn.active{border-color:var(--accent);color:var(--accent)}.control-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px}.content-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(420px,1.8fr);gap:12px;align-items:start}.budget-panel{margin-bottom:12px}.budget-panel-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.budget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.budget-card{border:1px solid var(--line);border-radius:12px;padding:10px;background:#fff}.budget-card h4{margin:0}.budget-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.compact-btn{padding:6px 10px;font-size:.85rem}.meter-track{height:10px;border-radius:999px;background:#e8edf6;overflow:hidden;margin:8px 0}.meter-fill{height:100%;transition:width .2s ease}.meter-fill.safe{background:#1f8f74}.meter-fill.warn{background:#d08d1f}.meter-fill.danger{background:#c73939}.budget-meta{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:.83rem}.panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:0 8px 24px #112c4714}.view-stack{display:grid;gap:12px}.add-panel{position:sticky;top:12px}.expense-panel,.summary-panel{display:flex;flex-direction:column}.total-panel{display:flex;flex-direction:column;justify-content:center}.total-value{margin:4px 0;font-size:1.8rem;font-weight:700}label{display:block;margin-bottom:8px;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:10px;font:inherit;background:#fff}.expense-form{display:flex;flex-direction:column}.expense-list,.summary-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.expense-list{max-height:45vh;overflow:auto;padding-right:4px}.summary-list{max-height:28vh;overflow:auto;padding-right:4px}.expense-list li,.summary-list li{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff}.clickable-expense{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.clickable-expense:hover,.clickable-expense:focus-visible{transform:translateY(-1px);box-shadow:0 8px 16px #112c471a;outline:none}.summary-list li{display:flex;justify-content:space-between;align-items:center}.expense-head{margin:0}.expense-note{margin:6px 0 0;color:#2f4a6a}.modal-backdrop{position:fixed;inset:0;background:#0e1d2e73;display:grid;place-items:center;padding:16px;z-index:1000}.modal-card{width:min(520px,100%);background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:0 18px 32px #0d213540}.modal-actions{display:flex;justify-content:flex-end;gap:8px}@media(max-width:980px){.control-grid,.content-grid{grid-template-columns:1fr}.add-panel{position:static}.expense-list,.summary-list{max-height:36vh}}
