:root{color-scheme:light;font-family:Sora,Avenir Next,Segoe UI,sans-serif;--bg: #f4f7f4;--panel: #ffffff;--ink: #102119;--muted: #5f6f66;--brand: #0e7a5f;--brand-soft: #dff4ee;--accent: #f2a33a;--danger: #bc3b2a;--stroke: #d9e3dd;--track: #ecf1ee}*{box-sizing:border-box}html,body{margin:0;width:100%;max-width:100%;overflow-x:hidden;background:radial-gradient(circle at top left,#f8f2e9 0%,var(--bg) 38%,#e8efe9 100%);color:var(--ink)}#root{width:100%;max-width:100%;overflow-x:hidden}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;padding:.9rem;width:100%;max-width:100%;min-width:0;display:grid;gap:.8rem;overflow-x:hidden}.topbar{position:relative;display:flex;justify-content:space-between;align-items:center;padding:1rem;border:1px solid var(--stroke);border-radius:16px;background:var(--panel);min-width:0}.brand-lockup{display:flex;align-items:center;gap:.7rem;min-width:0;max-width:100%}.brand-lockup>div{min-width:0}.brand-wordmark{width:250px;max-width:58%;height:auto;display:block}.brand-icon{width:34px;height:34px;border-radius:9px;flex:0 0 auto}.topbar h1{margin:0;font-size:1.15rem;letter-spacing:.02em}.topbar p{margin:.25rem 0 0;color:var(--muted);font-size:.82rem;white-space:normal;overflow-wrap:anywhere}.topbar-actions{display:flex;align-items:center;gap:.5rem;min-width:0}.auto-refresh-control{display:inline-flex;align-items:center;gap:.35rem;color:var(--muted);font-size:.78rem;white-space:nowrap}.auto-refresh-control input{width:14px;height:14px;margin:0;accent-color:var(--brand)}.topbar-actions button{min-width:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.topbar-menu{position:absolute;top:.72rem;right:1rem;z-index:30}.menu-link{border:0;background:transparent;color:#55675f;text-decoration:underline;text-underline-offset:.12em;padding:0;border-radius:0;font-size:.85rem;font-weight:600;cursor:pointer}.menu-link:hover{color:var(--brand)}.menu-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:170px;background:#fff;border:1px solid var(--stroke);border-radius:12px;box-shadow:0 10px 24px #1021191f;padding:.28rem;display:grid;gap:.2rem}.menu-dropdown-item{width:100%;text-align:left;border:1px solid transparent;border-radius:8px;background:#fff;color:var(--ink);padding:.45rem .52rem}.menu-dropdown-item:hover{background:#f2f8f5}.tab-strip{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:42px;gap:.45rem;width:100%;max-width:100%;min-width:0}.tab{display:flex;align-items:center;justify-content:center;gap:.22rem;width:100%;min-width:0;height:42px;border:1px solid var(--stroke);border-radius:999px;padding:.5rem .75rem;background:var(--panel);cursor:pointer;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden;transition:all .14s ease}.tab.active{border-color:var(--brand);background:var(--brand-soft);color:var(--ink)}.tab-label{display:inline-block}.tab-readonly-note{display:inline-block;font-size:.66rem;color:#778a80}.tab.active .tab-readonly-note{color:#4f665a}.content{display:grid;gap:.8rem;width:100%;max-width:100%;min-width:0;overflow-x:hidden}.panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;width:100%;min-width:0}.panel{background:var(--panel);border:1px solid var(--stroke);border-radius:16px;padding:.9rem;min-width:0;overflow-x:hidden}.panel.panel-tone-positive{background:#e8f6ef;border-color:#bcdccc}.panel.panel-tone-positive h2{color:#0f5f49}.panel.panel-tone-positive .muted{color:#4b6d60}.panel.panel-tone-warning{background:#fff4e2;border-color:#efd7aa}.panel.panel-tone-warning h2{color:#7f5a1b}.panel.panel-tone-warning .muted{color:#7a694a}.panel.panel-tone-negative{background:#fdebea;border-color:#efc3be}.panel.panel-tone-negative h2{color:#8b3025}.panel.panel-tone-negative .muted{color:#845a54}.panel h2{margin:0;font-size:.98rem}.panel .muted{margin-top:.55rem}.metric-value{margin:.5rem 0 0;font-size:1.45rem;font-weight:600}.metric-value.negative{color:var(--danger)}.metric{display:flex;flex-direction:column;gap:.45rem}.full-width{grid-column:1 / -1}.pill{display:inline-flex;align-items:center;gap:.35rem;width:fit-content;border-radius:999px;padding:.18rem .6rem;font-size:.76rem;font-weight:600}.pill-green{background:#e0f5eb;color:#1a6f4c}.pill-yellow{background:#fff4df;color:#8a5b11}.pill-red{background:#fee5e2;color:#942f23}.due-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.due-grid div{display:grid;gap:.2rem;background:var(--track);border-radius:10px;padding:.5rem}.bar-stack{display:grid;gap:.55rem;margin-top:.65rem}.bar-row{display:grid;gap:.35rem;grid-template-columns:74px 1fr auto;align-items:center;font-size:.83rem}.bar-track{height:8px;border-radius:999px;background:var(--track);overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#1f9072,#0e7a5f);border-radius:999px}.bar-fill.soft{background:linear-gradient(90deg,#f2bd6a,#f2a33a)}.list{display:grid;gap:.45rem;margin-top:.65rem}.list-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;border:1px solid var(--stroke);border-radius:12px;padding:.5rem .65rem}.list-row.compact{align-items:flex-start}.list-row p{margin:.15rem 0 0;color:var(--muted);font-size:.78rem}.tips{display:grid;gap:.45rem;margin-top:.6rem}.tips p{margin:0;border-left:3px solid var(--accent);padding-left:.6rem;color:#2f3d36}.section-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.section-head h2{margin:0}button.mini{border-radius:999px;padding:.24rem .54rem;font-size:.72rem}.action-queue-controls{display:grid;gap:.34rem;justify-items:end}.action-queue-controls button{min-width:78px}.breakdown-list{margin-top:.65rem;display:grid;gap:.35rem}.breakdown-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;border:1px solid var(--stroke);border-radius:10px;padding:.46rem .6rem;font-size:.83rem}.breakdown-row.total{background:#eff7f3;border-color:#cde2d7}.month-carousel{margin-top:.7rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.55rem}.carousel-arrow{min-width:38px;padding:.42rem .56rem}.month-carousel-track{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.45rem;padding:.4rem .6rem;border:1px solid var(--stroke);border-radius:999px;background:#f6faf8}.month-adjacent{color:#8ea097;font-size:.76rem}.month-adjacent:first-child{text-align:left}.month-adjacent:last-child{text-align:right}.month-current{font-size:.96rem;color:var(--ink)}.budget-donut-wrap{margin-top:.65rem;display:grid;gap:.55rem;justify-items:center}.budget-donut{width:148px;height:148px;border-radius:50%;color:#0e7a5f;display:grid;place-items:center}.budget-donut.green{color:#0f7f61}.budget-donut.yellow{color:#a86b10}.budget-donut.red{color:#b13a2a}.budget-donut-core{width:108px;height:108px;border-radius:50%;background:#fff;display:grid;place-items:center;gap:.1rem;text-align:center}.budget-donut-core strong{font-size:1.2rem}.budget-donut-core span{font-size:.76rem;color:var(--muted)}.budget-pie-wrap{margin-top:.65rem;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.75rem}.budget-pie{width:128px;height:128px;border-radius:50%;border:1px solid var(--stroke)}.budget-legend{display:grid;gap:.35rem}.budget-legend-item{display:grid;grid-template-columns:11px 1fr auto;align-items:center;gap:.35rem;font-size:.79rem}.swatch{width:11px;height:11px;border-radius:3px}.budget-form{margin-top:.7rem;display:grid;grid-template-columns:1fr 1fr auto;gap:.6rem;align-items:end}.saving-form{grid-template-columns:repeat(3,minmax(0,1fr))}.saving-form .actions{align-self:end}.forecast-form{margin-top:.7rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;align-items:end}.forecast-form label{display:grid;gap:.34rem;font-size:.82rem;color:#32433a}.forecast-results{margin-top:.75rem;display:grid;gap:.65rem}.forecast-meta{display:grid;gap:.18rem}.forecast-meta strong{font-size:.9rem}.forecast-meta span{color:var(--muted);font-size:.78rem}.forecast-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.forecast-metric{border:1px solid var(--stroke);border-radius:12px;padding:.55rem;display:grid;gap:.2rem;background:#f8fcfa}.forecast-metric small{color:var(--muted);font-size:.75rem}.forecast-metric strong{font-size:.95rem}.forecast-metric.negative strong{color:var(--danger)}.forecast-stack{height:11px;width:100%;border-radius:999px;overflow:hidden;display:flex;background:#e6eee9}.forecast-segment{height:100%}.forecast-segment.principal{background:#2f9c78}.forecast-segment.contribution{background:#5f8ee7}.forecast-segment.growth{background:#f2a33a}.forecast-legend{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem}.forecast-legend span{display:flex;align-items:center;gap:.35rem;font-size:.76rem;color:#2f3d36}.forecast-legend span.negative{color:var(--danger)}.swatch.forecast{border-radius:999px}.swatch.forecast.principal{background:#2f9c78}.swatch.forecast.contribution{background:#5f8ee7}.swatch.forecast.growth{background:#f2a33a}.budget-form label{display:grid;gap:.34rem;font-size:.82rem;color:#32433a}.budget-progress{height:8px;width:100%;min-width:96px;border-radius:999px;background:#e6eee9;overflow:hidden;margin-bottom:.16rem}.budget-progress-fill{height:100%;border-radius:999px;background:#0e7a5f}.budget-progress-fill.green{background:#0f7f61}.budget-progress-fill.yellow{background:#c9861d}.budget-progress-fill.red{background:#c64a38}.alert{border-radius:12px;border:1px solid #d2e2d8;background:#edf6f1;padding:.55rem .7rem;font-size:.83rem;overflow-wrap:anywhere}.alert.error{border-color:#f3d4ce;background:#fdf0ee}.undo-alert{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.undo-action{padding:.34rem .6rem;min-width:78px}.health-strip{border:1px solid var(--stroke);border-radius:12px;background:#f6fbf8;padding:.44rem .62rem;display:flex;align-items:center;gap:.46rem;font-size:.8rem}.health-strip.offline{border-color:#f3d4ce;background:#fff3f1}.health-strip.reconnecting{border-color:#efe0bf;background:#fff8ec}.health-dot{width:9px;height:9px;border-radius:999px;display:inline-block;background:#96a9a0}.health-dot.connected{background:#0e7a5f}.health-dot.reconnecting{background:#c9861d}.health-dot.offline{background:#bc3b2a}.form-grid{margin-top:.8rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.form-grid label{display:grid;gap:.34rem;font-size:.82rem;color:#32433a}.settings-fx-meta{margin-top:-.1rem;font-size:.74rem}.settings-fx-diagnostics{display:grid;gap:.25rem}.fx-status-badge{display:inline-flex;align-items:center;border-radius:999px;border:1px solid #c6d4ca;padding:.08rem .42rem;font-size:.72rem;font-weight:700;color:#3e4f45;background:#f2f6f3}.fx-status-badge.healthy{border-color:#9ad3ba;color:#0f6a50;background:#e7f7ef}.fx-status-badge.degraded{border-color:#e2c88e;color:#9a6419;background:#fff7e8}.fx-status-badge.offline{border-color:#e4a99d;color:#9d3526;background:#fff1ee}.fx-status-badge.unknown{border-color:#c9d1d9;color:#4e5b67;background:#f2f5f8}.settings-fx-error{font-size:.74rem;color:#a03d2d}.filter-bar{margin-top:.62rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.48rem;align-items:center}.date-range-picker{position:relative;grid-column:span 2;min-width:0}.date-range-trigger{width:100%;display:grid;grid-template-columns:auto 1fr;gap:.45rem;align-items:center;border:1px solid var(--stroke);border-radius:10px;background:#fff;color:var(--ink);padding:.45rem .58rem;text-align:left}.date-range-trigger.open{border-color:var(--brand);box-shadow:0 0 0 1px #0e7a5f2e}.date-range-trigger-label{font-size:.7rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.date-range-trigger-value{font-size:.82rem;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.date-range-popover{position:absolute;top:calc(100% + .35rem);left:0;z-index:40;width:min(352px,96vw);border:1px solid var(--stroke);border-radius:12px;background:#fff;box-shadow:0 12px 28px #1021192e;padding:.55rem}.date-range-popover-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.35rem;margin-bottom:.35rem}.date-range-popover-header strong{text-align:center;font-size:.82rem}.date-nav-btn{padding:.2rem .45rem;min-width:30px}.date-range-selection-summary{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;margin-bottom:.45rem;font-size:.72rem;color:var(--muted)}.date-range-weekday-row{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem;margin-bottom:.2rem}.date-range-weekday-row span{font-size:.68rem;color:var(--muted);text-align:center}.date-range-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem}.date-cell{height:34px;border-radius:8px;border:1px solid transparent;background:#fff;color:var(--ink);padding:0;font-size:.8rem}.date-cell.empty{visibility:hidden}.date-cell.today{border-color:#b7d7cb}.date-cell.in-range{background:#ecf7f2;color:#1f5a47}.date-cell.range-start,.date-cell.range-end{background:#0e7a5f;color:#fff;font-weight:700}.date-range-popover-actions{margin-top:.45rem;display:flex;justify-content:flex-end}.transactions-toolbar{margin-top:.55rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between}.saved-views{display:flex;flex-wrap:wrap;gap:.32rem}.saved-view-btn{padding:.35rem .58rem;font-size:.74rem;border-radius:999px}.saved-view-btn.active{border-color:var(--brand);background:var(--brand-soft);color:var(--ink);font-weight:600}.transactions-toolbar-actions{display:inline-flex;align-items:center;gap:.42rem}input,select,textarea{border:1px solid var(--stroke);border-radius:10px;background:#fff;color:var(--ink);padding:.48rem .58rem}textarea{resize:vertical}.inline-input{display:grid;grid-template-columns:1fr auto;gap:.4rem}.toggle-row{display:flex;align-items:center;gap:.45rem;min-height:38px}.actions{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}button{border:1px solid transparent;border-radius:10px;background:var(--brand);color:#fff;padding:.46rem .72rem;cursor:pointer}button.ghost{background:#fff;border-color:var(--stroke);color:var(--ink)}button.refresh-cta.busy{background:#e8f4ef;border-color:var(--brand);color:var(--brand);box-shadow:0 0 0 1px #0e7a5f14;animation:refresh-pulse 1s ease-in-out infinite}@keyframes refresh-pulse{0%{background:#e8f4ef}50%{background:#d6eee5}to{background:#e8f4ef}}button:disabled{opacity:.65;cursor:wait}.table-wrap{overflow-x:auto;margin-top:.6rem;width:100%;max-width:100%}table{width:100%;min-width:100%;table-layout:fixed;border-collapse:collapse;font-size:.8rem}.bills-table{table-layout:auto;min-width:900px}.bills-table th,.bills-table td{white-space:nowrap;overflow-wrap:normal;word-break:normal}.bills-table .status-toggle.single{min-width:96px}.bills-table .toggle-chip{min-width:92px;padding:.16rem .38rem;font-size:.72rem}th,td{border-bottom:1px solid var(--stroke);padding:.52rem;text-align:left;vertical-align:middle;overflow-wrap:anywhere;word-break:break-word}th{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.status{display:inline-flex;align-items:center;border-radius:999px;padding:.18rem .5rem;font-size:.72rem;text-transform:capitalize}.status.active{background:#e0f5eb;color:#1a6f4c}.status.paid{background:#ecf2ff;color:#28489b}.status.snoozed,.status.paused{background:#fff4df;color:#8a5b11}.status-toggle{display:inline-grid;grid-template-columns:1fr 1fr;gap:.25rem;min-width:160px}.status-toggle.single{grid-template-columns:1fr;min-width:110px}.toggle-chip{border:1px solid var(--stroke);background:#fff;color:var(--muted);border-radius:999px;padding:.2rem .5rem;font-size:.74rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.28rem}.toggle-chip:disabled{cursor:wait}.dot-spinner{display:inline-flex;gap:.14rem;align-items:center;justify-content:center}.dot-spinner span{width:.26rem;height:.26rem;border-radius:999px;background:currentColor;opacity:.28;animation:dot-pulse 1s ease-in-out infinite}.dot-spinner span:nth-child(2){animation-delay:.16s}.dot-spinner span:nth-child(3){animation-delay:.32s}@keyframes dot-pulse{0%,80%,to{opacity:.28;transform:scale(.82)}40%{opacity:.95;transform:scale(1)}}.toggle-chip.active{border-color:#12845f;color:#0f6a4b;background:#dff4ee}.toggle-chip.snoozed{border-color:#9aa7a0;color:#4d5a54;background:#eef2f0}.toggle-chip.paid{border-color:#12845f;color:#0f6a4b;background:#dff4ee}.toggle-chip.unpaid{border-color:#bc3b2a;color:#8f2b20;background:#fee5e2}.row-actions{display:inline-flex;align-items:center;gap:.25rem}.row-success{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid #cfe3da;background:#eff8f3;color:#11694d;font-size:.67rem;padding:.08rem .44rem}.icon-btn{width:30px;height:30px;padding:0;display:inline-grid;place-items:center;font-size:.95rem;line-height:1}.txn-row-high-value td{background:#fff7e9}.txn-row-duplicate td{box-shadow:inset 0 -1px #f2d1cb}.txn-row-high-value.txn-row-duplicate td{background:#fff2e7}.txn-merchant-cell{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.txn-flags{display:inline-flex;gap:.24rem}.txn-flag{display:inline-flex;align-items:center;border-radius:999px;padding:.08rem .38rem;font-size:.65rem;font-weight:700}.txn-flag.high{border:1px solid #f2c98d;background:#fff0d7;color:#8f5f1a}.txn-flag.duplicate{border:1px solid #f2bfb3;background:#ffe9e5;color:#8b3a2c}.actions.compact{flex-wrap:wrap}.import-card{margin-top:.65rem;border:1px dashed var(--stroke);border-radius:12px;padding:.62rem;background:#fcfdfc}.import-card p{margin:.28rem 0 .4rem}.rule-backfill-card{margin-top:.65rem;border:1px dashed var(--stroke);border-radius:12px;padding:.62rem;background:#fcfdfc;display:grid;gap:.52rem}.rule-backfill-summary{margin:0;font-size:.74rem;color:var(--muted)}.rule-backfill-stats{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.78rem}.rule-backfill-stats strong{font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;padding:1rem;background:#09130f59;display:grid;place-items:center}.modal-card{width:min(680px,100%);max-height:min(88vh,920px);overflow:auto;border:1px solid var(--stroke);border-radius:16px;background:var(--panel);padding:.95rem;box-shadow:0 20px 40px #10211933}.modal-card-compact{width:min(460px,100%)}.modal-card h2{margin:0;font-size:1rem}.modal-form{margin-top:.7rem}.modal-actions{display:flex;justify-content:flex-end;gap:.45rem}button.danger{border-color:transparent;background:var(--danger);color:#fff}.hint{display:inline-grid;place-items:center;margin-left:.25rem;width:15px;height:15px;border-radius:999px;background:var(--track);font-size:.67rem;cursor:help}.plan-check-row{margin-top:.48rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}.checklist{margin-top:.55rem;display:grid;gap:.36rem}.checklist-item{display:flex;align-items:center;gap:.52rem;border:1px solid var(--stroke);border-radius:10px;padding:.36rem .48rem}.checklist-item span{color:#91a49b;font-weight:700}.checklist-item.done{background:#eef8f3;border-color:#d1e7dc}.checklist-item.done span{color:#0e7a5f}.checklist-item p{margin:0}.install-wizard-header{margin-top:.55rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.install-step-card{display:grid;gap:.55rem}.install-command-list{display:grid;gap:.38rem}.install-command-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.45rem;border:1px solid var(--stroke);border-radius:10px;background:#f9fcfa;padding:.42rem .5rem}.install-command-row code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:.76rem;color:#234437;overflow-wrap:anywhere}.install-step-check{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--muted)}.install-step-check input{margin:0}.forecast-scenarios{margin-top:.5rem;border-top:1px solid var(--stroke);padding-top:.6rem}.forecast-scenarios h3{margin:0;font-size:.87rem}.muted{color:var(--muted)}.centered{text-align:center}@media(max-width:980px){.panel-grid,.form-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:stretch;gap:.5rem;padding-top:2rem}.brand-lockup{width:100%;align-items:flex-start;flex-direction:column;gap:.45rem}.brand-wordmark{width:190px;max-width:100%}.brand-icon{width:30px;height:30px}.topbar-actions{width:100%;display:flex;flex-direction:column;align-items:stretch}.topbar-actions button{width:100%;white-space:normal}.auto-refresh-control{width:100%;justify-content:center}.topbar-menu{top:.5rem;right:.9rem}.tab-strip{grid-template-columns:repeat(2,1fr);grid-auto-rows:40px}.tab{height:40px}.month-carousel-track{grid-template-columns:1fr;text-align:center}.month-adjacent{display:none}.budget-pie-wrap{grid-template-columns:1fr;justify-items:center}.budget-form,.forecast-form,.forecast-metrics,.forecast-legend,.saving-form,.filter-bar,.install-command-row{grid-template-columns:1fr}.date-range-popover{width:min(320px,calc(100vw - 2rem))}.date-range-picker{grid-column:auto}.bills-table{min-width:820px}}
