:root{--bg:#0b1220;--panel:#121a28;--panel-2:#0f1720;--muted:#94a3b8;--accent:#facc15;--deposit:#10b981;--deficit:#ef4444;--text:#e6eef8;color-scheme:dark}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text)}*{box-sizing:border-box}button,input,select{font:inherit}button,.button-link{background:var(--accent);color:#111827;border:none;border-radius:10px;padding:.7rem 1rem;cursor:pointer;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}button.secondary{background:#253247;color:var(--text)}button.danger{background:#7f1d1d;color:#fecaca}button:disabled{opacity:.55;cursor:not-allowed}input,select{background:var(--panel-2);border:1px solid #243041;color:var(--text);padding:.7rem .8rem;border-radius:10px;width:100%}input[type=file]{display:none}.topnav{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:#ffffff05;overflow:auto;position:sticky;top:0}.topnav-links{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.topnav a{color:var(--muted);text-decoration:none;white-space:nowrap}.topnav a:hover{color:var(--accent)}.topnav-logout{white-space:nowrap;flex-shrink:0}.app{min-height:100vh}.main{padding:1rem;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.card{background:var(--panel);border:1px solid #202c3c;border-radius:16px;padding:1rem}.grid{display:grid;gap:1rem}.grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-top-grid{align-items:start}.stack{display:flex;flex-direction:column;gap:1rem}.row{display:flex;align-items:center}.row.between{justify-content:space-between;gap:1rem}.row.gap{gap:.75rem;flex-wrap:wrap}.wrap{flex-wrap:wrap}.form-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:center}.settings-grid{align-items:end}.field-label{display:flex;flex-direction:column;gap:.35rem;color:var(--muted)}.field-label span{font-size:.9rem}.field-label input,.field-label select{color:var(--text)}.editable-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));align-items:center}.bill-grid,.bill-actions-grid,.account-actions-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.transaction-row{display:grid;grid-template-columns:minmax(220px,1fr) auto auto auto;gap:.75rem;align-items:center}.checkbox{display:flex;gap:.5rem;align-items:center}.checkbox input{width:auto}.muted{color:var(--muted)}.compact-list{margin:.5rem 0 1rem 1.2rem;padding:0}.compact-list li{margin:.25rem 0}.positive{color:var(--deposit)}.negative{color:var(--deficit)}.warning-text{color:#facc15}.list-item{padding:.75rem 0;border-top:1px solid #202c3c}.list-item:first-child{border-top:none;padding-top:0}.badge{padding:.25rem .5rem;border-radius:999px;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.badge.required{background:#ef444426;color:#fca5a5}.badge.optional{background:#facc151f;color:#fde68a}.badge.auto{background:#60a5fa24;color:#93c5fd}.section-block{display:flex;flex-direction:column;gap:1rem}.section-heading{margin:0 0 .25rem}.synopsis-box{margin:0 0 1rem;padding:1rem;border-radius:12px;background:var(--panel-2)}.chart-tooltip{background:#0f1720;border:1px solid #243041;border-radius:12px;padding:.85rem;max-width:360px;display:flex;flex-direction:column;gap:.35rem;box-shadow:0 12px 32px #00000059}.chart-tooltip-synopsis{margin-top:.25rem;font-size:.95rem;line-height:1.45}.dashboard-subcard{margin-top:1rem;padding-top:1rem;border-top:1px solid #202c3c;display:flex;flex-direction:column;gap:.5rem}.discover-stats-grid{margin-top:.25rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.gauge-card{background:var(--panel-2);border:1px solid #243041;border-radius:14px;padding:.9rem;display:flex;flex-direction:column;gap:.75rem}.stat-gauge{display:block;width:100%;height:auto}.stat-gauge-track{stroke:#243041;stroke-width:12;stroke-linecap:round}.stat-gauge-fill{stroke-width:12;stroke-linecap:round}.stat-gauge-marker-line{stroke-width:3;stroke-linecap:round}.stat-gauge-scale{fill:var(--muted);font-size:10px}.gauge-legend{display:grid;gap:.45rem}.gauge-legend-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.legend-inline{display:inline-flex;align-items:center;gap:.5rem}.legend-swatch{width:.7rem;height:.7rem;border-radius:999px;display:inline-block;flex-shrink:0}.legend-swatch.diamond{border-radius:2px;transform:rotate(45deg)}.gauge-summary{display:flex;flex-direction:column;gap:.35rem}.gauge-delta{font-size:1.4rem;font-weight:800;line-height:1.15}.gauge-caption{line-height:1.45}.today-spend-box{margin-top:1rem;padding-top:1rem;border-top:1px solid #202c3c;display:flex;flex-direction:column;gap:.35rem}.today-spend-amount{font-size:2.4rem;font-weight:800;line-height:1.1}.chart-card{min-height:420px}.chart-card-wide{min-height:520px}.chart-wrap{height:340px;width:100%}.chart-card-wide .chart-wrap{height:420px}.chart-loading{height:340px;display:flex;align-items:center;justify-content:center}.discover-mini-chart-wrap{width:100%;height:220px}.upload-box{display:inline-flex;align-items:center;justify-content:center;min-width:180px;padding:.9rem 1rem;border-radius:12px;border:1px dashed #42516a;background:var(--panel-2);color:var(--text);cursor:pointer}.upload-box:hover{border-color:var(--accent);color:var(--accent)}.preview-box{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.preview-row{display:flex;flex-direction:column;gap:.2rem;padding:.75rem;border-radius:12px;background:var(--panel-2)}.preview-dup{outline:1px solid rgba(239,68,68,.35)}.center-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{width:min(100%,360px);display:flex;flex-direction:column;gap:1rem}code{background:var(--panel-2);padding:.1rem .35rem;border-radius:6px}ul{padding-left:1.2rem}@media (max-width: 720px){.transaction-row{grid-template-columns:1fr}.row.between,.gauge-legend-row{align-items:flex-start;flex-direction:column}}
