@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,700;1,9..144,300;1,9..144,400&family=Inter+Tight:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;border-top:.5px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding:8px 0 calc(8px + env(safe-area-inset-bottom,0px));z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f6f2eaeb}html.dark .bottom-nav{background:#161614eb}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--faint);padding:4px 12px;border-radius:var(--r-sm);transition:color var(--duration) var(--ease);cursor:pointer;background:none;border:none;font-family:var(--font);min-width:48px}.nav-item span{font-size:10px;font-weight:500;letter-spacing:.01em}.nav-item.active{color:var(--ink)}.nav-item svg{transition:transform var(--duration) var(--ease)}.nav-item:active svg{transform:scale(.9)}.nav-fab{width:52px;height:52px;background:var(--accent);color:var(--accent-ink);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-top:-20px;box-shadow:var(--shadow-fab);transition:transform var(--duration) var(--ease),background var(--duration) var(--ease);flex-shrink:0}.nav-fab:hover{background:var(--accent-deep)}.nav-fab:active{transform:scale(.93)}@media(min-width:768px){.bottom-nav{display:none}}.space-switcher{position:relative;width:100%}.space-trigger{display:flex;align-items:center;gap:7px;width:100%;padding:8px 10px;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;color:var(--ink);text-align:left;transition:background var(--duration) var(--ease)}.space-trigger:hover{background:var(--border)}.space-icon{color:var(--green-mid);display:flex;align-items:center;flex-shrink:0}.space-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.space-chevron{color:var(--faint);flex-shrink:0;transition:transform var(--duration) var(--ease)}.space-chevron.open{transform:rotate(180deg)}.space-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);overflow:hidden;z-index:200;animation:fadeUp .15s var(--ease) both}.space-option{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:none;border:none;cursor:pointer;font-family:var(--font);font-size:13px;color:var(--ink);text-align:left;transition:background var(--duration) var(--ease)}.space-option:hover{background:var(--raised)}.space-option.active{color:var(--green-mid)}.space-option-icon{color:var(--muted);display:flex;align-items:center;flex-shrink:0}.space-option.active .space-option-icon{color:var(--green-mid)}.space-option-name{flex:1}.space-check{color:var(--green-mid);flex-shrink:0}.space-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 0}@media(min-width:768px){.space-bar{display:none}}.notif-bell-wrap{position:relative}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;color:var(--muted);transition:background var(--duration),color var(--duration);flex-shrink:0}.notif-bell-btn:hover{background:var(--border);color:var(--ink)}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;background:var(--amber);color:#fff;border-radius:8px;font-size:10px;font-weight:700;font-family:var(--font);display:flex;align-items:center;justify-content:center;line-height:1}.notif-drawer{position:fixed;top:60px;left:16px;right:16px;width:auto;max-height:70vh;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-xl);box-shadow:0 8px 32px #00000029;display:flex;flex-direction:column;overflow:hidden;z-index:300}.notif-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:.5px solid var(--border);flex-shrink:0}.notif-drawer-title{font-size:14px;font-weight:600;color:var(--ink)}.notif-mark-read{background:none;border:none;font-size:12px;color:var(--green-mid);cursor:pointer;font-family:var(--font);padding:0}.notif-mark-read:hover{text-decoration:underline}.notif-list{overflow-y:auto;flex:1}.notif-empty{padding:32px 16px;text-align:center;font-size:13px;color:var(--faint)}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:.5px solid var(--border-light, var(--border));transition:background var(--duration)}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--amber-tint)}.notif-item-icon{font-size:16px;flex-shrink:0;margin-top:1px}.notif-item-body{flex:1;min-width:0}.notif-item-text{font-size:13px;color:var(--ink);line-height:1.4;margin:0 0 4px}.notif-item-time{font-size:11px;color:var(--faint)}.notif-item-actions{display:flex;gap:4px;flex-shrink:0;align-items:center;margin-top:1px}.notif-action-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:background var(--duration),color var(--duration);padding:0}.notif-action-btn:hover{background:var(--border);color:var(--ink)}.notif-action-btn:disabled{opacity:.4;cursor:not-allowed}.notif-action-dismiss:hover{background:var(--red-tint);color:var(--red);border-color:var(--red-mid)}@media(min-width:768px){.notif-drawer{top:auto;bottom:80px;left:234px;right:auto;width:320px}}.side-nav{display:none}@media(min-width:768px){.side-nav{display:flex;flex-direction:column;width:220px;min-height:100dvh;height:100%;background:var(--surface);border-right:.5px solid var(--border);padding:24px 14px;position:sticky;top:0;flex-shrink:0}.snav-brand{display:flex;align-items:center;gap:10px;padding:0 8px;margin-bottom:24px}.snav-logo{width:30px;height:30px;background:var(--accent);color:var(--accent-ink);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;letter-spacing:-.02em;flex-shrink:0}.snav-brand-name{font-size:16px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}.side-nav .space-switcher{margin-bottom:12px}.snav-add-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:10px;background:var(--accent);color:var(--accent-ink);border:none;border-radius:var(--r-md);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;margin-bottom:20px;transition:background var(--duration) var(--ease)}.snav-add-btn:hover{background:var(--accent-deep)}.snav-add-btn:active{transform:scale(.97)}.snav-links{display:flex;flex-direction:column;gap:2px;flex:1}.snav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);text-decoration:none;color:var(--muted);font-size:14px;font-weight:500;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.snav-item:hover{background:var(--raised);color:var(--ink)}.snav-item.active{background:var(--accent-tint);color:var(--ink);font-weight:600}.snav-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);border:.5px solid var(--border);margin-top:8px;overflow:hidden}.snav-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}.snav-avatar-initials{background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.snav-user-info{min-width:0;overflow:hidden}.snav-user-name{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snav-user-email{font-size:11px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.snav-bell-row{display:none;padding:8px 16px 4px}@media(min-width:768px){.snav-bell-row{display:flex}}.add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1880;z-index:200;display:flex;align-items:flex-end;animation:fadeIn .2s var(--ease)}.add-sheet{width:100%;max-width:430px;margin:0 auto;background:var(--canvas);border-radius:var(--r-2xl) var(--r-2xl) 0 0;padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0px));max-height:90dvh;overflow-y:auto;animation:slideUp .35s var(--ease)}.sheet-handle{width:36px;height:4px;background:var(--border-mid);border-radius:2px;margin:var(--space-3) auto var(--space-1)}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4) var(--space-3)}.sheet-back{width:34px;height:34px;background:var(--raised);border:none;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);flex-shrink:0}.sheet-title{font-size:16px;font-weight:600;color:var(--ink)}.amount-chip{display:flex;align-items:center;gap:5px;background:var(--raised);border:.5px solid var(--border-mid);border-radius:var(--r-full);padding:5px 10px;cursor:pointer;font-family:var(--font)}.amount-chip-val{font-size:14px;font-weight:600;color:var(--ink)}.amount-chip-edit{font-size:10px;color:var(--green-mid);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.step-amount{padding:0 var(--space-4) var(--space-4)}.numpad-display{text-align:center;padding:var(--space-5) 0 var(--space-4);display:flex;align-items:center;justify-content:center;gap:4px}.numpad-currency{font-size:24px;color:var(--faint);font-weight:400;align-self:flex-start;margin-top:8px}.numpad-input{font-family:var(--font);font-size:52px;font-weight:500;color:var(--ink);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums;background:transparent;border:none;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;box-shadow:none;caret-color:var(--green);min-width:1ch;max-width:220px;padding:0;margin:0}.numpad-input::placeholder{color:var(--border-mid)}.scan-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-md);padding:var(--space-3);font-family:var(--font);font-size:13px;color:var(--muted);cursor:pointer;margin-bottom:var(--space-4);transition:background var(--duration)}.scan-btn:hover{background:var(--border)}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.numpad-key{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);height:52px;font-family:var(--font);font-size:20px;font-weight:400;color:var(--ink);cursor:pointer;transition:all var(--duration) var(--ease);display:flex;align-items:center;justify-content:center}.numpad-key:active{transform:scale(.95);background:var(--raised)}.key-del{background:var(--raised);color:var(--muted);font-size:16px}.key-next{background:var(--green);color:var(--green-light);font-size:16px;font-weight:600;border-color:var(--green)}.key-next:disabled{opacity:.4;cursor:not-allowed}.step-category{padding:0 var(--space-4) var(--space-4);overflow-y:auto}.step-hint{font-size:13px;color:var(--faint);margin-bottom:var(--space-3)}.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.cat-tile{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--font);transition:all var(--duration) var(--ease)}.cat-tile:active{transform:scale(.97)}.cat-tile.selected{border-color:var(--green);background:var(--green-tint)}.cat-tile-icon{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}.cat-tile-name{font-size:12px;font-weight:500;color:var(--ink);text-align:center;line-height:1.3}.step-sub{padding:0 var(--space-4) var(--space-4)}.sub-list{display:flex;flex-direction:column;gap:var(--space-2)}.sub-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);padding:var(--space-3) var(--space-4);font-family:var(--font);cursor:pointer;transition:all var(--duration) var(--ease);text-align:left}.sub-row:active{transform:scale(.98)}.sub-row.selected{border-color:var(--green);background:var(--green-tint)}.sub-name{font-size:14px;font-weight:500;color:var(--ink)}.sub-spent{font-size:12px;color:var(--faint)}.step-confirm{padding:0 var(--space-4) var(--space-4)}.confirm-card{margin-bottom:var(--space-3)}.confirm-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4)}.confirm-divider{height:.5px;background:var(--border-soft);margin:0 var(--space-4)}.confirm-label{font-size:12px;color:var(--faint)}.confirm-value{font-size:14px;font-weight:500;color:var(--ink)}.confirm-val-row{display:flex;align-items:center;gap:var(--space-2)}.inline-edit{font-size:11px;color:var(--green-mid);background:var(--green-tint);border:.5px solid var(--green-light);border-radius:var(--r-full);padding:2px 8px;cursor:pointer;font-family:var(--font);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.date-input{font-family:var(--font);font-size:14px;font-weight:500;color:var(--ink);border:none;background:transparent;outline:none;cursor:pointer}.inline-text-input{font-family:var(--font);font-size:14px;font-weight:500;color:var(--ink);border:none;background:transparent;outline:none;text-align:right;width:160px}.inline-text-input::placeholder{color:var(--placeholder);font-weight:400}.optional-toggle{background:none;border:none;font-family:var(--font);font-size:13px;color:var(--faint);cursor:pointer;padding:var(--space-2) 0;margin-bottom:var(--space-3);display:block}.optional-section{margin-bottom:var(--space-4)}.optional-field{margin-bottom:var(--space-3)}.optional-label{display:block;font-size:12px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-2)}.tags-row{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag-chip{display:flex;align-items:center;gap:5px;font-family:var(--font);font-size:13px;padding:6px 12px;border-radius:var(--r-full);border:.5px solid var(--border-mid);background:var(--surface);color:var(--ink);cursor:pointer;transition:all var(--duration) var(--ease)}.tag-chip.selected{font-weight:500}.tag-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.file-btn-row{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.file-btn-row .btn{flex:1}.file-btn-row--single .btn{flex:1 1 100%}.add-another-btn{flex:0 0 auto;white-space:nowrap}.btn-ghost{background:transparent;border:1.5px solid var(--border-mid);color:var(--muted)}.btn-ghost:hover{border-color:var(--ink);color:var(--ink);background:var(--raised)}.toggle-switch{position:relative;width:44px;height:26px;background:var(--border-mid);border:none;border-radius:var(--r-full);cursor:pointer;transition:background var(--duration) var(--ease);flex-shrink:0;padding:0}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--duration) var(--ease);box-shadow:0 1px 3px #0000002e}.toggle-switch.on{background:var(--green)}.toggle-switch.on:after{transform:translate(18px)}.frequency-select{font-family:var(--font);font-size:14px;font-weight:500;color:var(--ink);border:none;background:transparent;outline:none;cursor:pointer;text-align:right}.filed-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);gap:var(--space-3);min-height:260px}.filed-icon{width:64px;height:64px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--green-light);animation:fadeUp .4s var(--ease)}.filed-label{font-size:13px;color:var(--faint);letter-spacing:.06em;text-transform:uppercase;font-weight:600}.filed-amount{font-size:36px;font-weight:500;color:var(--ink);letter-spacing:-.02em}.filed-cat{font-size:14px;color:var(--muted)}.dup-warning{background:var(--amber-tint);border:.5px solid var(--amber-mid);border-radius:var(--r-md);padding:10px 12px;margin-bottom:10px;animation:fadeIn .2s var(--ease)}.dup-warning-top{display:flex;align-items:center;gap:6px;margin-bottom:6px}.dup-icon{color:var(--amber-mid);flex-shrink:0}.dup-title{flex:1;font-size:12px;font-weight:700;color:var(--amber);letter-spacing:.02em;text-transform:uppercase}.dup-dismiss{background:none;border:none;cursor:pointer;color:var(--amber-mid);opacity:.6;display:flex;padding:2px;border-radius:50%;transition:opacity var(--duration)}.dup-dismiss:hover{opacity:1}.dup-matches{display:flex;flex-direction:column;gap:3px}.dup-match-row{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--amber)}.dup-match-amount{font-weight:600}.dup-match-sep{color:var(--amber-mid);opacity:.5}.dup-match-note{opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.period-selector{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;-ms-overflow-style:none;scrollbar-width:none}.period-selector::-webkit-scrollbar{display:none}.period-pill{font-family:var(--font);font-size:12px;font-weight:500;padding:6px 13px;border-radius:var(--r-full);border:.5px solid var(--border-mid);background:var(--surface);color:var(--muted);cursor:pointer;white-space:nowrap;transition:all var(--duration) var(--ease)}.period-pill.active{background:var(--green);color:var(--green-light);border-color:var(--green);font-weight:600}.period-pill:hover:not(.active){background:var(--raised)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5) var(--space-3);padding-top:calc(var(--space-5) + env(safe-area-inset-top,0px))}.dashboard-greeting{font-size:13px;color:var(--faint);margin-bottom:2px}.dashboard-name{font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.dashboard-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.dashboard-avatar-img{object-fit:cover;background:var(--raised)}.editorial-total{margin:var(--space-3) 0 var(--space-4)}.editorial-rule{height:.5px;background:var(--border-mid);border:none}.editorial-inner{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-3) 0;gap:var(--space-3)}.editorial-label{font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.04em;text-transform:uppercase;flex-shrink:0}.editorial-right{display:flex;align-items:baseline;gap:var(--space-3)}.editorial-amount{font-family:var(--font-serif);font-size:42px;font-weight:300;color:var(--ink);letter-spacing:-.03em;line-height:1}.editorial-meta{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.hero-delta{font-size:13px;font-weight:600}.hero-delta.delta-up{color:var(--red-mid)}.hero-delta.delta-down{color:var(--green-positive)}.income-pct{font-size:11px;color:var(--faint)}.chart-card,.chart-toggle-row{margin-bottom:var(--space-4)}.chart-toggle{display:flex;border:.5px solid var(--border-mid);border-radius:var(--r-full);overflow:hidden;width:fit-content}.chart-toggle-btn{font-family:var(--font);font-size:12px;font-weight:500;padding:5px 16px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all var(--duration) var(--ease)}.chart-toggle-btn.active{background:var(--ink);color:var(--accent);font-weight:600}.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.month-nav-label{font-size:13px;font-weight:500;color:var(--charcoal);letter-spacing:-.01em}.month-nav-btn{width:28px;height:28px;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-sm);font-size:16px;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration) var(--ease);line-height:1}.month-nav-btn:hover:not(:disabled){background:var(--border)}.month-nav-btn:disabled{color:var(--placeholder);cursor:default}.chart-tooltip{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-md);padding:8px 12px;box-shadow:var(--shadow-md)}.tooltip-label{font-size:11px;color:var(--faint);margin-bottom:2px}.tooltip-value{font-size:14px;font-weight:600;color:var(--ink)}.cat-donut-wrap{display:flex;gap:var(--space-4);align-items:center}.cat-legend{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.legend-row{display:flex;align-items:center;gap:8px}.legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.legend-name{font-size:12px;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-val{font-size:12px;color:var(--muted);flex-shrink:0}.cat-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.cat-row{padding:var(--space-3) var(--space-4);transition:transform var(--duration) var(--ease),opacity .25s var(--ease),border-left-color .25s var(--ease)}.cat-row.interactive{cursor:pointer}.cat-row.interactive:hover{background:var(--raised)}.cat-row.interactive:active{transform:scale(.98)}.cat-row.selected{padding-left:calc(var(--space-4) - 2px)}.cat-row.dimmed{opacity:.35}.cat-row-top{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.cat-sparkline{flex-shrink:0;opacity:.6}.cat-icon-wrap{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-row-info{flex:1;min-width:0}.cat-row-name{font-size:14px;font-weight:500;color:var(--ink)}.cat-row-count{font-size:12px;color:var(--faint)}.cat-row-amount{font-size:15px;font-weight:500}.cat-progress-track{height:3px;background:var(--raised);border-radius:2px;overflow:hidden}.cat-progress-fill{height:3px;border-radius:2px;transition:width .5s var(--ease)}.empty-cats{margin-bottom:var(--space-6)}.empty-cats-toggle{width:100%;background:transparent;border:.5px dashed var(--border-mid);border-radius:var(--r-md);padding:var(--space-3);font-family:var(--font);font-size:13px;color:var(--faint);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--space-2);transition:background var(--duration)}.empty-cats-toggle:hover{background:var(--raised)}.empty-cats-list{margin-top:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.empty-cat-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-sm)}.empty-cat-name{font-size:13px;color:var(--muted);flex:1}.empty-cat-zero{font-size:13px;color:var(--faint)}.due-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-2)}.due-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.due-row-info{flex:1;min-width:0}.due-row-name{font-size:14px;font-weight:500;color:var(--ink)}.due-row-sub{font-size:12px;color:var(--muted);margin-top:1px}.due-row-date{font-size:12px;color:var(--faint)}.due-row-date.overdue{color:var(--red, #EF4444);font-weight:500}.due-row-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.due-row-amount{font-size:14px;font-weight:500;color:var(--ink)}.due-log-btn{font-family:var(--font);font-size:12px;font-weight:600;color:var(--accent-ink);background:var(--accent);border:none;border-radius:var(--r-full);padding:4px 12px;cursor:pointer;transition:background var(--duration) var(--ease);white-space:nowrap}.due-log-btn:hover{background:var(--accent-deep)}.due-log-btn:disabled{opacity:.5;cursor:not-allowed}.due-row-error{font-size:11px;color:var(--red, #EF4444);margin-top:2px}.search-wrap{position:relative;margin-bottom:var(--space-3)}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--faint);pointer-events:none}.search-input{width:100%;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);padding:10px 36px 10px 38px;font-family:var(--font);font-size:14px;color:var(--ink);outline:none;transition:border-color var(--duration)}.search-box.focused .search-input,.search-input:focus{border-color:var(--green)}.search-input::placeholder{color:var(--placeholder)}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--faint);display:flex;padding:3px;border-radius:50%;transition:color var(--duration),background var(--duration)}.search-clear:hover{color:var(--muted);background:var(--raised)}.active-filters{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;margin-bottom:var(--space-3)}.filter-chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;border:.5px solid var(--border-mid);border-radius:var(--r-full);padding:3px 6px 3px 9px;color:var(--muted);background:var(--raised);white-space:nowrap}.filter-chip-remove{background:none;border:none;cursor:pointer;color:inherit;opacity:.55;display:flex;padding:1px;line-height:1;border-radius:50%;transition:opacity var(--duration)}.filter-chip-remove:hover{opacity:1}.suggest-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);box-shadow:var(--shadow-md);z-index:50;overflow:hidden;max-height:340px;overflow-y:auto}.suggest-section{padding:6px 0}.suggest-section+.suggest-section{border-top:.5px solid var(--border-soft)}.suggest-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);padding:6px 14px 4px}.suggest-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:8px 14px;font-family:var(--font);font-size:14px;color:var(--ink);cursor:pointer;text-align:left;transition:background var(--duration)}.suggest-item:hover{background:var(--raised)}.suggest-icon{width:26px;height:26px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.suggest-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.suggest-date-row{display:flex;flex-wrap:wrap;gap:6px;padding:4px 14px 10px}.suggest-date-chip{background:var(--raised);border:.5px solid var(--border-mid);border-radius:var(--r-full);padding:5px 12px;font-family:var(--font);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:background var(--duration),color var(--duration),border-color var(--duration)}.suggest-date-chip:hover{background:var(--green-tint);color:var(--green);border-color:var(--green)}.history-group{margin-bottom:var(--space-4)}.history-date-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-2)}.history-date{font-size:12px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}.history-date-total{font-size:13px;font-weight:500;color:var(--muted)}.expense-row{border-bottom:.5px solid var(--border-soft);cursor:pointer;transition:background var(--duration)}.expense-row:hover{background:var(--raised)}.expense-row:active{background:var(--border-soft)}.expense-row.last{border-bottom:none}.expense-row-main{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.expense-icon{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.expense-info{flex:1;min-width:0}.expense-sub{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-meta{font-size:12px;color:var(--faint);display:flex;gap:4px;margin-top:1px}.expense-note{color:var(--placeholder)}.expense-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.expense-tag{font-size:11px;font-weight:500;border:.5px solid;border-radius:var(--r-full);padding:1px 7px}.expense-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.expense-amount{font-size:15px;font-weight:500;color:var(--ink)}.expense-delete-btn{background:none;border:none;cursor:pointer;color:var(--placeholder);padding:2px;display:flex;transition:color var(--duration)}.expense-delete-btn:hover{color:var(--red)}.delete-confirm{display:flex;gap:4px}.delete-yes{font-family:var(--font);font-size:11px;background:var(--red-tint);color:var(--red);border:.5px solid var(--red-mid);border-radius:6px;padding:3px 8px;cursor:pointer;font-weight:600}.delete-no{font-family:var(--font);font-size:11px;background:var(--raised);color:var(--muted);border:.5px solid var(--border);border-radius:6px;padding:3px 8px;cursor:pointer}.export-menu-wrap{position:relative}.export-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-lg);box-shadow:0 4px 16px #0000001f;z-index:50;overflow:hidden;min-width:140px}.export-menu-item{display:block;width:100%;padding:10px 16px;background:none;border:none;font-family:var(--font);font-size:13px;color:var(--ink);text-align:left;cursor:pointer;transition:background var(--duration)}.export-menu-item:hover{background:var(--raised)}.export-menu-item+.export-menu-item{border-top:.5px solid var(--border-soft)}.export-error{margin:0 var(--space-4) var(--space-3);padding:10px 14px;background:var(--red-soft, #fdecea);color:var(--red-mid, #c0392b);border-radius:var(--r-md);font-size:12px;cursor:pointer}.reports-summary{background:var(--green);border-radius:var(--r-xl);padding:var(--space-4) var(--space-5);display:flex;justify-content:space-between;align-items:center;margin:var(--space-3) 0 var(--space-4)}.summary-total{font-family:var(--font-serif);font-size:36px;font-weight:300;color:var(--green-light);letter-spacing:-.03em;line-height:1;margin-top:4px}.summary-delta-wrap{text-align:right}.summary-delta{font-size:18px;font-weight:700}.summary-delta.delta-up{color:var(--red-mid)}.summary-delta.delta-down{color:var(--green-positive)}.summary-vs{font-size:11px;color:var(--green-light);opacity:.65;margin-top:3px}.report-types{display:flex;gap:6px;margin-bottom:var(--space-4);overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.report-types::-webkit-scrollbar{display:none}.report-type-pill{font-family:var(--font);font-size:12px;font-weight:500;padding:6px 13px;border-radius:var(--r-full);border:.5px solid var(--border-mid);background:var(--surface);color:var(--muted);cursor:pointer;white-space:nowrap;transition:all var(--duration) var(--ease)}.report-type-pill.active{background:var(--ink);color:var(--canvas);border-color:var(--ink)}.view-toggle{display:flex;border:.5px solid var(--border-mid);border-radius:var(--r-full);overflow:hidden;width:fit-content;margin-bottom:var(--space-3)}.vt-btn{font-family:var(--font);font-size:12px;font-weight:500;padding:6px 18px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all var(--duration)}.vt-btn.active{background:var(--green);color:var(--green-light);font-weight:600}.report-bar-row{margin-bottom:var(--space-4)}.report-bar-row:last-child{margin-bottom:0}.report-bar-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1)}.report-bar-name-wrap{display:flex;align-items:center;gap:var(--space-2);min-width:0}.report-bar-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-tag-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.report-bar-name{font-size:13px;color:var(--ink)}.report-bar-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.report-change{font-size:12px;font-weight:600}.report-amount{font-size:14px;font-weight:500;color:var(--ink)}.report-track{background:var(--raised);border-radius:4px;height:8px}.report-fill{height:8px;border-radius:4px;transition:width .5s var(--ease)}.table-head{display:flex;align-items:center;padding:8px 16px;background:var(--raised);border-bottom:.5px solid var(--border);font-size:10px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}.table-row{display:flex;align-items:center;padding:11px 16px;border-bottom:.5px solid var(--border-soft);gap:var(--space-3)}.table-row:last-child{border-bottom:none}.table-row-name{flex:1;display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--ink);min-width:0;overflow:hidden}.table-amount{width:70px;text-align:right;font-size:13px;font-weight:500;color:var(--ink)}.table-change{width:60px;text-align:right;font-size:12px;font-weight:600}.drill-breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:var(--space-3);font-size:12px}.drill-back{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--green-positive);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;padding:0}.drill-back:hover{opacity:.75}.drill-sep{color:var(--faint)}.drill-current{display:flex;align-items:center;gap:4px;color:var(--ink);font-weight:500}.drill-current-icon{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-bar-row--drillable{cursor:pointer;border-radius:var(--r-md);padding:6px 4px;margin:0 -4px var(--space-4);transition:background var(--duration)}.report-bar-row--drillable:last-child{margin-bottom:0}.report-bar-row--drillable:hover{background:var(--raised)}.table-row--drillable{cursor:pointer}.table-row--drillable:hover{background:var(--raised)}.drill-chevron{color:var(--faint);flex-shrink:0;margin-left:auto}.proj-note{font-size:11px;color:var(--faint);margin-bottom:var(--space-4)}.proj-row{margin-bottom:var(--space-4)}.proj-row:last-child{margin-bottom:0}.proj-amounts{display:flex;align-items:center;gap:5px;flex-shrink:0}.proj-current{font-size:13px;font-weight:500;color:var(--muted)}.proj-arrow{font-size:11px;color:var(--faint)}.proj-projected{font-size:14px;font-weight:600;color:var(--ink)}.proj-track{position:relative;height:8px;width:var(--track-w);border-radius:4px;overflow:hidden;margin-top:var(--space-1)}.proj-fill-projected{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px}.proj-fill-current{position:absolute;top:0;left:0;height:100%;border-radius:4px;transition:width .5s var(--ease)}.profile-card{display:flex;align-items:center;gap:var(--space-3);background:var(--green);border:none;border-radius:var(--r-xl);padding:var(--space-4);width:100%;cursor:pointer;margin-bottom:var(--space-5);font-family:var(--font);text-align:left;transition:opacity var(--duration)}.profile-card:active{opacity:.9}.profile-avatar{width:52px;height:52px;border-radius:50%;background:var(--green-mid);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--green-light);flex-shrink:0}.profile-avatar-large{width:76px;height:76px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--green-light);margin:0 auto var(--space-6)}.profile-info{flex:1}.profile-name{font-size:16px;font-weight:600;color:var(--green-light)}.profile-role{font-size:12px;color:var(--green-light);opacity:.7;margin-top:2px}.settings-section{margin-bottom:var(--space-5)}.settings-group{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;border:.5px solid var(--border)}.setting-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.setting-row:last-child{border-bottom:none}.setting-row.clickable{cursor:pointer;transition:background var(--duration)}.setting-row.clickable:active{background:var(--raised)}.setting-icon{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.setting-label-wrap{flex:1;min-width:0}.setting-name{font-size:14px;color:var(--ink)}.setting-sub{font-size:12px;color:var(--faint);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setting-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.setting-value{font-size:13px;color:var(--faint)}.setting-input{font-family:var(--font);font-size:14px;color:var(--ink);border:none;background:transparent;outline:none;text-align:right;max-width:160px}.setting-input::placeholder{color:var(--placeholder)}.scan-bar-wrap{padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.scan-bar-meta{display:flex;justify-content:space-between;margin-bottom:6px}.scan-bar-label{font-size:13px;color:var(--ink)}.scan-bar-count{font-size:13px;font-weight:600;color:var(--green)}.scan-track{background:var(--raised);border-radius:var(--r-full);height:6px}.scan-fill{border-radius:var(--r-full);background:var(--green);transition:width .5s var(--ease)}.tier-card{border-radius:var(--r-lg);padding:var(--space-4);margin-bottom:var(--space-2);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:all var(--duration)}.tier-card.active{border-color:var(--green);background:var(--green-tint)}.tier-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1)}.tier-name{font-size:15px;font-weight:700;color:var(--ink)}.tier-price{font-size:15px;font-weight:700;color:var(--green)}.tier-desc{font-size:12px;color:var(--muted);line-height:1.5}.member-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.member-row:last-child{border-bottom:none}.member-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.income-member-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft);gap:var(--space-3)}.income-member-row:last-child{border-bottom:none}.income-member-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.income-member-name{font-size:14px;font-weight:500;color:var(--ink)}.income-input-wrap{display:flex;align-items:center;gap:4px;flex-shrink:0}.income-currency{font-size:16px;color:var(--faint)}.income-input{width:90px;font-family:var(--font);font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.02em;border:none;background:transparent;outline:none;text-align:right}.income-input::placeholder{color:var(--placeholder);font-weight:400}.income-per-mo{font-size:12px;color:var(--faint)}.income-total-card{background:var(--green-tint);border-radius:var(--r-md);padding:14px 16px;border:.5px solid var(--green-light)}.income-total-row{display:flex;justify-content:space-between;align-items:center}.income-total-label{font-size:13px;color:var(--green-mid)}.income-total-value{font-size:16px;font-weight:700;color:var(--green);letter-spacing:-.02em}.tags-grid{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag-item{display:flex;align-items:center;gap:6px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-full);padding:6px 10px;font-size:13px;color:var(--ink)}.tag-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tag-name{flex:1}.tag-delete{background:none;border:none;cursor:pointer;color:var(--placeholder);display:flex;padding:0}.tag-delete:hover{color:var(--red)}.explainer-card{background:var(--green-tint);border:.5px solid var(--green-light);border-radius:var(--r-lg);padding:var(--space-4)}.explainer-title{font-size:14px;font-weight:600;color:var(--green);margin-bottom:var(--space-2)}.explainer-body{font-size:12px;color:var(--green-mid);line-height:1.5;margin-bottom:var(--space-3)}.explainer-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:var(--space-2)}.echip{font-size:11px;background:var(--surface);color:var(--green);border:.5px solid var(--green-light);border-radius:var(--r-full);padding:3px 10px}.explainer-hint{font-size:11px;color:var(--green-mid);font-style:italic;margin-bottom:var(--space-2)}.explainer-toggle{font-size:11px;color:var(--faint);background:none;border:none;cursor:pointer;font-family:var(--font);display:block;width:100%;text-align:right}.optional-label{display:block;font-size:11px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}.cat-edit-preview{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--raised);border-radius:var(--r-xl);margin-bottom:20px}.cat-edit-preview-icon{width:56px;height:56px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:28px;transition:background var(--duration)}.cat-name-input{width:100%;font-family:var(--font);font-size:15px;font-weight:500;color:var(--ink);background:transparent;border:none;outline:none;padding:0}.cat-name-input::placeholder{color:var(--placeholder);font-weight:400}.cat-color-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:8px;padding:4px 0 20px}.cat-color-swatch{aspect-ratio:1;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform var(--duration),border-color var(--duration);outline:none}.cat-color-swatch:hover{transform:scale(1.15)}.cat-color-swatch.selected{border-color:var(--ink);transform:scale(1.1);box-shadow:0 0 0 2px var(--canvas),0 0 0 4px currentColor}.icon-group-tabs{display:flex;gap:6px;overflow-x:auto;padding:4px 0 10px;scrollbar-width:none}.icon-group-tabs::-webkit-scrollbar{display:none}.icon-group-tab{flex-shrink:0;font-family:var(--font);font-size:12px;font-weight:500;color:var(--muted);background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-full);padding:5px 12px;cursor:pointer;transition:background var(--duration),color var(--duration),border-color var(--duration);white-space:nowrap}.icon-group-tab.active{background:var(--green-tint);color:var(--green);border-color:var(--green-light);font-weight:600}.icon-emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;margin-bottom:4px}.icon-emoji-btn{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:22px;background:none;border:1.5px solid transparent;border-radius:var(--r-md);cursor:pointer;transition:background var(--duration),border-color var(--duration),transform var(--duration);line-height:1}.icon-emoji-btn:hover{background:var(--raised);transform:scale(1.12)}.icon-emoji-btn.selected{border-width:2px;transform:scale(1.08)}@media(max-width:360px){.cat-color-grid{grid-template-columns:repeat(8,1fr)}.icon-emoji-grid{grid-template-columns:repeat(6,1fr)}}.sub-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.sub-header h3{flex:1;font-size:16px;font-weight:600;color:var(--ink);margin:0}.sub-header-action{background:none;border:none;cursor:pointer;color:var(--muted);display:flex;padding:6px;border-radius:var(--r-sm);transition:background var(--duration),color var(--duration)}.sub-header-action:hover{background:var(--raised);color:var(--ink)}.cat-detail-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:20px;padding:var(--space-3) var(--space-4);background:var(--raised);border-radius:var(--r-xl)}.subcat-row{display:flex;align-items:center;justify-content:space-between;padding:10px var(--space-4);border-bottom:.5px solid var(--border-soft);gap:var(--space-3);min-height:44px}.subcat-row:last-of-type{border-bottom:none}.subcat-row.subcat-hidden{opacity:.4}.subcat-name{flex:1;font-size:14px;color:var(--ink);cursor:pointer;padding:2px 0}.subcat-name:hover{color:var(--green)}.subcat-edit-input{flex:1;font-family:var(--font);font-size:14px;color:var(--ink);background:var(--raised);border:.5px solid var(--green);border-radius:var(--r-sm);padding:4px 8px;outline:none}.subcat-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.subcat-reset{background:none;border:none;cursor:pointer;font-size:14px;color:var(--faint);padding:3px;line-height:1}.subcat-reset:hover{color:var(--muted)}.subcat-restore{font-family:var(--font);font-size:11px;background:var(--green-tint);color:var(--green);border:.5px solid var(--green-light);border-radius:var(--r-full);padding:2px 8px;cursor:pointer;font-weight:600}.subcat-del{background:none;border:none;cursor:pointer;color:var(--faint);display:flex;padding:3px;transition:color var(--duration)}.subcat-del:hover{color:var(--red)}.subcat-add-row{display:flex;align-items:center;padding:8px var(--space-4);gap:var(--space-2)}.subcat-add-input{flex:1;font-family:var(--font);font-size:14px;color:var(--ink);background:transparent;border:none;outline:none}.subcat-add-input::placeholder{color:var(--placeholder)}.subcat-add-btn{background:none;border:none;cursor:pointer;display:flex;padding:4px;border-radius:var(--r-sm);transition:opacity var(--duration)}.subcat-add-btn:disabled{opacity:.3;cursor:default}.delete-confirm-row{display:flex;align-items:center;gap:8px;padding:12px 0}.delete-confirm-row span{flex:1}.btn-danger:hover{background:var(--red-tint);opacity:.8}.cat-delete-blocked{background:var(--raised);border:1px solid var(--border-mid);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:6px}.cat-delete-blocked-icon{color:var(--amber-mid);display:flex}.cat-delete-blocked-title{font-size:14px;font-weight:600;color:var(--ink);margin:0}.cat-delete-blocked-body{font-size:13px;color:var(--muted);margin:0;line-height:1.5}.cat-delete-blocked-link{display:inline-block;margin-top:4px;font-size:13px;font-weight:500;color:var(--ink);text-decoration:underline;text-underline-offset:2px}.notif-mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px}.notif-mode-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 10px;background:var(--raised);border:1.5px solid var(--border);border-radius:var(--r-lg);cursor:pointer;font-family:var(--font);transition:border-color var(--duration),background var(--duration)}.notif-mode-btn.active{border-color:var(--green);background:var(--green-tint)}.notif-mode-label{font-size:14px;font-weight:600;color:var(--ink)}.notif-mode-sub{font-size:11px;color:var(--faint);text-align:center}.setting-row.selected-row{background:var(--green-tint)}.recurring-row{align-items:flex-start;padding:var(--space-3) var(--space-4)}.recurring-overdue{color:var(--red, #EF4444)!important;font-weight:500}.icon-action-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:background var(--duration)}.icon-action-btn:hover{background:var(--border)}.icon-action-btn.icon-action-danger:hover{background:var(--red-tint, #FEE2E2);color:var(--red, #EF4444);border-color:var(--red, #EF4444)}.recurring-edit-row{padding:var(--space-3) var(--space-4);background:var(--raised);border-top:.5px solid var(--border-soft);display:flex;flex-direction:column;gap:var(--space-3)}.recurring-edit-2col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.recurring-edit-field{display:flex;flex-direction:column;gap:var(--space-1)}.recurring-edit-field .optional-label{margin-bottom:0}.recurring-edit-field .income-input-wrap{width:100%}.recurring-edit-field .income-input{flex:1;width:100%}.notif-history-empty{font-size:13px;color:var(--faint);text-align:center;padding:var(--space-6) 0}.notif-history-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.notif-history-count{font-size:12px;color:var(--faint)}.notif-history-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.notif-history-item:last-child{border-bottom:none}.notif-history-icon{font-size:15px;flex-shrink:0;margin-top:1px}.notif-history-body{flex:1;min-width:0}.notif-history-text{font-size:13px;color:var(--ink);line-height:1.4;margin:0 0 3px}.notif-history-meta{display:flex;align-items:center;gap:var(--space-2);font-size:11px;color:var(--faint)}.notif-history-status{padding:1px 6px;border-radius:var(--r-full);font-size:10px;font-weight:600}.notif-history-status.unread{background:var(--amber-tint);color:var(--amber)}.notif-history-status.read{background:var(--raised);color:var(--faint)}.notif-history-actions{display:flex;gap:4px;flex-shrink:0;align-items:center}.notif-history-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--raised);border:.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:background var(--duration),color var(--duration);padding:0}.notif-history-btn:hover{background:var(--border);color:var(--ink)}.notif-history-dismiss:hover{background:var(--red-tint);color:var(--red);border-color:var(--red-mid)}.invite-sent-banner{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--green-tint, #f0f7d4);border:.5px solid var(--green-mid, #b8cc3a);border-radius:var(--r-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3)}.invite-sent-icon{width:28px;height:28px;border-radius:50%;background:var(--green);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:1px}.invite-sent-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:2px}.invite-sent-sub{font-size:12px;color:var(--muted);line-height:1.5}.invite-sent-again{margin-left:auto;background:none;border:.5px solid var(--border);border-radius:var(--r-sm);padding:4px 10px;font-size:12px;color:var(--muted);cursor:pointer;white-space:nowrap;flex-shrink:0;align-self:center}.invite-sent-again:hover{background:var(--raised);color:var(--ink)}.invite-link-row{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:12px;border-top:.5px solid var(--border-soft)}.invite-link-btn{background:none;border:.5px solid var(--border);border-radius:var(--r-sm);padding:5px 12px;font-size:12px;color:var(--muted);cursor:pointer;white-space:nowrap}.invite-link-btn:hover{background:var(--raised);color:var(--ink)}.invite-link-btn:disabled{opacity:.5;cursor:default}.income-current-card{background:var(--ink);border-radius:var(--r-lg);padding:var(--space-4) var(--space-4);margin-bottom:4px}.income-current-label{font-size:11px;color:#c7dc4ea6;letter-spacing:.04em;text-transform:uppercase;font-weight:600;margin-bottom:4px}.income-current-amount{font-size:28px;font-weight:800;color:#c7dc4e;letter-spacing:-.03em;line-height:1}.income-current-mo{font-size:15px;font-weight:500;margin-left:2px;opacity:.7}.income-pct-pill{display:inline-block;margin-top:10px;background:#c7dc4e26;color:#c7dc4e;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.income-empty-hint{font-size:13px;color:var(--faint);background:var(--raised);border-radius:var(--r-md);padding:var(--space-3) var(--space-4);text-align:center;line-height:1.5}.income-history-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:.5px solid var(--border-soft)}.income-history-row:last-child{border-bottom:none}.income-history-left{flex:1;min-width:0}.income-history-month{font-size:14px;font-weight:500;color:var(--ink);display:flex;align-items:center;gap:6px}.income-history-badge{font-size:10px;font-weight:700;color:var(--green);background:var(--green-tint);border-radius:10px;padding:1px 7px;letter-spacing:.03em;text-transform:uppercase}.income-history-until{font-size:12px;color:var(--faint);margin-top:1px}.income-history-amount{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap}.income-history-del{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--faint);padding:0;flex-shrink:0;transition:background var(--duration),color var(--duration)}.income-history-del:hover{background:var(--red-tint);color:var(--red);border-color:var(--red-mid)}.income-add-form{background:var(--raised);border-radius:var(--r-md);padding:var(--space-4);margin-top:12px;border:.5px solid var(--border)}.income-add-row{display:flex;gap:8px;align-items:stretch}.income-form-field{background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);padding:9px 12px;font-family:var(--font);font-size:14px;color:var(--ink);outline:none;transition:border-color var(--duration) var(--ease);flex:0 0 148px}.income-form-field:focus{border-color:var(--ink)}.income-form-amount-wrap{flex:1;display:flex;align-items:center;gap:6px;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);padding:0 12px}.income-form-amount-wrap:focus-within{border-color:var(--ink)}.income-form-prefix,.income-form-suffix{font-size:14px;color:var(--faint);flex-shrink:0}.income-form-amount{flex:1;border:none;background:transparent;font-family:var(--font);font-size:14px;font-weight:600;color:var(--ink);outline:none;min-width:0;padding:9px 0}.login-bg{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--canvas);padding:var(--space-4)}.login-card{width:100%;max-width:380px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-2xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);box-shadow:var(--shadow-lg)}.login-brand{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.login-logo{width:44px;height:44px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--accent-ink);letter-spacing:-.02em;flex-shrink:0}.login-app-name{font-size:20px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}.login-app-sub{font-size:12px;color:var(--faint);margin-top:1px}.login-error{background:var(--red-tint);border:.5px solid var(--red-mid);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--red);line-height:1.4}.oauth-stack{display:flex;flex-direction:column;gap:var(--space-2)}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);font-family:var(--font);font-size:14px;font-weight:500;color:var(--ink);text-decoration:none;cursor:pointer;transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease);-webkit-user-select:none;user-select:none}.oauth-btn:hover{background:var(--canvas);border-color:var(--border)}.oauth-btn:active{transform:scale(.98)}.or-row{display:flex;align-items:center;gap:var(--space-3);color:var(--faint);font-size:12px}.or-row:before,.or-row:after{content:"";flex:1;height:.5px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:var(--space-2)}.auth-input{width:100%;background:var(--canvas);border:.5px solid var(--border-mid);border-radius:var(--r-md);padding:11px 14px;font-family:var(--font);font-size:15px;color:var(--ink);outline:none;transition:border-color var(--duration) var(--ease),background var(--duration) var(--ease)}.auth-input:focus{border-color:var(--green);background:var(--surface)}.auth-input::placeholder{color:var(--placeholder)}.pw-wrap{position:relative}.pw-wrap .auth-input{padding-right:42px}.pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--faint);display:flex;align-items:center;padding:4px;border-radius:var(--r-sm);transition:color var(--duration)}.pw-eye:hover{color:var(--muted)}.auth-switch{text-align:center;font-size:13px;color:var(--faint)}.auth-switch button{background:none;border:none;color:var(--green-mid);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;padding:0;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color var(--duration)}.auth-switch button:hover{text-decoration-color:currentColor}.auth-loading{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--canvas)}.auth-loading-logo{width:44px;height:44px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--accent-ink);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}:root{--canvas: #F6F2EA;--surface: #FFFFFF;--raised: #EDE8DF;--border: #E8E3DA;--border-mid: #DDD8CF;--border-soft: #F2EEE6;--ink: #1B1814;--charcoal: #3A3630;--muted: #6B6560;--faint: #A09B94;--placeholder: #C0BBB4;--green-tint: #F0F5D0;--green-light: #C7DC4E;--green-mid: #7A8A1F;--green: #1B1814;--green-deep: #111009;--accent: #C7DC4E;--accent-ink: #1B1814;--accent-deep: #B8CC3A;--accent-tint: #F0F5D0;--amber-tint: #FFF3D6;--amber-mid: #D4860A;--amber: #9A6200;--red-tint: #FAEAEA;--red: #8A2828;--red-mid: #C0392B;--green-positive: #2D6A3F;--cat-housing: oklch(.42 .12 145);--cat-bills: oklch(.42 .12 70);--cat-transport: oklch(.42 .12 200);--cat-education: oklch(.42 .12 245);--cat-food: oklch(.42 .12 25);--cat-health: oklch(.42 .12 10);--cat-personal: oklch(.42 .12 320);--cat-clothing: oklch(.42 .12 285);--cat-entertainment: oklch(.42 .12 290);--cat-financial: oklch(.42 .12 230);--cat-housing-tint: oklch(.93 .06 145);--cat-bills-tint: oklch(.93 .06 70);--cat-transport-tint: oklch(.93 .06 200);--cat-education-tint: oklch(.93 .06 245);--cat-food-tint: oklch(.93 .06 25);--cat-health-tint: oklch(.93 .06 10);--cat-personal-tint: oklch(.93 .06 320);--cat-clothing-tint: oklch(.93 .06 285);--cat-entertainment-tint: oklch(.93 .06 290);--cat-financial-tint: oklch(.93 .06 230);--font: "Inter Tight", -apple-system, system-ui, sans-serif;--font-serif: "Fraunces", Georgia, serif;--font-mono: "SFMono-Regular", Menlo, monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--r-2xl: 28px;--r-full: 999px;--shadow-sm: 0 1px 3px rgba(27,24,20,.07);--shadow-md: 0 4px 12px rgba(27,24,20,.09);--shadow-lg: 0 8px 24px rgba(27,24,20,.11);--shadow-fab: 0 4px 16px rgba(27,24,20,.3);--ease: cubic-bezier(.16, 1, .3, 1);--duration: .2s}html.dark{color-scheme:dark;--canvas: #161614;--surface: #1E1E1C;--raised: #262624;--border: #323230;--border-mid: #3E3E3C;--border-soft: #2A2A28;--ink: #F0EDE8;--charcoal: #D0CEC9;--muted: #8A8880;--faint: #5A5855;--placeholder: #4A4845;--green-tint: #2A3010;--green-light: #C7DC4E;--green-mid: #A0B02A;--green: #252320;--green-deep: #1A1917;--green-positive: #5A9E6A;--accent: #C7DC4E;--accent-ink: #1B1814;--accent-deep: #B8CC3A;--accent-tint: #2A3010;--amber-tint: #2A200E;--amber-mid: #E09A20;--amber: #C88A18;--red-tint: #2A1212;--red: #C05858;--red-mid: #E05050;--cat-housing: oklch(.68 .14 145);--cat-bills: oklch(.68 .14 70);--cat-transport: oklch(.68 .14 200);--cat-education: oklch(.68 .14 245);--cat-food: oklch(.68 .14 25);--cat-health: oklch(.68 .14 10);--cat-personal: oklch(.68 .14 320);--cat-clothing: oklch(.68 .14 285);--cat-entertainment: oklch(.68 .14 290);--cat-financial: oklch(.68 .14 230);--cat-housing-tint: oklch(.22 .06 145);--cat-bills-tint: oklch(.22 .06 70);--cat-transport-tint: oklch(.22 .06 200);--cat-education-tint: oklch(.22 .06 245);--cat-food-tint: oklch(.22 .06 25);--cat-health-tint: oklch(.22 .06 10);--cat-personal-tint: oklch(.22 .06 320);--cat-clothing-tint: oklch(.22 .06 285);--cat-entertainment-tint: oklch(.22 .06 290);--cat-financial-tint: oklch(.22 .06 230);--shadow-sm: 0 1px 3px rgba(0,0,0,.35);--shadow-md: 0 4px 12px rgba(0,0,0,.45);--shadow-lg: 0 8px 24px rgba(0,0,0,.55);--shadow-fab: 0 4px 16px rgba(0,0,0,.55)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--canvas);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{max-width:430px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative;background:var(--canvas)}.app-shell{display:flex;flex-direction:column;flex:1;min-height:100dvh}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}@media(min-width:768px){body{background:var(--canvas)}#root{max-width:none;margin:0}.app-shell{flex-direction:row}.app-main{overflow-y:auto;height:100dvh;max-width:780px}}::-webkit-scrollbar{width:0;height:0}h1{font-size:28px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}h2{font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}h3{font-size:17px;font-weight:500;color:var(--ink)}.label-xs{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--faint)}.amount{font-family:var(--font);font-weight:500;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font);font-size:14px;font-weight:500;border:none;border-radius:var(--r-md);cursor:pointer;padding:10px 18px;transition:opacity var(--duration) var(--ease),transform var(--duration) var(--ease);white-space:nowrap;text-decoration:none}.btn:active{transform:scale(.97);opacity:.9}.btn-primary{background:var(--green);color:var(--green-light)}.btn-primary:hover{background:var(--green-deep)}.btn-secondary{background:var(--raised);color:var(--ink);border:.5px solid var(--border-mid)}.btn-secondary:hover{background:var(--border)}.btn-ghost{background:transparent;color:var(--muted);border:.5px solid var(--border)}.btn-danger{background:var(--red-tint);color:var(--red);border:.5px solid var(--red-mid)}.btn-full{width:100%}.btn-lg{font-size:15px;padding:13px 22px}.btn-sm{font-size:12px;padding:6px 12px;border-radius:var(--r-sm)}.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.card-pad{padding:var(--space-4)}.input{width:100%;background:var(--surface);border:.5px solid var(--border-mid);border-radius:var(--r-md);padding:10px 14px;font-family:var(--font);font-size:14px;color:var(--ink);outline:none;transition:border-color var(--duration) var(--ease)}.input:focus{border-color:var(--ink)}.input::placeholder{color:var(--placeholder)}.toggle{width:44px;height:26px;background:var(--border-mid);border-radius:var(--r-full);position:relative;cursor:pointer;transition:background var(--duration) var(--ease);flex-shrink:0;border:none}.toggle.on{background:var(--green)}.toggle:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left var(--duration) var(--ease);box-shadow:0 1px 3px #00000026}.toggle.on:after{left:21px}.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;border-radius:var(--r-full);padding:2px 8px}.badge-green{background:var(--green-tint);color:var(--green)}.badge-amber{background:var(--amber-tint);color:var(--amber)}.badge-red{background:var(--red-tint);color:var(--red)}.badge-neutral{background:var(--raised);color:var(--muted)}.delta-up{color:var(--red-mid)}.delta-down{color:var(--green-positive)}.delta-neutral{color:var(--faint)}.section-label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);margin-bottom:var(--space-2);padding-left:2px}.divider{height:.5px;background:var(--border-soft);border:none}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center;gap:var(--space-3)}.empty-icon{color:var(--faint)}.empty-title{font-size:16px;font-weight:500;color:var(--charcoal)}.empty-sub{font-size:13px;color:var(--faint);max-width:240px;line-height:1.5}.page{flex:1;display:flex;flex-direction:column;padding-bottom:80px;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);padding-top:calc(var(--space-4) + env(safe-area-inset-top,0px))}.page-title{font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.page-body{padding:0 var(--space-5) var(--space-6)}.sub-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);padding-top:calc(var(--space-4) + env(safe-area-inset-top,0px))}.back-btn{width:34px;height:34px;background:var(--raised);border:none;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--muted);transition:background var(--duration)}.back-btn:hover{background:var(--border)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.animate-fade-up{animation:fadeUp .4s var(--ease) both}.animate-fade-in{animation:fadeIn .3s var(--ease) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:50ms}.stagger>*:nth-child(3){animation-delay:.1s}.stagger>*:nth-child(4){animation-delay:.15s}.stagger>*:nth-child(5){animation-delay:.2s}.stagger>*:nth-child(6){animation-delay:.25s}@media(min-width:768px){.page{padding-bottom:0}}
