@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;600;700&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap";:root{--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--primary: #059669;--primary-strong: #047857;--primary-soft: #d1fae5;--expense: #e11d48;--expense-soft: #ffe4e6;--income: #059669;--income-soft: #dcfce7;--amber: #f59e0b;--shadow: 0 24px 60px rgba(15, 23, 42, .1);--radius: 8px;--radius-lg: 12px;--title: "Plus Jakarta Sans", "Inter", sans-serif;--body: "Inter", system-ui, sans-serif;--number: "JetBrains Mono", ui-monospace, monospace}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pop-in{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes soft-scale{0%{opacity:0;transform:scale(.985)}to{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}body{margin:0;min-width:320px;background:var(--bg);color:var(--text);font-family:var(--body)}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app-shell{min-height:100svh;display:grid;grid-template-rows:1fr auto}.app-main{min-height:100%;overflow:auto}.screen{width:min(1180px,100%);min-height:100%;margin:0 auto;padding:28px 18px 116px;animation:fade-up .26s ease-out both}.swipe-screen,.stats-screen{touch-action:pan-y}.dash-card{padding:22px 20px 18px;margin-bottom:12px;border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:0 1px 4px #0000000a;animation:pop-in .32s ease-out both}.dash-card-top{display:flex;align-items:center;justify-content:space-between}.dash-label{font-size:13px;font-weight:600;color:var(--muted)}.dash-balance{display:block;margin:6px 0 14px;font-family:var(--number);font-size:clamp(28px,7vw,46px);font-weight:800;letter-spacing:-1px;color:var(--income)}.dash-metrics{display:flex;gap:20px}.dash-metric{display:flex;flex-direction:column;gap:2px}.metric-label{font-size:11px;font-weight:600;color:var(--muted)}.metric-value{font-family:var(--number);font-size:15px;font-weight:700}.metric-value.is-up{color:var(--income)}.metric-value.is-down{color:var(--expense)}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:18px}.stat-card{display:flex;flex-direction:column;gap:4px;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--surface);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.stat-icon{display:none}.stat-card p{font-size:12px;font-weight:500;color:var(--muted);margin:0}.stat-card strong{font-family:var(--number);font-size:17px;font-weight:700;line-height:1.2}.stat-card.income strong{color:var(--income)}.stat-card.expense strong{color:var(--expense)}.section-heading{margin:20px 0 10px;font-size:15px;font-weight:700;color:var(--text)}.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:20px 0 10px}.section-title h2{margin:0;font-size:16px;font-weight:700}.section-title span{color:var(--muted);font-size:12px;font-weight:600}.dash-wallets{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(170px,1fr);gap:10px;overflow-x:auto;padding-bottom:4px;margin-bottom:4px}.wallet-chip{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;gap:4px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.wallet-chip span{font-size:12px;color:var(--muted);font-weight:500}.wallet-chip strong{font-family:var(--number);font-size:17px;font-weight:700;color:var(--income)}.empty-state{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface)}.row-list{display:grid;border:1px solid var(--border);border-radius:12px;background:var(--surface);overflow:hidden}.dash-tx{border:1px solid var(--border);border-radius:12px;background:var(--surface);overflow:hidden}.rank-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--border);transition:transform .18s ease,background .18s ease,box-shadow .18s ease,border-color .18s ease}.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}.rank-row.is-clickable:active{background:var(--surface-2)}.rank-row:last-child{border-bottom:0}.tx-info{display:flex;flex-direction:column;gap:2px;min-width:0}.tx-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-meta{font-size:11px;color:var(--muted)}.tx-money{font-family:var(--number);font-size:14px;font-weight:700;white-space:nowrap;text-align:right}.tx-money.expense{color:var(--expense)}.tx-money.income{color:var(--income)}.dash-empty{padding:24px;text-align:center;color:var(--muted);font-size:13px}.dash-add{display:inline-flex;align-items:center;gap:4px;border:0;background:var(--primary);color:#fff;font-size:12px;font-weight:700;padding:6px 14px;border-radius:8px}.wallet-list{display:grid;gap:10px}.wallet-add-button{width:100%;min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px;border:1px dashed color-mix(in srgb,var(--primary) 28%,var(--border));border-radius:14px;background:color-mix(in srgb,var(--primary-soft) 55%,white);color:var(--primary-strong);font-weight:800;font-size:14px}.wallet-add-button:active{transform:scale(.98)}.wallet-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:var(--surface);border:1px solid var(--border);transition:transform .18s ease,background .18s ease,box-shadow .18s ease,border-color .18s ease}.wallet-row-info{display:flex;flex-direction:column;gap:3px}.wallet-name{font-size:15px;font-weight:700}.wallet-row-actions{display:flex;gap:8px}.w-btn{width:38px;height:38px;display:grid;place-items:center;border:0;border-radius:10px;transition:transform .15s ease}.w-btn:active{transform:scale(.9)}.w-btn.up{background:#e0f2fe;color:#0284c7}.w-btn:disabled{opacity:.3}.wallet-balance{font-family:var(--number);font-size:16px;font-weight:700;color:var(--income)}.snap-row{padding:12px 16px;border-bottom:1px solid var(--border);transition:transform .18s ease,background .18s ease,box-shadow .18s ease,border-color .18s ease}.snap-row.is-clickable{width:100%;border-left:0;border-right:0;border-top:0;background:transparent;color:inherit;font:inherit;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.snap-row.is-clickable:active{background:var(--surface-2)}.snap-row:last-child{border-bottom:0}.snap-name{display:block;font-size:13px;font-weight:600;margin-bottom:4px}.snap-bottom{display:flex;align-items:center;justify-content:space-between}.snap-range{font-family:var(--number);font-size:12px;color:var(--muted)}.snap-diff{font-family:var(--number);font-size:13px;font-weight:700;white-space:nowrap}.snap-diff.is-up{color:var(--income)}.snap-diff.is-down{color:var(--expense)}.segmented{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:6px;margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface)}.segmented button{min-height:38px;border:0;border-radius:var(--radius);background:transparent;color:var(--muted);font-size:13px;font-weight:800}.segmented button.active{background:var(--primary);color:#fff}.search-box{display:flex;align-items:center;gap:10px;min-height:48px;margin-bottom:12px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--muted)}.search-box input{width:100%;border:0;outline:0;background:transparent}.settings{display:flex;flex-direction:column;gap:18px}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.settings-card{min-height:124px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:18px;padding:16px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fffffff5,#f8fafceb);box-shadow:0 8px 24px #0f172a0f;color:var(--text);text-align:left;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;animation:fade-up .32s ease-out both}.settings-card:active{transform:translateY(1px) scale(.99)}.settings-card-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:var(--surface-2);color:inherit}.settings-card-body{display:flex;flex-direction:column;gap:4px}.settings-card-body strong{font-size:15px;font-weight:800;line-height:1.2}.settings-card-body span{font-size:12px;font-weight:400;color:var(--muted)}.settings-card.export{color:#0a84ff;border-color:color-mix(in srgb,#0a84ff 22%,var(--border))}.settings-card.import{color:var(--income);border-color:color-mix(in srgb,var(--income) 22%,var(--border))}.settings-card.warn{color:#ff9f0a;border-color:color-mix(in srgb,#ff9f0a 22%,var(--border))}.settings-card.danger{color:#ff3b30;border-color:color-mix(in srgb,#ff3b30 22%,var(--border))}.settings-card.export:active{background:color-mix(in srgb,#0a84ff 8%,var(--surface))}.settings-card.import:active{background:color-mix(in srgb,var(--income) 8%,var(--surface))}.settings-card.warn:active{background:color-mix(in srgb,#ff9f0a 8%,var(--surface))}.settings-card.danger:active{background:color-mix(in srgb,#ff3b30 8%,var(--surface))}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:0;padding:8px 12px max(8px,env(safe-area-inset-bottom));border-top:1px solid var(--border);background:#fffffff5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 -8px 30px #0f172a0a}.bottom-nav-group{flex:1 1 0;display:flex;align-items:stretch;justify-content:space-around;min-width:0}.bottom-nav-group:first-child{padding-right:28px}.bottom-nav-group:last-child{padding-left:28px}.nav-button{position:relative;flex:1 1 0;min-width:0;height:56px;display:grid;place-items:center;gap:4px;padding:0;border:0;border-radius:0;background:transparent;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:-.01em;transition:transform .18s ease,color .18s ease,background .18s ease,box-shadow .18s ease;text-align:center}.nav-icon{display:grid;place-items:center;width:30px;height:30px;border-radius:10px;flex:0 0 auto;transition:background .2s ease,color .2s ease}.nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;text-align:center}.nav-button.is-active{color:var(--primary-strong)}.nav-button.is-active .nav-icon{background:var(--primary-soft);color:var(--primary-strong);box-shadow:0 6px 16px #05966926}.nav-button-add{position:absolute;left:50%;top:0;transform:translate(-50%,-35%);z-index:2;flex:0 0 auto;width:64px;height:64px;border-radius:999px;color:#fff;background:transparent;box-shadow:none}.nav-button-add .nav-icon{width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg,#047857,#065f46);color:#fff;box-shadow:0 14px 28px #04785757,0 3px #ffffff2e inset}.nav-button:active{transform:translateY(1px) scale(.98)}.nav-button-add:active{transform:translate(-50%,-35%) scale(.98)}@media(max-width:560px){.screen{padding:20px 14px 116px}.bottom-nav{padding:6px 10px max(6px,env(safe-area-inset-bottom))}.nav-button{height:52px;padding:0;gap:2px}.nav-icon{width:28px;height:28px}.nav-button-add .nav-icon{width:56px;height:56px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;align-items:end;background:#0f172a4d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fade-in .18s ease-out both;will-change:opacity}.modal-backdrop.is-fab{z-index:60}.modal-backdrop.is-sheet{z-index:50}.modal-backdrop.is-fab,.modal-backdrop.is-sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a4d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fade-in .18s ease-out both;will-change:opacity}.fab-menu{position:fixed;left:50%;bottom:90px;transform:translate(-50%);width:max-content;pointer-events:auto}.fab-menu-inner{display:flex;gap:10px;padding:12px 16px;border-radius:18px;background:#fffffff5;box-shadow:0 8px 40px #0f172a2e;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(226,232,240,.8);animation:pop-in .18s ease-out both;will-change:transform,opacity}.fab-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 14px;border:0;background:transparent;border-radius:14px;min-width:90px;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.fab-item:hover{background:var(--surface-2)}.fab-item:active{transform:scale(.95)}.fab-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:12px}.fab-icon.is-red{background:linear-gradient(135deg,#ffe4e6,#fecdd3);color:var(--expense)}.fab-icon.is-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:var(--income)}.fab-icon.is-gray{background:var(--surface-2);color:var(--muted)}.fab-icon.is-amber{background:#fef3c7;color:#d97706}.fab-label{font-size:12px;font-weight:700;color:var(--text);text-align:center}.sheet{width:min(680px,100%);max-height:min(88dvh,820px);margin:0 auto;overflow:auto;border-radius:24px 24px 0 0;background:var(--surface);box-shadow:0 -4px 40px #0f172a1a;animation:pop-in .22s 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:16px;border-bottom:1px solid var(--border);background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:center}.sheet>header strong{font-family:var(--title);font-size:16px}.sheet>header .icon-button{width:36px;height:36px;display:grid;place-items:center;border:0;border-radius:50%;background:transparent;color:var(--muted);transition:background .15s ease,color .15s ease}.sheet>header .icon-button:hover{background:var(--surface-2);color:var(--text)}.progress{display:grid;grid-auto-flow:column;gap:8px;padding:18px 20px 0}.progress span{height:6px;border-radius:99px;background:var(--surface-2)}.progress span.active{background:var(--primary)}.flow-step{padding:22px 20px 26px}.flow-step h2{margin:0 0 18px;font-family:var(--title);font-size:28px;line-height:1.1}.flow-step>input{width:100%;height:58px;margin-bottom:14px;border:0;border-bottom:2px solid var(--border);outline:0;font-family:var(--body);font-size:24px;text-transform:none}.flow-step>input::placeholder{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);white-space:nowrap}.money-input input{min-width:0;width:100%;border:0;outline:0;font-family:var(--number);font-size:clamp(36px,12vw,58px);font-weight:800;line-height:1.2}.money-input span{margin-bottom:12px;color:var(--muted);font-weight:800;white-space:nowrap}.suggestion-cloud{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:6px;min-height:46px;margin:14px 0 24px;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.suggestion-cloud::-webkit-scrollbar{display:none}.suggestion-cloud button{flex:0 0 auto;min-height:42px;display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:99px;background:var(--surface);color:var(--text);padding:0 20px;font-size:15px;font-weight:700;transition:border-color .15s ease,background .15s ease,transform .15s ease}.suggestion-cloud button:active{transform:scale(.96)}.flow-actions{display:grid;grid-template-columns:.8fr 1.2fr;gap:10px}.primary-button{width:100%;min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;background:var(--primary);color:#fff;padding:0 16px;font-weight:800;font-size:15px;transition:background .15s ease,transform .15s ease,box-shadow .15s ease,opacity .15s ease}.primary-button:hover{background:var(--primary-strong)}.primary-button:active{transform:scale(.97)}.primary-button:disabled{opacity:.4}.secondary-button{width:100%;min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);padding:0 16px;font-weight:700;font-size:15px;transition:background .15s ease,transform .15s ease,box-shadow .15s ease,opacity .15s ease}.secondary-button:active{transform:scale(.97)}.tx-sheet{padding:18px 20px 22px}.tx-sheet-summary{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:16px;border-radius:14px;background:var(--surface-2)}.tx-sheet-summary span{color:var(--muted);font-size:12px;font-weight:600}.tx-sheet-summary strong{font-size:16px;font-weight:800;line-height:1.2}.tx-sheet-summary b{font-family:var(--number);font-size:18px;font-weight:800}.tx-sheet-summary b.expense{color:var(--expense)}.tx-sheet-summary b.income{color:var(--income)}.sheet-actions{display:grid;gap:10px}.delete-sheet{padding:18px 20px 22px}.delete-warning{margin:0 0 14px;font-size:14px;line-height:1.5;color:var(--text);font-weight:600}.delete-list{margin:0 0 18px;padding:0 0 0 18px;color:var(--muted);display:grid;gap:8px;font-size:13px;line-height:1.45}.sheet-action{min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text);font-weight:800;font-size:15px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease}.sheet-action.amber{border-color:color-mix(in srgb,#f59e0b 22%,var(--border));background:#fef3c7;color:#d97706}.sheet-action.danger{border-color:color-mix(in srgb,var(--expense) 20%,var(--border));background:var(--expense-soft);color:var(--expense)}.sheet-action:active{transform:scale(.98)}.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,.snap-row.is-clickable:focus-visible,.wallet-row:focus-visible{outline:2px solid color-mix(in srgb,var(--primary) 55%,white);outline-offset:2px}@media(hover:hover)and (pointer:fine){.wallet-chip:hover,.stat-card:hover,.settings-card:hover,.wallet-row:hover,.snap-row.is-clickable:hover,.rank-row.is-clickable:hover,.sheet-action:hover{transform:translateY(-2px);box-shadow:0 14px 30px #0f172a14}.rank-row.is-clickable:hover,.snap-row.is-clickable:hover,.wallet-row:hover{border-color:color-mix(in srgb,var(--primary) 18%,var(--border));background:color-mix(in srgb,var(--surface-2) 72%,white)}.primary-button:hover,.secondary-button:hover,.wallet-add-button:hover,.fab-item:hover,.w-btn:hover{transform:translateY(-1px)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.wallet-picker{display:grid;gap:10px;margin-bottom:16px}.wallet-picker button{min-height:60px;display:grid;grid-template-columns:minmax(0,1fr) auto 24px;align-items:center;gap:10px;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:0 16px;text-align:left;transition:border-color .15s ease,background .15s ease,transform .15s ease}.wallet-picker button:active{transform:scale(.98)}.wallet-picker button.selected{border-color:var(--primary);background:var(--primary-soft)}.wallet-picker button.selected:active{transform:scale(.98)}.wallet-picker strong{font-family:var(--number)}.confirm-box{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;padding:16px;border-radius:12px;background:var(--surface-2)}.confirm-box-copy{display:flex;flex-direction:column;gap:4px;min-width:0}.confirm-box span{font-weight:600;font-size:15px}.confirm-box strong{font-family:var(--number);font-size:18px;font-weight:800}.confirm-box strong.income-text{color:var(--income)}.confirm-box strong.expense-text{color:var(--expense)}@media(min-width:760px){.screen{padding-top:38px}.wallet-list,.row-list{grid-template-columns:repeat(2,minmax(0,1fr))}.row-list.compact,.screen:has(.search-box) .row-list{grid-template-columns:1fr}}
