:root{--bg: #f4f6f8;--card: #ffffff;--ink: #0f172a;--ink-soft: #64748b;--ink-faint: #94a3b8;--line: #e7ebef;--line-soft: #f1f4f7;--green: #22c55e;--green-deep: #16a34a;--green-soft: #ecfdf3;--red: #ef4444;--red-deep: #dc2626;--red-soft: #fef2f2;--brand: #0d9488;--brand-deep: #0f766e;--brand-soft: #e6f5f3;--amber: #f59e0b;--radius: 18px;--radius-sm: 12px;--shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 8px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .16);--pad: 18px;--max: 480px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;font-feature-settings:"tnum" 1,"cv01" 1}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit}.app{max-width:var(--max);margin:0 auto;min-height:100%;padding:0 var(--pad) calc(120px + env(safe-area-inset-bottom));position:relative}.loading{display:grid;place-items:center;height:100vh;color:var(--ink-soft);font-weight:500}.topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(14px + env(safe-area-inset-top)) 0 12px;position:sticky;top:0;background:linear-gradient(var(--bg) 70%,transparent);z-index:30}.brandmark{font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--brand-deep)}.switcher{position:relative}.switcher-trigger{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-weight:600;font-size:14px;color:var(--ink);box-shadow:var(--shadow);max-width:220px}.switcher-trigger .dot{width:8px;height:8px;border-radius:50%;flex:none}.switcher-trigger .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.switcher-trigger .chev{color:var(--ink-faint);margin-left:2px}.switcher-menu{position:absolute;right:0;top:calc(100% + 8px);width:260px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:6px;z-index:40;animation:pop .14s ease}.switcher-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px;border-radius:10px;font-size:14px;color:var(--ink)}.switcher-item:hover{background:var(--line-soft)}.switcher-item.active{background:var(--brand-soft);color:var(--brand-deep);font-weight:600}.switcher-item .meta{margin-left:auto;font-size:12px;color:var(--ink-faint)}.switcher-sep{height:1px;background:var(--line);margin:6px 4px}.switcher-add{color:var(--brand-deep);font-weight:600}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--pad)}.hero{text-align:center;padding:26px var(--pad) 22px}.hero .acct-name{font-size:14px;font-weight:600;color:var(--ink-soft);letter-spacing:.02em}.hero .balance{font-size:46px;font-weight:800;letter-spacing:-.03em;margin:6px 0 2px;font-variant-numeric:tabular-nums}.hero .balance-sub{font-size:13px;color:var(--ink-faint)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;letter-spacing:.04em;padding:6px 12px;border-radius:999px;margin-top:14px}.badge.ahead{background:var(--brand-soft);color:var(--brand-deep)}.badge.on_track{background:var(--green-soft);color:var(--green-deep)}.badge.behind{background:var(--red-soft);color:var(--red-deep)}.streak-chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;padding:6px 12px;border-radius:999px;background:#fff7ed;color:#c2410c;margin:14px 0 0 8px}.progress-wrap{margin:18px 0 6px}.progress-row{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-soft);margin-bottom:7px;font-weight:600}.progress-track{height:12px;background:var(--line-soft);border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--green));transition:width .7s cubic-bezier(.22,1,.36,1)}.metrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:16px}.metric{padding:14px 12px;text-align:left}.metric .label{font-size:11px;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.05em}.metric .value{font-size:18px;font-weight:800;margin-top:8px;letter-spacing:-.02em}.metric .value.pos{color:var(--green-deep)}.metric .sub{font-size:11.5px;color:var(--ink-soft);margin-top:3px}.section-title{font-size:13px;font-weight:700;color:var(--ink-soft);margin:24px 4px 10px;letter-spacing:.01em}.chart-card{padding:16px 8px 8px}.chart-legend{display:flex;gap:16px;padding:0 12px 6px;font-size:12px;color:var(--ink-soft)}.chart-legend .key{display:inline-flex;align-items:center;gap:6px}.chart-legend .swatch{width:14px;height:3px;border-radius:2px}.countdown{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-top:4px}.countdown .num{font-size:30px;font-weight:800;color:var(--brand-deep);letter-spacing:-.02em}.countdown .unit{font-size:13px;color:var(--ink-soft)}.tab-bar{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:space-around;background:#ffffffeb;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:35;max-width:var(--max);margin:0 auto}.tab-bar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--ink-faint);padding:4px 0}.tab-bar button .ic{font-size:19px;line-height:1}.tab-bar button.active{color:var(--brand-deep)}.fab{position:fixed;bottom:calc(78px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:36;display:flex;align-items:center;gap:8px;background:var(--brand);color:#fff;font-weight:700;font-size:15px;padding:14px 26px;border-radius:999px;box-shadow:0 8px 24px #0d948866;max-width:calc(var(--max) - 36px)}.fab:active{transform:translate(-50%) scale(.96)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:50;display:flex;align-items:flex-end;justify-content:center;animation:fade .18s ease}.modal{background:var(--card);width:100%;max-width:var(--max);border-radius:24px 24px 0 0;padding:22px var(--pad) calc(24px + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);animation:slideup .26s cubic-bezier(.22,1,.36,1);max-height:92vh;overflow-y:auto}.modal-grip{width:40px;height:4px;background:var(--line);border-radius:999px;margin:-6px auto 16px}.modal h2{margin:0 0 4px;font-size:20px;letter-spacing:-.02em}.modal .modal-sub{color:var(--ink-soft);font-size:13.5px;margin:0 0 18px}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:16px;color:var(--ink);background:var(--card);transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand)}.field textarea{resize:vertical;min-height:64px}.field .prefix-wrap{position:relative}.field .prefix-wrap .prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-faint);font-weight:600}.field .prefix-wrap input{padding-left:30px}.btn{width:100%;padding:15px;border-radius:var(--radius-sm);font-size:16px;font-weight:700;background:var(--brand);color:#fff;transition:transform .1s,opacity .15s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5}.btn.ghost{background:var(--line-soft);color:var(--ink)}.btn.danger{background:var(--red-soft);color:var(--red-deep)}.btn.green{background:var(--green)}.type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.type-toggle button{padding:14px;border-radius:var(--radius-sm);border:1.5px solid var(--line);font-weight:700;font-size:14px;color:var(--ink-soft);background:var(--card)}.type-toggle button.sel-green{border-color:var(--green);background:var(--green-soft);color:var(--green-deep)}.type-toggle button.sel-red{border-color:var(--red);background:var(--red-soft);color:var(--red-deep)}.calc-preview{background:var(--brand-soft);border-radius:var(--radius-sm);padding:14px 16px;margin:4px 0 16px}.calc-preview .row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0;color:var(--brand-deep)}.calc-preview .row strong{font-weight:800}.login-screen{display:grid;place-items:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:360px;text-align:center}.login-card .logo{font-size:34px;font-weight:800;color:var(--brand-deep);letter-spacing:-.03em}.login-card .tag{color:var(--ink-soft);font-size:14px;margin:6px 0 26px}.error-text{color:var(--red-deep);font-size:13px;margin-top:10px}.onboard{padding:60px var(--pad) 40px;text-align:center}.onboard h1{font-size:26px;letter-spacing:-.03em;margin-bottom:6px}.onboard p.lead{color:var(--ink-soft);margin-bottom:30px}.choice-cards{display:grid;gap:14px}.choice-card{text-align:left;padding:22px;border-radius:var(--radius);border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);display:flex;align-items:center;gap:16px}.choice-card:active{transform:scale(.99)}.choice-card .emoji{font-size:34px}.choice-card .ttl{font-size:17px;font-weight:700}.choice-card .desc{font-size:13px;color:var(--ink-soft);margin-top:2px}.filter-bar{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;-webkit-overflow-scrolling:touch}.filter-bar::-webkit-scrollbar{display:none}.chip{flex:none;padding:7px 14px;border-radius:999px;background:var(--card);border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-soft)}.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}.search-input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:15px;margin-bottom:14px}.week-header{display:flex;justify-content:space-between;align-items:center;margin:18px 4px 8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint)}.week-net{font-weight:800}.week-net.pos{color:var(--green-deep)}.week-net.neg{color:var(--red-deep)}.week-header .ind{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px}.ledger-row{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:8px;width:100%;text-align:left}.ledger-row .tx-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex:none;font-size:16px}.ledger-row .tx-icon.pay{background:var(--green-soft)}.ledger-row .tx-icon.chg{background:var(--red-soft)}.ledger-row .tx-main{flex:1;min-width:0}.ledger-row .tx-label{font-weight:600;font-size:14.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ledger-row .tx-date{font-size:12px;color:var(--ink-faint);margin-top:2px}.ledger-row .tx-amt{font-weight:800;font-size:15px;white-space:nowrap}.ledger-row .tx-amt.pos{color:var(--green-deep)}.ledger-row .tx-amt.neg{color:var(--red-deep)}.ledger-row .tx-bal{font-size:11px;color:var(--ink-faint);margin-top:2px;text-align:right}.empty{text-align:center;color:var(--ink-faint);padding:50px 20px;font-size:14px}.plan-table{width:100%;border-collapse:collapse;font-size:13px}.plan-table th{text-align:right;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);padding:8px;font-weight:700}.plan-table th:first-child{text-align:left}.plan-table td{text-align:right;padding:10px 8px;border-top:1px solid var(--line-soft);font-variant-numeric:tabular-nums}.plan-table td:first-child{text-align:left;color:var(--ink-soft)}.plan-table tr.current{background:var(--brand-soft)}.plan-table tr.current td{color:var(--brand-deep);font-weight:700}.whatif{margin-top:8px}.whatif .slider-row{margin-bottom:16px}.whatif .slider-row label{display:flex;justify-content:space-between;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:8px}.whatif input[type=range]{width:100%;accent-color:var(--brand)}.interest-note{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:14px;font-size:13px;color:#92400e;margin-top:14px}.toast-stack{position:fixed;top:calc(16px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;width:calc(100% - 36px);max-width:calc(var(--max) - 36px)}.toast{background:var(--ink);color:#fff;padding:12px 16px;border-radius:12px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow-lg);animation:toastIn .3s cubic-bezier(.22,1,.36,1);text-align:center}.toast.good{background:var(--green-deep)}.milestone-card{text-align:center;padding:8px 4px}.milestone-card .pct{font-size:54px;font-weight:800;color:var(--brand-deep);letter-spacing:-.03em}.milestone-card .ms-title{font-size:22px;font-weight:800;margin:6px 0}.milestone-card .ms-msg{color:var(--ink-soft);font-size:15px;line-height:1.5;margin-bottom:22px}.reminder{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:12px 14px;font-size:13px;color:#92400e;margin:14px 0 4px;display:flex;align-items:center;gap:8px}.ouch-flash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:55;box-shadow:inset 0 0 80px 20px #ef44448c;animation:ouch .6s ease}.focus-mode .metrics,.focus-mode .chart-card,.focus-mode .section-title,.focus-mode .progress-wrap,.focus-mode .countdown-card,.focus-mode .reminder{display:none!important}@keyframes pop{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}@keyframes ouch{0%{opacity:0}30%{opacity:1}to{opacity:0}}@keyframes count-pop{0%{transform:scale(1)}40%{transform:scale(1.08)}to{transform:scale(1)}}.balance.pop{animation:count-pop .5s ease}.row-actions{display:flex;gap:10px;margin-top:8px}.link-btn{color:var(--brand-deep);font-weight:600;font-size:14px}.muted{color:var(--ink-soft)}.center{text-align:center}
