@import"https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@300;400;500;600;700;800&family=Roboto+Mono:wght@400;500;600&display=swap";:root{--bg: #0b0f1a;--bg-2: #111827;--surface: #151c2c;--surface-2: #1e2840;--surface-3: #253048;--glass: rgba(21, 28, 44, .72);--text: #f0f4ff;--text-2: #8fa3c8;--text-3: #8894a8;--border: rgba(255,255,255,.07);--border-2: rgba(255,255,255,.12);--primary: #3b82f6;--primary-dim: rgba(59,130,246,.14);--primary-glow: rgba(59,130,246,.28);--income: #22d3a5;--income-dim: rgba(34,211,165,.12);--income-glow: rgba(34,211,165,.25);--expense: #f4476b;--expense-dim: rgba(244,71,107,.12);--expense-glow: rgba(244,71,107,.25);--amber: #f59e0b;--amber-dim: rgba(245,158,11,.13);--display: "Be Vietnam Pro", system-ui, sans-serif;--body: "Be Vietnam Pro", system-ui, sans-serif;--mono: "Roboto Mono", ui-monospace, monospace;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-2xl: 28px;--shadow-sm: 0 2px 8px rgba(0,0,0,.4);--shadow-md: 0 8px 32px rgba(0,0,0,.5);--shadow-lg: 0 24px 64px rgba(0,0,0,.6);--glow-income: 0 0 24px rgba(34,211,165,.18);--glow-expense: 0 0 24px rgba(244,71,107,.18);--glow-primary: 0 0 24px rgba(59,130,246,.2)}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;scrollbar-width:none;-ms-overflow-style:none;outline:0!important;margin:0;padding:0}*::-webkit-scrollbar{display:none}body{margin:0;min-width:320px;background:var(--bg);color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.35}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-up{0%{opacity:0;transform:translateY(22px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pulse-glow{0%,to{opacity:.6}50%{opacity:1}}@keyframes tap-shake{0%{filter:brightness(1)}30%{filter:brightness(1.18)}65%{filter:brightness(.94)}to{filter:brightness(1.08)}}button:not(:disabled):active,.wallet-row:active,.rank-row.is-clickable:active{animation:tap-shake .13s ease-out both;animation-duration:.17s}.app-shell{min-height:100svh;display:grid;grid-template-rows:1fr auto;background:var(--bg)}.app-main{position:relative;min-height:100%;overflow:auto}.screen{width:min(1180px,100%);min-height:100%;margin:0 auto;padding:28px 16px 120px}.app-main-stage{position:relative;min-height:100%}.screen-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;-webkit-overflow-scrolling:touch}.screen-layer-enter{animation:screen-enter .22s ease-out both}.screen-layer-exit{animation:screen-exit .22s ease-out both;pointer-events:none}@keyframes screen-enter{0%{opacity:0;transform:translateY(8px) scale(.992)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes screen-exit{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-4px) scale(.995)}}.swipe-screen,.stats-screen{touch-action:pan-y}.dash-card{position:relative;overflow:hidden;padding:26px 22px 22px;margin-bottom:16px;border-radius:var(--r-xl);border:1px solid var(--border-2);background:linear-gradient(145deg,#1a2440,#111827 80%);box-shadow:var(--shadow-md),inset 0 1px #ffffff0f;animation:slide-up .32s ease-out both}.dash-card:before{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,var(--income-glow) 0%,transparent 70%);pointer-events:none}.dash-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.dash-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2)}.dash-balance{display:block;margin:4px 0 18px;font-family:var(--mono);font-size:clamp(30px,8vw,52px);font-weight:600;letter-spacing:-.02em;color:var(--income);text-shadow:var(--glow-income)}.dash-metrics{display:flex;gap:24px;padding-top:16px;border-top:1px solid var(--border)}.dash-metric{display:flex;flex-direction:column;gap:3px}.metric-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}.metric-value{font-family:var(--mono);font-size:15px;font-weight:600}.metric-value.is-up{color:var(--income)}.metric-value.is-down{color:var(--expense)}.section-heading{margin:24px 0 10px;font-family:var(--display);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:24px 0 10px}.section-title h2{margin:0;font-family:var(--display);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.section-title span{color:var(--text-3);font-size:12px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.chart-card{margin-bottom:18px;padding:14px 14px 10px;border-radius:var(--r-xl);border:0;background:linear-gradient(145deg,#1e2840eb,#151c2cfa);box-shadow:var(--shadow-md)}.chart-tooltip{display:grid;gap:8px;padding:12px 14px;border-radius:var(--r-md);background:#0b0f1af2;border:0;box-shadow:var(--shadow-sm)}.chart-tooltip-row{display:grid;gap:3px}.chart-tooltip-label{color:var(--text);font-size:12px;font-weight:500}.chart-tooltip-value{color:var(--income);font-family:var(--mono);font-size:13px;font-weight:500}.chart-card :is(.recharts-wrapper,.recharts-surface,.recharts-layer,svg){outline:0!important}.chart-card :is(.recharts-wrapper,.recharts-surface,.recharts-layer,svg):focus,.chart-card :is(.recharts-wrapper,.recharts-surface,.recharts-layer,svg):focus-visible{outline:0!important}.stat-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:6px;padding:18px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);transform:translateY(0) scale(1);transition:transform .15s cubic-bezier(.2,.8,.2,1),border-color .15s ease,background .15s ease,box-shadow .15s ease}.stat-card:active{transform:translateY(2px) scale(.96);border-color:var(--border-2);background:var(--surface-2);box-shadow:inset 0 2px 12px #0000002e}.stat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;border-radius:0 0 var(--r-lg) var(--r-lg)}.stat-card.income:after{background:linear-gradient(90deg,transparent,var(--income),transparent)}.stat-card.expense:after{background:linear-gradient(90deg,transparent,var(--expense),transparent)}.stat-icon{display:none}.stat-card p{margin:0;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-2)}.stat-card strong{font-family:var(--mono);font-size:18px;font-weight:600;letter-spacing:-.01em}.stat-card.income strong{color:var(--income)}.stat-card.expense strong{color:var(--expense)}.dash-wallets{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(155px,1fr);gap:10px;overflow-x:auto;padding-bottom:4px;margin-bottom:4px}.wallet-chip{padding:16px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;gap:6px;transform:translateY(0) scale(1);transition:transform .15s cubic-bezier(.2,.8,.2,1),border-color .15s ease,background .15s ease,box-shadow .15s ease}.wallet-chip:active{transform:translateY(2px) scale(.96);border-color:var(--border-2);background:var(--surface-2);box-shadow:inset 0 2px 12px #0000002e}.wallet-chip span{font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--text)}.wallet-chip strong{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--income)}.dash-tx{border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);overflow:hidden}.row-list{display:grid;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);overflow:hidden}.rank-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--border);transition:background .16s ease}.rank-row:last-child{border-bottom:0}.rank-row.is-clickable{width:100%;border:0;border-bottom:1px solid var(--border);background:transparent;color:inherit;font:inherit;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transform:translateY(0) scale(1);transition:transform .14s cubic-bezier(.2,.8,.2,1),background .14s ease,border-color .14s ease}.rank-row.is-clickable:active{transform:scale(.985);background:var(--surface-2)}.rank-row.is-clickable:last-child{border-bottom:0}.tx-info{display:flex;flex-direction:column;gap:8px;min-width:0}.tx-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.tx-meta{display:inline-flex;align-items:center;width:fit-content;max-width:100%;padding:3px 9px;border-radius:999px;border:1px solid var(--wallet-accent-border, var(--border-2));background:var(--wallet-accent-soft, rgba(59,130,246,.12));color:var(--wallet-accent, var(--text-3));font-size:11px;font-weight:700;line-height:1.2;white-space:nowrap;margin-right:auto}.tx-money{font-family:var(--mono);font-size:14px;font-weight:600;white-space:nowrap;text-align:right}.tx-money.expense{color:var(--expense)}.tx-money.income{color:var(--income)}.dash-empty{padding:28px;text-align:center;color:var(--text-3);font-size:13px}.dash-link{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);color:var(--text-2);font-size:12px;font-weight:700;transition:transform .15s ease,border-color .15s ease,background .15s ease,color .15s ease}.dash-link:active{transform:scale(.96);border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}.history-screen{display:flex;flex-direction:column;gap:10px}.history-head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center;min-height:40px}.history-back-icon{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);color:var(--text-2);transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease}.history-back-icon:active{transform:scale(.96);background:var(--surface-2);color:var(--primary)}.history-summary-line{display:grid;grid-auto-flow:column;grid-auto-columns:max-content;justify-content:start;align-items:center;gap:8px;overflow-x:auto;overflow-y:hidden;white-space:nowrap;padding-bottom:2px;-webkit-overflow-scrolling:touch;width:100%}.history-summary-line span{display:inline-flex;align-items:center;white-space:nowrap;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-3);font-size:12px;font-weight:600}.history-search{display:flex;align-items:center;gap:10px;min-height:40px;padding:0 12px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);min-width:0}.history-search svg{color:var(--text-3);flex:0 0 auto}.history-search input{width:100%;min-width:0;border:0;background:transparent;color:var(--text);font-size:14px;outline:none}.history-search input::placeholder{color:var(--text-3);opacity:1}.history-filter-icon{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);color:var(--text-2);transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease}.history-filter-icon:active{transform:scale(.96);background:var(--surface-2);color:var(--primary)}.history-toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.history-select{display:grid;gap:6px}.history-select span{color:var(--text-3);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.history-select select{width:100%;min-height:44px;padding:0 12px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;outline:none}.history-select select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3b82f61f}.history-list{display:grid;gap:8px}.history-list.is-empty{margin-top:8px}.history-load-more{height:1px}.history-empty-state{display:flex;align-items:center;justify-content:center;min-height:72px;padding:14px 16px;border:1px dashed var(--border);border-radius:var(--r-lg);background:#ffffff05;color:var(--text-3);font-size:13px;font-weight:500;text-align:center}.history-item{display:flex;flex-direction:column;gap:4px;width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);text-align:left;transition:transform .15s cubic-bezier(.2,.8,.2,1),background .15s ease,border-color .15s ease}.history-item:active{transform:scale(.985);background:var(--surface-2)}.history-item-main{display:grid;gap:8px;min-width:0}.history-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;min-width:0}.history-item-balance-range{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:1px 0 2px}.history-balance-chip{display:inline-flex;align-items:center;min-width:0;padding:4px 8px;border-radius:999px;background:#ffffff08}.history-balance-chip.is-now{background:#10b98114;border-color:#10b98124}.history-balance-value{color:var(--text);font-size:11px;font-weight:400;line-height:1;white-space:nowrap}.history-balance-chip.is-now .history-balance-value{color:var(--income)}.history-balance-arrow{color:var(--text-3);flex:0 0 auto;stroke-width:2.5px}.tx-name{flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;font-size:14px;font-weight:600;line-height:1.2}.tx-meta{max-width:fit-content}.history-item-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.history-amount{font-family:var(--mono);font-size:14px;font-weight:700;white-space:nowrap;line-height:1;margin-left:auto;text-align:right}.history-amount.is-up{color:var(--income)}.history-amount.is-down{color:var(--expense)}.history-date{color:var(--text-3);font-size:10px;font-weight:600;white-space:nowrap;line-height:1.2;text-align:left}.history-filter-sheet{display:grid;gap:12px;padding:18px 20px 22px}.history-filter-group{display:grid;gap:8px}.history-filter-title{color:var(--text-3);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.history-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.history-filter-chips.is-scroll{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch}.history-filter-chip{flex:0 0 auto;min-height:36px;padding:0 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-2);font-size:12px;font-weight:700;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease}.history-filter-chip:active{transform:scale(.96)}.history-filter-chip.is-active{border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}.history-filter-actions{display:grid;grid-template-columns:1fr .9fr;gap:10px;margin-top:4px}.history-filter-actions .primary-button,.history-filter-actions .secondary-button{min-height:46px}.history-filter-actions .primary-button{background:var(--primary);color:#fff}.history-filter-actions .secondary-button{background:var(--surface-2);border-color:var(--border);color:var(--text-2)}@media(max-width:560px){.history-item{gap:5px}.history-head{grid-template-columns:auto minmax(0,1fr) auto}.history-item-top{gap:8px}}.wallet-list{display:grid;gap:10px}.wallet-add-button{width:100%;min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;border:1px dashed rgba(59,130,246,.3);border-radius:var(--r-lg);background:#3b82f60d;color:var(--primary);font-weight:700;font-size:14px;transition:background .15s ease,border-color .15s ease,transform .15s cubic-bezier(.2,.8,.2,1),box-shadow .15s ease}.wallet-add-button:active{transform:translateY(2px) scale(.96);background:#3b82f61a;border-color:#3b82f67a;box-shadow:inset 0 2px 12px #0000002e}.wallet-add-icon{display:inline-flex;align-items:center;justify-content:center;color:currentColor;flex:0 0 auto}.wallet-add-button span:last-child{line-height:1}.wallet-row{--wallet-accent: var(--primary);--wallet-accent-soft: rgba(59,130,246,.14);--wallet-accent-border: rgba(59,130,246,.28);--wallet-accent-glow: rgba(59,130,246,.18);position:relative;display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:16px;border-radius:var(--r-lg);background:radial-gradient(circle at left top,var(--wallet-accent-soft),transparent 58%),linear-gradient(180deg,#ffffff05,#fff0),var(--surface);border:1px solid var(--wallet-accent-border);cursor:pointer;transform:translateY(0) scale(1);box-shadow:0 0 0 1px #ffffff04,0 10px 24px #0000002e,0 0 20px var(--wallet-accent-glow);transition:border-color .15s ease,background .15s ease,transform .15s cubic-bezier(.2,.8,.2,1),box-shadow .15s ease,filter .15s ease}.wallet-row:active{transform:translateY(2px) scale(.96);border-color:color-mix(in srgb,var(--wallet-accent) 65%,white 10%);filter:saturate(1.05);background:radial-gradient(circle at left top,color-mix(in srgb,var(--wallet-accent) 20%,transparent),transparent 58%),linear-gradient(180deg,#ffffff08,#fff0),var(--surface-2);box-shadow:inset 0 2px 12px #0000002e}.wallet-row-info{display:flex;flex-direction:column;gap:4px}.wallet-name{font-size:15px;font-weight:700;color:color-mix(in srgb,var(--wallet-accent) 72%,var(--text) 28%)}.wallet-balance{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--wallet-accent)}.wallet-row-actions{display:flex;gap:8px}.w-btn{width:36px;height:36px;display:grid;place-items:center;border:0;border-radius:var(--r-sm);transition:transform .14s ease,background .14s ease}.w-btn:active{transform:scale(.88)}.w-btn.up{background:var(--wallet-accent-soft);color:var(--wallet-accent)}.w-btn:disabled{opacity:.2}.segmented{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:5px;margin-bottom:18px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}.segmented button{min-height:36px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:13px;font-weight:700;letter-spacing:.01em;transition:background .18s ease,color .18s ease}.segmented button.active{background:var(--primary);color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.settings{display:flex;flex-direction:column;gap:20px}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.settings-card{min-height:130px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:14px;padding:18px;border-radius:var(--r-xl);border:1px solid var(--border);background:var(--surface);color:var(--text);text-align:left;box-shadow:0 0 #0000;transform:translateY(0) scale(1);transition:transform .12s cubic-bezier(.2,.8,.2,1),border-color .12s ease,background .12s ease,box-shadow .12s ease,filter .12s ease;animation:fade-in .22s ease-out both}.settings-card:active{transform:translateY(3px) scale(.92);border-color:var(--border-2);background:var(--surface-2);box-shadow:inset 0 3px 18px #00000047;filter:brightness(1.08)}.settings-card-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:var(--r-md);background:var(--surface-2);transition:transform .12s ease,background .12s ease}.settings-card:active .settings-card-icon{transform:translateY(1px) scale(.84);background:var(--surface-3)}.settings-card-body{display:flex;flex-direction:column;gap:4px}.settings-card-body strong{font-size:14px;font-weight:700;line-height:1.2}.settings-card-body span{font-size:11px;font-weight:500;color:var(--text-3)}.settings-card.export{border-color:#3b82f638;background:linear-gradient(145deg,rgba(59,130,246,.06),var(--surface));color:#60a5fa}.settings-card.import{border-color:#22d3a52e;background:linear-gradient(145deg,rgba(34,211,165,.06),var(--surface));color:var(--income)}.settings-card.guide{border-color:#06b6d438;background:linear-gradient(145deg,rgba(6,182,212,.07),var(--surface));color:#22d3ee}.settings-card.warn{border-color:#f59e0b2e;background:linear-gradient(145deg,rgba(245,158,11,.06),var(--surface));color:var(--amber)}.settings-card.danger{border-color:#f4476b2e;background:linear-gradient(145deg,rgba(244,71,107,.06),var(--surface));color:var(--expense)}.bottom-nav{--nav-bg: rgba(11, 15, 26, .84);--fab-size: 62px;position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:8px 12px max(10px,env(safe-area-inset-bottom));background:var(--nav-bg);border-top:1px solid var(--border);backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);overflow:visible}.bottom-nav-group{position:relative;z-index:1;flex:1 1 0;display:flex;align-items:stretch;justify-content:space-around;min-width:0}.bottom-nav-group:first-child{padding-right:36px}.bottom-nav-group:last-child{padding-left:36px}.nav-button{position:relative;flex:1 1 0;min-width:0;height:58px;display:grid;place-items:center;gap:0;padding:0;border:0;border-radius:0;background:transparent;color:#93a0b5;transition:color .18s ease,transform .18s ease}.nav-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;transition:background .2s ease,color .2s ease,transform .2s ease}.nav-button.is-active{color:var(--primary)}.nav-button.is-active .nav-icon{color:var(--primary);transform:translateY(-1px) scale(1.08)}.nav-button.is-active:before{content:"";position:absolute;left:24%;right:24%;top:-8px;height:2px;border-radius:999px;background:var(--primary);box-shadow:0 0 10px #3b82f64d}.nav-button-add{position:absolute;left:50%;top:-24px;transform:translate(-50%);z-index:3;flex:0 0 auto;width:74px;height:74px;border-radius:999px;color:var(--primary);background:var(--surface);box-shadow:var(--shadow-lg)}.nav-button-add .nav-icon{width:var(--fab-size);height:var(--fab-size);border-radius:999px;background:linear-gradient(135deg,var(--primary) 0%,#1d4ed8 100%);color:#fff;box-shadow:0 14px 30px #2563eb52,inset 0 2px #ffffff1f}.nav-button:active{transform:translateY(1px) scale(.97)}.nav-button-add:active{transform:translate(-50%) scale(.94)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;align-items:end;background:#0009;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:fade-in .18s ease-out both}.modal-backdrop.is-fab{z-index:60}.modal-backdrop.is-sheet{z-index:50}.onboarding{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:grid;place-items:center;padding:14px;background:linear-gradient(180deg,rgba(59,130,246,.16),transparent 38%),var(--bg);animation:fade-in .18s ease-out both}.onboarding-card{position:relative;width:min(420px,100%);padding:16px;border:1px solid var(--border-2);border-radius:var(--r-2xl);background:linear-gradient(160deg,#1e2840f5,#151c2cfa);box-shadow:var(--shadow-lg);animation:slide-up .26s ease-out both}.onboarding-skip{position:absolute;top:12px;right:12px;z-index:1;min-height:34px;padding:0 12px;border:1px solid var(--border);border-radius:99px;background:#ffffff0a;color:var(--text-2);font-size:12px;font-weight:700}.onboarding-visual{position:relative;min-height:156px;display:grid;place-items:center;margin-bottom:14px;border-radius:var(--r-xl);overflow:hidden;background:linear-gradient(145deg,#3b82f62e,#22d3a514)}.onboarding-phone{width:118px;min-height:142px;padding:13px 10px;border:1px solid var(--border-2);border-radius:24px;background:#0b0f1ab8;box-shadow:0 18px 44px #00000057,inset 0 1px #ffffff14;transform:rotate(-5deg)}.onboarding-phone-top{width:38px;height:4px;margin:0 auto 16px;border-radius:99px;background:var(--surface-3)}.onboarding-phone-balance{height:42px;margin-bottom:12px;border-radius:var(--r-lg);background:linear-gradient(145deg,var(--primary),#1d4ed8);box-shadow:0 10px 26px var(--primary-glow)}.onboarding-phone-list{display:grid;gap:7px}.onboarding-phone-list span{height:20px;border-radius:var(--r-md);background:var(--surface-2)}.onboarding-icon{position:absolute;right:48px;bottom:24px;width:56px;height:56px;display:grid;place-items:center;border-radius:24px;background:var(--surface);border:1px solid var(--border-2);color:var(--primary);box-shadow:var(--shadow-md)}.onboarding-copy{display:grid;gap:6px;text-align:center}.onboarding-kicker{color:var(--income);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.onboarding-copy h1{margin:0;color:var(--text);font-family:var(--display);font-size:24px;font-weight:800;line-height:1.18}.onboarding-copy p{margin:0 auto;max-width:310px;color:var(--text-2);font-size:13px;font-weight:500;line-height:1.55}.onboarding-steps{display:grid;gap:6px;margin:10px 0 0;text-align:left}.onboarding-steps span{display:grid;grid-template-columns:20px 1fr;align-items:start;gap:8px;min-height:30px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:#ffffff09;color:var(--text);font-size:12px;font-weight:600;line-height:1.35}.onboarding-steps svg{margin-top:1px;color:var(--income)}.onboarding-tip{margin-top:8px;padding:9px 10px;border-radius:var(--r-md);background:var(--primary-dim);color:#bfdbfe;font-size:12px;font-weight:600;line-height:1.5;text-align:left}.onboarding-dots{display:flex;justify-content:center;gap:7px;padding:14px 0 12px}.onboarding-dots button{width:8px;height:8px;border:0;border-radius:99px;background:var(--surface-3);padding:0;transition:width .18s ease,background .18s ease}.onboarding-dots button.active{width:24px;background:var(--primary)}.onboarding-actions{display:grid;grid-template-columns:.9fr 1.1fr;gap:10px}.action-sheet{display:grid;gap:10px;padding:18px 20px 22px}.action-sheet-item{display:grid;grid-template-columns:48px 1fr;align-items:center;gap:12px;width:100%;min-height:68px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2);color:var(--text);text-align:left;transition:transform .16s ease,background .16s ease,border-color .16s ease}.action-sheet-item:active{transform:scale(.98);background:var(--surface-3)}.action-sheet-item strong{display:block;margin-bottom:3px;font-size:15px;font-weight:700}.action-sheet-item small{display:block;color:var(--text-3);font-size:12px;font-weight:500;line-height:1.35}.fab-menu{position:fixed;left:50%;bottom:96px;transform:translate(-50%);width:max-content;pointer-events:auto}.fab-menu-inner{display:flex;gap:8px;padding:12px;border-radius:var(--r-xl);background:var(--glass);border:1px solid var(--border-2);box-shadow:var(--shadow-lg);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);animation:slide-up .18s ease-out both}.fab-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 16px;border:0;background:transparent;border-radius:var(--r-lg);min-width:88px;transition:background .15s ease,transform .15s ease}.fab-item:active{transform:scale(.93);background:var(--surface-2)}.fab-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:var(--r-md)}.fab-icon.is-red{background:var(--expense-dim);color:var(--expense)}.fab-icon.is-green{background:var(--income-dim);color:var(--income)}.fab-icon.is-amber{background:var(--amber-dim);color:var(--amber)}.fab-label{font-size:12px;font-weight:700;color:var(--text);text-align:center;letter-spacing:.01em}.sheet{width:min(680px,100%);max-height:min(90dvh,840px);margin:0 auto;overflow:auto;border-radius:var(--r-2xl) var(--r-2xl) 0 0;background:var(--surface);border:1px solid var(--border-2);border-bottom:0;box-shadow:0 -8px 48px #00000080;animation:slide-up .24s ease-out both}.sheet>header{position:sticky;top:0;z-index:1;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:8px;padding:18px 16px;border-bottom:1px solid var(--border);background:#151c2cf0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);text-align:center}.sheet>header strong{font-family:var(--display);font-size:16px;font-weight:700;color:var(--text)}.sheet>header .icon-button{width:36px;height:36px;display:grid;place-items:center;border:0;border-radius:50%;background:var(--surface-2);color:var(--text-2);transition:background .15s ease,color .15s ease}.sheet>header .icon-button:hover{background:var(--surface-3);color:var(--text)}.progress{display:grid;grid-auto-flow:column;gap:6px;padding:18px 20px 0}.progress span{height:3px;border-radius:99px;background:var(--surface-3)}.progress span.active{background:var(--primary);box-shadow:0 0 8px var(--primary-glow)}.flow-step{padding:24px 20px 28px}.flow-step h2{margin:0 0 20px;font-family:var(--display);font-size:26px;font-weight:800;line-height:1.15;color:var(--text)}.flow-step>input{width:100%;height:56px;margin-bottom:12px;border:0;border-bottom:2px solid var(--border-2);background:transparent;outline:0;font-family:var(--body);font-size:22px;font-weight:600;color:var(--text);caret-color:var(--primary)}.flow-step>input::placeholder{color:var(--text-3);font-weight:400}.flow-step>input:focus{border-bottom-color:var(--primary)}.money-input{display:flex;align-items:end;gap:8px;margin-bottom:14px;border-bottom:2px solid var(--primary)}.money-input input{min-width:0;width:100%;border:0;background:transparent;outline:0;font-family:var(--mono);font-size:clamp(36px,11vw,56px);font-weight:600;letter-spacing:-.01em;color:var(--text);caret-color:var(--primary);line-height:1.2}.money-input span{margin-bottom:12px;color:var(--text-3);font-weight:600;white-space:nowrap;font-size:20px}.suggestion-cloud{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;min-height:44px;margin:12px 0 22px;-webkit-overflow-scrolling:touch;padding-bottom:2px}.suggestion-cloud button{flex:0 0 auto;min-height:40px;display:inline-flex;align-items:center;border:1px solid var(--border-2);border-radius:99px;background:var(--surface-2);color:var(--text-2);padding:0 18px;font-size:14px;font-weight:700;transition:border-color .15s ease,background .15s ease,color .15s ease,transform .15s ease}.suggestion-cloud button:active{transform:scale(.95);background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.flow-actions{display:grid;grid-template-columns:.85fr 1.15fr;gap:10px}.primary-button{width:100%;min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:var(--r-md);background:var(--primary);color:#fff;padding:0 16px;font-weight:700;font-size:15px;letter-spacing:.01em;transition:background .15s ease,transform .15s ease,box-shadow .15s ease,opacity .15s ease;box-shadow:0 4px 18px var(--primary-glow)}.primary-button:hover{background:#2563eb}.primary-button:active{transform:scale(.97)}.primary-button:disabled{opacity:.35;box-shadow:none}.secondary-button{width:100%;min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border-2);border-radius:var(--r-md);background:var(--surface-2);color:var(--text-2);padding:0 16px;font-weight:700;font-size:15px;transition:background .15s ease,transform .15s ease,color .15s ease}.secondary-button:active{transform:scale(.97);background:var(--surface-3)}.wallet-picker{display:grid;gap:8px;margin-bottom:18px}.wallet-picker button{min-height:64px;display:grid;grid-template-columns:minmax(0,1fr) auto 24px;align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);padding:0 16px;text-align:left;color:var(--text);transition:border-color .16s ease,background .16s ease,transform .16s ease}.wallet-picker button:active{transform:scale(.98)}.wallet-picker button.selected{border-color:var(--primary);background:var(--primary-dim);color:#a5c4ff}.wallet-picker strong{font-family:var(--mono);font-size:15px;color:var(--income)}.confirm-box{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;padding:16px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border)}.confirm-box-copy{display:flex;flex-direction:column;gap:4px;min-width:0}.confirm-box span{font-weight:600;font-size:14px;color:var(--text-2)}.confirm-box strong{font-family:var(--mono);font-size:20px;font-weight:600}.confirm-box strong.income-text{color:var(--income)}.confirm-box strong.expense-text{color:var(--expense)}.tx-sheet{padding:18px 20px 22px}.tx-sheet-summary{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:18px;border-radius:var(--r-lg);background:var(--surface-2);border:1px solid var(--border)}.tx-sheet-summary span{color:var(--text-3);font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.tx-sheet-summary strong{font-size:17px;font-weight:700;color:var(--text)}.tx-sheet-summary b{font-family:var(--mono);font-size:20px;font-weight:600}.tx-sheet-summary b.expense{color:var(--expense)}.tx-sheet-summary b.income{color:var(--income)}.sheet-actions{display:grid;gap:10px}.sheet-action{min-height:54px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);color:var(--text);font-weight:700;font-size:15px;transition:transform .16s ease,background .16s ease,border-color .16s ease}.sheet-action:active{transform:scale(.98)}.sheet-action.amber{border-color:#f59e0b40;background:var(--amber-dim);color:var(--amber)}.sheet-action.danger{border-color:#f4476b33;background:var(--expense-dim);color:var(--expense)}.delete-sheet{padding:18px 20px 22px}.delete-warning{margin:0 0 14px;font-size:14px;line-height:1.6;color:var(--text-2);font-weight:500}.delete-list{margin:0 0 20px;padding:0 0 0 16px;color:var(--text-3);display:grid;gap:8px;font-size:13px;line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);color:var(--text-3);text-align:center}.empty-state strong{color:var(--text-2);font-size:15px}.empty-state p{margin:0;font-size:13px}@media(hover:hover)and (pointer:fine){.wallet-chip:hover,.stat-card:hover,.wallet-row:hover,.settings-card:hover{transform:translateY(-2px);border-color:var(--border-2)}.rank-row.is-clickable:hover{background:var(--surface-2)}.primary-button:hover{box-shadow:0 6px 24px var(--primary-glow)}.fab-item:hover{background:var(--surface-2)}.suggestion-cloud button:hover{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}}@media(max-width:560px){.screen{padding:20px 14px 120px}.bottom-nav{--fab-size: 56px;padding:6px 10px max(8px,env(safe-area-inset-bottom))}.nav-button{height:54px}.nav-icon{width:40px;height:40px}.bottom-nav-group:first-child{padding-right:30px}.bottom-nav-group:last-child{padding-left:30px}.nav-button-add{top:-22px;width:68px;height:68px}.flow-step h2{font-size:22px}.dash-balance{font-size:clamp(26px,9vw,44px)}}@media(min-width:760px){.screen{padding-top:40px}.wallet-list,.row-list{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.primary-button:focus-visible,.secondary-button:focus-visible,.wallet-add-button:focus-visible,.sheet-action:focus-visible,.nav-button:focus-visible,.w-btn:focus-visible,.rank-row.is-clickable:focus-visible,.wallet-row:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
