*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#edf1f8;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.6}#root{max-width:1240px;margin:0 auto;padding:1rem}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25}button,input,select,textarea{font-family:inherit;font-size:inherit}.theme-light{--bg:#edf1f8;--surface:#fff;--surface-soft:#f6f8fc;--surface-raised:#e8edf6;--text:#111827;--text-muted:#64748b;--text-subtle:#94a3b8;--border-color:#dde4ef;--primary:#2563eb;--primary-hover:#1d4ed8;--primary-soft:#eff6ff;--success:#059669;--success-soft:#ecfdf5;--warning:#d97706;--warning-soft:#fffbeb;--danger:#dc2626;--danger-soft:#fef2f2;--focus-ring:#2563eb47}.theme-dark{--bg:#0d1520;--surface:#15212f;--surface-soft:#1b2a3c;--surface-raised:#213247;--text:#e0eaf8;--text-muted:#8fa3be;--text-subtle:#5b7898;--border-color:#243347;--primary:#3b82f6;--primary-hover:#60a5fa;--primary-soft:#1a3461;--success:#10b981;--success-soft:#062718;--warning:#f59e0b;--warning-soft:#271c04;--danger:#f87171;--danger-soft:#290d0d;--focus-ring:#3b82f666}.app{background:var(--bg);color:var(--text);border:1px solid var(--border-color);border-radius:18px;grid-template-columns:234px 1fr;min-height:calc(100vh - 2rem);transition:background .2s,color .2s,border-color .2s;display:grid;overflow:hidden;box-shadow:0 4px 6px #0000000a,0 12px 32px #00000012}.sidebar{background:var(--surface);border-right:1px solid var(--border-color);flex-direction:column;padding:1.5rem .875rem 1.25rem;display:flex}.brand{border-bottom:1px solid var(--border-color);margin-bottom:.75rem;padding:0 .5rem 1.1rem}.brand h1{letter-spacing:-.01em;font-size:1rem}.brand p{color:var(--text-muted);margin-top:.2rem;font-size:.75rem}.sidebar nav ul{gap:.15rem;list-style:none;display:grid}.sidebar nav button{text-align:left;width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:9px;padding:.58rem .75rem;font-size:.875rem;font-weight:500;transition:background .14s,color .14s}.sidebar nav button:hover{background:var(--surface-soft);color:var(--text)}.sidebar nav button.active{background:var(--primary-soft);color:var(--primary);font-weight:700}.content{grid-template-rows:auto 1fr;min-width:0;display:grid}.topbar{border-bottom:1px solid var(--border-color);background:var(--surface);grid-template-columns:auto 1fr 1fr 1.6fr auto auto;align-items:end;gap:.75rem;padding:.75rem 1.25rem;display:grid}.topbar label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;gap:.2rem;font-size:.68rem;font-weight:700;display:grid}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.6rem;display:flex}.save-state{color:var(--text-subtle);font-size:.72rem}.danger-text{color:var(--danger)}.user-chip{border:1px solid var(--border-color);background:var(--surface-soft);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;border-radius:999px;max-width:200px;padding:.28rem .65rem;font-size:.72rem;font-weight:500;overflow:hidden}.menu-btn{display:none}.page{padding:1.25rem;overflow:auto}.topbar input,.topbar select,.filter-grid input,.filter-grid select,.inline-form input,.modal-grid input,.modal-grid select,.modal-grid textarea,.settings-grid select,.budget-item input,.auth-form input{border:1px solid var(--border-color);background:var(--surface-soft);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.5rem .65rem;font-size:.875rem;line-height:1.4;transition:border-color .15s,box-shadow .15s}.topbar input:focus,.topbar select:focus,.filter-grid input:focus,.filter-grid select:focus,.inline-form input:focus,.modal-grid input:focus,.modal-grid select:focus,.modal-grid textarea:focus,.settings-grid select:focus,.budget-item input:focus,.auth-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus-ring)}.primary{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:0;border-radius:8px;padding:.54rem 1rem;font-size:.875rem;font-weight:600;line-height:1.4;transition:background .14s,box-shadow .14s,transform .1s}.primary:hover{background:var(--primary-hover);box-shadow:0 2px 10px #2563eb52}.primary:active{transform:translateY(1px)}.primary:disabled{opacity:.52;cursor:not-allowed;pointer-events:none}.secondary{border:1.5px solid var(--border-color);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;padding:.54rem 1rem;font-size:.875rem;font-weight:600;line-height:1.4;transition:background .14s,border-color .14s}.secondary:hover{background:var(--surface-soft);border-color:var(--primary)}.text-btn{color:var(--primary);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:.28rem .45rem;font-size:.82rem;font-weight:600;line-height:1.4;transition:background .14s,color .14s}.text-btn:hover{background:var(--primary-soft)}.text-btn.danger{color:var(--danger)}.text-btn.danger:hover{background:var(--danger-soft)}.text-btn.danger-sm,button.danger-sm{color:var(--text-subtle);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:.18rem .4rem;font-size:.78rem;font-weight:600;line-height:1.4;transition:color .14s,background .14s}.text-btn.danger-sm:hover,button.danger-sm:hover{color:var(--danger);background:var(--danger-soft)}.pill{letter-spacing:.03em;cursor:pointer;border:0;border-radius:999px;padding:.24rem .65rem;font-size:.71rem;font-weight:700;transition:opacity .14s}.pill:hover{opacity:.78}.pill.paid{background:var(--success-soft);color:var(--success)}.pill.unpaid{background:var(--danger-soft);color:var(--danger)}.status{letter-spacing:.03em;white-space:nowrap;border-radius:999px;padding:.2rem .58rem;font-size:.69rem;font-weight:700}.status.good{background:var(--success-soft);color:var(--success)}.status.warn{background:var(--warning-soft);color:var(--warning)}.status.over{background:var(--danger-soft);color:var(--danger)}.row-actions,.budget-item-actions{white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:.2rem;display:flex}.row-actions input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.row-actions input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.row-actions input[type=number]{-moz-appearance:textfield}.checkbox-row{cursor:pointer;align-items:center;gap:.55rem;font-size:.875rem;display:flex}.checkbox-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.auth-screen{background:var(--bg);place-items:center;min-height:calc(100vh - 2rem);display:grid}.auth-card{border:1px solid var(--border-color);background:var(--surface);border-radius:16px;width:min(440px,100%);padding:2rem 2rem 1.75rem;box-shadow:0 8px 28px #00000017}.auth-card h1{margin-bottom:.35rem;font-size:1.45rem}.auth-card>p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.875rem}.auth-switch{background:var(--surface-soft);border:1px solid var(--border-color);border-radius:10px;gap:.3rem;margin-bottom:1.25rem;padding:.25rem;display:flex}.auth-switch button{color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:7px;flex:1;padding:.48rem .75rem;font-size:.875rem;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.auth-switch button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 4px #0000001a}.auth-form{gap:.85rem;display:grid}.auth-form label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;gap:.3rem;font-size:.72rem;font-weight:700;display:grid}.auth-form .primary{width:100%;margin-top:.25rem;padding:.65rem;font-size:.9rem}.auth-error{color:var(--danger);background:var(--danger-soft);border:1px solid color-mix(in oklab, var(--danger) 30%, var(--border-color));border-radius:8px;margin-top:1rem;padding:.55rem .8rem;font-size:.835rem}.auth-success{color:var(--success);background:color-mix(in oklab, var(--success) 12%, var(--surface));border:1px solid color-mix(in oklab, var(--success) 30%, var(--border-color));border-radius:8px;margin-bottom:.75rem;padding:.55rem .8rem;font-size:.835rem}.card{border:1px solid var(--border-color);background:var(--surface);border-radius:14px;padding:1.25rem;box-shadow:0 1px 3px #0000000a,0 4px 14px #0000000a}.card-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.card-header h2{letter-spacing:-.01em;font-size:.95rem;font-weight:700}.card-header span{color:var(--text-muted);font-size:.8rem}.card>h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:1.25rem 0 .6rem;font-size:.7rem;font-weight:700}.page-grid{gap:1rem;display:grid}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}.kpi p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;font-size:.72rem;font-weight:700}.kpi strong{letter-spacing:-.025em;font-size:1.6rem;font-weight:800;line-height:1.1;display:block}.kpi.highlight{background:var(--primary-soft);border-color:color-mix(in oklab, var(--primary) 25%, var(--border-color))}.kpi.highlight strong{color:var(--primary)}.kpi.success strong{color:var(--success)}.budget-list{gap:.7rem;margin-top:1rem;display:grid}.budget-item{border:1px solid var(--border-color);background:var(--surface-soft);border-radius:12px;padding:1rem 1.1rem}.budget-item-head{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.budget-item-head h3{text-transform:none!important;letter-spacing:0!important;color:var(--text)!important;margin:0!important;font-size:.9rem!important;font-weight:700!important}.budget-item label{margin-top:.65rem}.budget-item label input{max-width:200px}.budget-item>p{color:var(--text-muted);margin:.5rem 0 0;font-size:.82rem}.budget-item>small{color:var(--text-subtle);margin-top:.35rem;font-size:.75rem;display:block}.bar{background:var(--surface-raised);border-radius:999px;height:6px;margin-top:.6rem;overflow:hidden}.bar div{border-radius:inherit;height:100%;transition:width .45s}.bar .good{background:var(--success)}.bar .warn{background:var(--warning)}.bar .over{background:var(--danger)}.bar .goal,.bar .report{background:var(--primary)}.recent-list{gap:0;margin:.85rem 0 0;padding:0;list-style:none;display:grid}.recent-list li{border-bottom:1px solid var(--border-color);grid-template-columns:1fr auto;align-items:center;gap:1rem;padding:.7rem 0;display:grid}.recent-list li:last-child{border-bottom:0}.recent-list li>div{gap:.1rem;display:grid}.recent-list li>div:last-child{text-align:right}.recent-list li strong{font-size:.875rem;font-weight:600}.recent-list li span{color:var(--text-muted);font-size:.76rem}.recent-list strong.income{color:var(--success)}.recent-list strong.expense{color:var(--danger)}td.income{color:var(--success);font-weight:600}td.expense{color:var(--danger);font-weight:600}td.transfer{color:var(--text-muted);font-weight:600}.compact-list{gap:0;margin:.75rem 0 0;padding:0;list-style:none;display:grid}.compact-list li{border-bottom:1px solid var(--border-color);grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;padding:.62rem 0;font-size:.875rem;display:grid}.compact-list li:last-child{border-bottom:0}.compact-list li>span:last-of-type{color:var(--text-muted);font-size:.78rem}.compact-list li>strong{text-align:right;font-weight:700}.insights{gap:.5rem;margin:.85rem 0 0;padding:0;list-style:none;display:grid}.insights li{background:var(--surface-soft);border:1px solid var(--border-color);border-radius:8px;padding:.6rem .9rem;font-size:.875rem}.goals-mini{gap:.8rem;margin-top:.85rem;display:grid}.goals-mini article{gap:.35rem;display:grid}.goals-mini article>div:first-child{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.goals-mini article strong{font-size:.875rem;font-weight:600}.goals-mini article span{color:var(--text-muted);white-space:nowrap;font-size:.77rem}.trend-chart{align-items:flex-end;gap:.4rem;min-height:180px;margin-top:1rem;display:flex}.trend-col{flex-direction:column;flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.trend-col>span{color:var(--text-muted);font-size:.7rem;font-weight:600}.trend-bars{justify-content:center;align-items:flex-end;gap:3px;width:100%;height:160px;display:flex}.trend-bars .income,.trend-bars .expense{border-radius:4px 4px 0 0;flex:1;max-width:28px;min-height:3px;transition:height .4s}.trend-bars .income{background:var(--success)}.trend-bars .expense{background:var(--danger)}.trend-legend{color:var(--text-muted);gap:1.25rem;margin-top:.75rem;font-size:.75rem;display:flex}.trend-legend-item{align-items:center;gap:.35rem;font-weight:600;display:flex}.trend-legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.trend-legend-dot.income{background:var(--success)}.trend-legend-dot.expense{background:var(--danger)}.goal-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1rem;display:grid}.goal-card{border:1px solid var(--border-color);background:var(--surface-soft);border-radius:12px;gap:.5rem;padding:1rem 1.1rem;display:grid}.goal-card h3{text-transform:none!important;letter-spacing:0!important;color:var(--text)!important;margin:0!important;font-size:.9rem!important;font-weight:700!important}.goal-card>p{color:var(--text-muted);margin:0;font-size:.8rem}.goal-card>small{color:var(--text-muted);font-size:.76rem}.goal-card .bar{height:8px;margin-top:0}.goal-card .inline-form{margin-top:.25rem}.breakdown-list{gap:.6rem;margin-top:1rem;display:grid}.breakdown-list article{border:1px solid var(--border-color);background:var(--surface-soft);border-radius:10px;padding:.8rem 1rem}.breakdown-list article>div:first-child{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.breakdown-list article strong{font-size:.875rem;font-weight:600}.breakdown-list article span{color:var(--text-muted);font-size:.82rem}.breakdown-list article small{color:var(--text-subtle);margin-top:.3rem;font-size:.72rem;display:block}.breakdown-list article .bar{margin-top:.4rem}.filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem;margin-top:1rem;display:grid}.filter-grid label,.settings-grid label,.budget-item label,.modal-grid label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;gap:.3rem;font-size:.7rem;font-weight:700;display:grid}.table-wrap{border:1px solid var(--border-color);border-radius:10px;margin-top:1rem;overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:var(--surface-soft)}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-color);white-space:nowrap;padding:.65rem .9rem;font-size:.68rem;font-weight:700}td{border-bottom:1px solid var(--border-color);white-space:nowrap;padding:.72rem .9rem;font-size:.875rem}tbody tr:last-child td{border-bottom:0}tbody tr{transition:background .1s}tbody tr:hover{background:var(--surface-soft)}td p{color:var(--text-muted);white-space:normal;margin:.15rem 0 0;font-size:.75rem}.inline-form{flex-wrap:wrap;align-items:flex-end;gap:.6rem;margin-top:1rem;display:flex}.card-header .inline-form{margin-top:0}.settings-grid{gap:1rem;max-width:500px;padding-top:.5rem;display:grid}.settings-grid article{border:1px solid var(--border-color);background:var(--surface-soft);border-radius:10px;padding:.85rem 1rem}.settings-grid article h3{margin:0 0 .6rem;font-size:.82rem;font-weight:700}.tag-list{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;padding:0;list-style:none;display:flex}.tag-list li{border:1px solid var(--border-color);background:var(--surface-raised);color:var(--text-muted);border-radius:999px;padding:.22rem .65rem;font-size:.76rem}.security-note{color:var(--text-muted);background:var(--surface-soft);border:1px solid var(--border-color);border-radius:8px;margin:1rem 0 0;padding:.65rem .9rem;font-size:.82rem}.security-meta{white-space:normal;max-width:380px;color:var(--text-muted);font-size:.78rem}.setup-list{gap:.45rem;margin:.75rem 0 0;padding:0;list-style:none;display:grid}.setup-list li{border:1px solid var(--border-color);background:var(--surface-soft);border-radius:10px;align-items:flex-start;gap:.75rem;padding:.65rem .85rem;display:flex}.setup-list li>strong{letter-spacing:.06em;flex-shrink:0;min-width:30px;margin-top:.15rem;font-size:.65rem}.setup-list li>div{gap:.1rem;display:grid}.setup-list li.ok strong{color:var(--success)}.setup-list li.fail strong{color:var(--danger)}.setup-list li span{font-size:.875rem;font-weight:600}.setup-list li small{color:var(--text-muted);font-size:.78rem}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000085;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{background:var(--surface);width:min(800px,100%);max-height:calc(100dvh - 2rem);color:var(--text);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;overflow-y:auto;box-shadow:0 24px 64px #00000038}.modal-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;margin-top:1.25rem;display:grid}.modal-grid .wide{grid-column:1/-1}@media (width<=1080px){.topbar{grid-template-rows:auto auto;grid-template-columns:auto 1fr 1fr auto;row-gap:.5rem}.topbar>label:nth-child(4){grid-column:1/-1}.topbar>button.primary{align-self:end}.topbar-actions{grid-column:1/-1;justify-content:flex-start}.kpi-grid,.filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.goal-grid{grid-template-columns:1fr}}@media (width<=860px){.app{border-radius:12px;grid-template-columns:1fr}.menu-btn{border:1px solid var(--border-color);background:var(--surface-soft);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;padding:.5rem .75rem;font-size:.875rem;font-weight:600;transition:background .14s;display:inline-flex}.menu-btn:hover{background:var(--surface-raised)}.sidebar{z-index:50;width:240px;transition:transform .24s;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:4px 0 24px #0000002e}.sidebar.open{transform:translate(0)}.topbar{grid-template-columns:auto 1fr auto}}@media (width<=620px){#root{padding:.5rem}.app{border-radius:10px}.page{padding:.875rem}.topbar{grid-template-columns:auto 1fr;padding:.65rem .875rem}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.kpi strong{font-size:1.3rem}.filter-grid{grid-template-columns:1fr}.inline-form{flex-direction:column}.inline-form input{width:100%}.modal-grid,.goal-grid{grid-template-columns:1fr}.compact-list li{grid-template-columns:1fr auto}.compact-list li>span:last-of-type{display:none}}
