*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;color:#e8e0d8;background-color:#1a1714;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(255,140,107,.06),transparent),radial-gradient(ellipse 60% 50% at 80% 80%,rgba(166,199,156,.04),transparent),#1a1714;color:#e8e0d8;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}:root{--bg-base: #1a1714;--bg-primary: #201d19;--bg-secondary: #2a2520;--bg-tertiary: #332e28;--bg-card: rgba(42, 37, 32, .65);--bg-hover: rgba(255, 140, 107, .06);--bg-active: rgba(255, 140, 107, .1);--glass-bg: rgba(38, 34, 28, .55);--glass-border: rgba(255, 255, 255, .05);--glass-blur: 20px;--border: rgba(255, 255, 255, .07);--border-subtle: rgba(255, 255, 255, .04);--border-focus: #8bdc6b;--text-primary: #f2ebe4;--text-secondary: #a89e94;--text-muted: #6d635a;--text-accent: #a8e890;--accent: #8bdc6b;--accent-hover: #9de382;--accent-glow: rgba(139, 220, 107, .25);--accent-subtle: rgba(139, 220, 107, .1);--accent-gradient: linear-gradient(135deg, #8bdc6b, #6bc98b);--success: #a6c79c;--success-dark: #7ba36e;--success-bg: rgba(166, 199, 156, .1);--error: #e87c7c;--error-bg: rgba(232, 124, 124, .1);--warning: #e8c77c;--info: #7cb5e8;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 3rem;--radius-sm: .625rem;--radius-md: .875rem;--radius-lg: 1.125rem;--radius-xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-glow: 0 0 24px var(--accent-glow);--shadow-card: 0 2px 16px rgba(0, 0, 0, .15), inset 0 1px 0 rgba(255, 255, 255, .03);--shadow-card-hover: 0 4px 24px rgba(0, 0, 0, .2), inset 0 1px 0 rgba(255, 255, 255, .05);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1)}h1,h2,h3,.font-display{font-family:DM Sans,sans-serif}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem;letter-spacing:-.025em}.text-3xl{font-size:1.875rem;line-height:2.25rem;letter-spacing:-.03em}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-accent{color:var(--text-accent)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-error{color:var(--error)}.container{max-width:428px;margin:0 auto;padding:0 var(--space-lg)}.page-container{min-height:100vh;padding-bottom:6rem;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--space-xl) var(--space-lg) var(--space-lg);max-width:428px;margin:0 auto;width:100%}.card{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-card-hover)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.card-title{font-family:DM Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.75rem 1.5rem;font-weight:600;font-size:.9375rem;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden;font-family:DM Sans,sans-serif;letter-spacing:.01em}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-gradient);color:#1a1714;box-shadow:0 2px 16px var(--accent-glow)}.btn-primary:hover{box-shadow:0 4px 24px var(--accent-glow),var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0) scale(.97)}.btn-secondary{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--text-accent)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem .75rem;min-height:auto}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-accent)}.fab{position:fixed;bottom:6rem;right:1.5rem;width:56px;height:56px;border-radius:var(--radius-full);background:var(--accent-gradient);color:var(--bg-base);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 20px var(--accent-glow);transition:all var(--transition-spring);z-index:50;text-decoration:none}.fab:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 30px var(--accent-glow)}.fab:active{transform:scale(.95) rotate(90deg)}.form-group{margin-bottom:var(--space-xl)}.form-label{display:block;margin-bottom:var(--space-sm);font-weight:500;font-size:.8125rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.form-input{width:100%;min-height:48px;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all var(--transition-base)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle),var(--shadow-glow);background:var(--bg-tertiary)}.form-input::placeholder{color:var(--text-muted)}.amount-input{font-size:2.5rem;font-weight:700;text-align:center;background:var(--bg-secondary);border:2px solid var(--border);color:var(--text-accent);letter-spacing:-.02em;padding:1rem;border-radius:var(--radius-lg);font-family:DM Sans,sans-serif}.amount-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-subtle)}.toggle-group{display:flex;background:var(--bg-secondary);border-radius:var(--radius-md);padding:4px;gap:4px;border:1px solid var(--border-subtle)}.toggle-option{flex:1;padding:.625rem .75rem;border:none;background:transparent;color:var(--text-secondary);border-radius:calc(var(--radius-md) - 2px);cursor:pointer;font-weight:500;font-size:.875rem;font-family:inherit;transition:all var(--transition-base)}.toggle-option:hover:not(.active){color:var(--text-primary);background:rgba(255,255,255,.03)}.toggle-option.active{background:var(--accent-gradient);color:var(--bg-base);font-weight:600;box-shadow:0 2px 8px var(--accent-glow)}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin:var(--space-md) 0}.category-item{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80px;padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-spring);text-align:center}.category-item:hover{background:var(--bg-hover);border-color:#ff8c6b4d;transform:translateY(-2px)}.category-item:active{transform:translateY(0) scale(.96)}.category-item.active{background:var(--accent-gradient);border-color:var(--accent);color:var(--bg-base);box-shadow:0 4px 20px var(--accent-glow)}.category-icon{font-size:1.5rem;margin-bottom:var(--space-xs)}.category-name{font-size:.75rem;font-weight:600;letter-spacing:.02em}.progress-container{margin:var(--space-lg) 0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.progress-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1);position:relative}.progress-fill:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:inherit;box-shadow:0 0 8px currentColor}.progress-fill.success{background:linear-gradient(90deg,var(--success-dark),var(--success));color:var(--success)}.progress-fill.warning{background:linear-gradient(90deg,#c9a544,var(--warning));color:var(--warning)}.progress-fill.danger{background:linear-gradient(90deg,#c44,var(--error));color:var(--error)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:rgba(26,23,20,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--glass-border);padding:.5rem 0 calc(.5rem + env(safe-area-inset-bottom));z-index:40}.nav-container{display:flex;justify-content:space-around;align-items:center;max-width:428px;margin:0 auto}.nav-item{display:flex;flex-direction:column;align-items:center;padding:.5rem .75rem;color:var(--text-muted);text-decoration:none;transition:all var(--transition-base);min-width:48px;border-radius:var(--radius-md);position:relative}.nav-item:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%) scaleX(0);width:20px;height:2px;background:var(--accent);border-radius:var(--radius-full);transition:transform var(--transition-base)}.nav-item.active{color:var(--text-accent)}.nav-item.active:before{transform:translate(-50%) scaleX(1)}.nav-item.add-btn{background:var(--accent-gradient);color:var(--bg-base);border-radius:var(--radius-full);width:48px;height:48px;margin-top:-12px;box-shadow:0 4px 16px var(--accent-glow);padding:0;transition:all var(--transition-spring);border:none;cursor:pointer;font-family:inherit;font-size:inherit}.nav-item.add-btn:before{display:none}.nav-item.add-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px var(--accent-glow)}.nav-item.add-btn:active{transform:scale(.92)}.nav-icon{font-size:1.25rem;margin-bottom:2px;transition:transform var(--transition-base)}.nav-item:hover .nav-icon{transform:scale(1.1)}.nav-label{font-size:.6875rem;font-weight:500;letter-spacing:.02em}.expense-list{display:flex;flex-direction:column;gap:var(--space-sm)}.expense-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:rgba(255,255,255,.02);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:default}.expense-item:hover{background:var(--bg-hover);border-color:#ff8c6b1f;transform:translate(4px)}.expense-info{flex:1;min-width:0}.expense-description{font-weight:500;margin-bottom:2px;font-size:.9375rem}.expense-meta{font-size:.8125rem;color:var(--text-muted);display:flex;gap:var(--space-md);flex-wrap:wrap}.expense-amount{font-weight:700;color:var(--text-accent);font-size:1rem;font-variant-numeric:tabular-nums;font-family:DM Sans,sans-serif}.balance-card{background:var(--accent-gradient);color:var(--bg-base);text-align:center;padding:var(--space-xl);border-radius:var(--radius-xl);margin:var(--space-lg) 0;position:relative;overflow:hidden;box-shadow:0 8px 32px var(--accent-glow)}.balance-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.12) 0%,transparent 60%);pointer-events:none}.balance-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.65;margin-bottom:var(--space-sm)}.balance-amount{font-family:DM Sans,sans-serif;font-size:1.375rem;font-weight:800;letter-spacing:-.02em}.personal-card{background:linear-gradient(135deg,rgba(255,140,107,.08),rgba(166,199,156,.06));border:1px solid rgba(255,140,107,.12);border-radius:var(--radius-xl);padding:var(--space-xl);margin:var(--space-lg) 0}.personal-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.personal-card-avatar{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-full);flex-shrink:0}.personal-card-title{font-family:DM Sans,sans-serif;font-size:1.0625rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.personal-card-subtitle{font-size:.8125rem;color:var(--text-muted);margin-top:1px}.personal-card-stats{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.personal-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.personal-stat-value{font-family:DM Sans,sans-serif;font-size:1.375rem;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.personal-stat-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.personal-stat-divider{width:1px;height:36px;background:var(--border)}.login-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--space-2xl)}.login-card{width:100%;max-width:340px;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-2xl);text-align:center;box-shadow:var(--shadow-lg)}.login-title{font-family:DM Sans,sans-serif;font-size:2.5rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-2xl);letter-spacing:-.04em}.avatar-selection{display:flex;justify-content:center;gap:var(--space-xl);margin:var(--space-xl) 0}.avatar-option{width:80px;height:80px;border-radius:var(--radius-full);border:2px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-spring);font-size:1.75rem}.avatar-option:hover{border-color:var(--accent);transform:scale(1.08);box-shadow:0 0 20px var(--accent-glow)}.avatar-option.selected{border-color:var(--accent);background:var(--accent-gradient);box-shadow:0 0 30px var(--accent-glow)}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-sm)}.mb-2{margin-bottom:var(--space-lg)}.mb-4{margin-bottom:var(--space-2xl)}.mt-2{margin-top:var(--space-lg)}.mt-4{margin-top:var(--space-2xl)}.hidden{display:none}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-sm)}.gap-4{gap:var(--space-lg)}.py-4{padding-top:var(--space-2xl);padding-bottom:var(--space-2xl)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:fadeIn .4s cubic-bezier(.4,0,.2,1) forwards}.fade-in>.card,.fade-in>.balance-card,.fade-in>div>.card,.fade-in>details.card{animation:slideUp .5s cubic-bezier(.4,0,.2,1) backwards}.fade-in>:nth-child(1){animation-delay:0ms}.fade-in>:nth-child(2){animation-delay:50ms}.fade-in>:nth-child(3){animation-delay:.1s}.fade-in>:nth-child(4){animation-delay:.15s}.fade-in>:nth-child(5){animation-delay:.2s}.fade-in>:nth-child(6){animation-delay:.25s}.fade-in>:nth-child(7){animation-delay:.3s}.fade-in>:nth-child(8){animation-delay:.35s}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 375px){.container{padding:0 var(--space-md)}.main-content{padding:var(--space-lg) var(--space-md)}.card{padding:var(--space-lg)}.fab{right:var(--space-lg);bottom:5.5rem}}@supports (padding-bottom: env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}}::selection{background:var(--accent-subtle);color:var(--text-accent)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:sheetFadeIn .2s ease-out}@keyframes sheetFadeIn{0%{opacity:0}to{opacity:1}}.sheet{width:100%;max-width:428px;background:var(--bg-primary);border-top-left-radius:1.75rem;border-top-right-radius:1.75rem;border:1px solid var(--glass-border);border-bottom:none;box-shadow:0 -8px 48px #0006;animation:sheetSlideUp .3s cubic-bezier(.32,.72,0,1);transition:transform .15s ease-out;padding:0 var(--space-xl) var(--space-2xl);overflow-y:auto;max-height:92vh;overscroll-behavior:contain}.sheet-success{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{display:flex;justify-content:center;padding:var(--space-md) 0 var(--space-sm)}.sheet-handle-bar{width:36px;height:4px;border-radius:var(--radius-full);background:var(--text-muted);opacity:.35}.sheet-amount-area{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) 0 var(--space-xl)}.sheet-amount-row{display:flex;align-items:baseline}.sheet-currency{font-family:DM Sans,sans-serif;font-size:2.5rem;font-weight:300;color:var(--text-muted);margin-right:var(--space-xs)}.sheet-amount-input{font-family:DM Sans,sans-serif;font-size:3.5rem;font-weight:800;color:var(--text-primary);background:transparent;border:none;outline:none;text-align:left;width:180px;letter-spacing:-.04em;caret-color:var(--accent)}.sheet-amount-input::placeholder{color:var(--text-muted);opacity:.2}.sheet-desc-input{font-family:inherit;font-size:.9375rem;color:var(--text-secondary);background:transparent;border:none;outline:none;text-align:center;width:100%;max-width:260px;padding:var(--space-sm) 0;margin-top:var(--space-xs)}.sheet-desc-input::placeholder{color:var(--text-muted);opacity:.5}.sheet-categories{display:flex;gap:var(--space-sm);overflow-x:auto;scrollbar-width:none;padding:var(--space-sm) 0 var(--space-lg);margin:0 calc(-1 * var(--space-xl));padding-left:var(--space-xl);padding-right:var(--space-xl)}.sheet-categories::-webkit-scrollbar{display:none}.sheet-cat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-md) var(--space-lg);min-width:72px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1.5px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-spring);font-family:inherit;flex-shrink:0}.sheet-cat:active{transform:scale(.93)}.sheet-cat.active{background:var(--accent-subtle);border-color:var(--accent);color:var(--text-accent)}.sheet-cat-icon{font-size:1.375rem}.sheet-cat-name{font-size:.6875rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.sheet-meta-row{display:flex;gap:6px;padding-bottom:var(--space-md);flex-wrap:wrap;align-items:center}.sheet-meta-chip{padding:.375rem .75rem;border-radius:var(--radius-full);background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);font-family:inherit;white-space:nowrap}.sheet-meta-chip.active{background:var(--bg-tertiary);border-color:var(--text-secondary);color:var(--text-primary)}.sheet-meta-chip:active{transform:scale(.95)}.sheet-meta-spacer{width:1px;height:16px;background:var(--border);margin:0 2px}.sheet-date-btn{display:block;width:100%;padding:var(--space-sm) 0;background:transparent;border:none;color:var(--text-muted);font-size:.8125rem;cursor:pointer;text-align:center;font-family:inherit;transition:color var(--transition-base)}.sheet-date-btn:hover{color:var(--text-secondary)}.sheet-extra{padding-bottom:var(--space-md)}.sheet-error{color:var(--error);font-size:.8125rem;text-align:center;padding:var(--space-sm) 0}.sheet-submit{width:100%;margin-top:var(--space-md);min-height:52px;font-size:1rem;border-radius:var(--radius-lg)}.sheet-success-msg{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-3xl) 0;color:var(--success);font-size:1.125rem;font-weight:600}.sheet-success-icon{width:56px;height:56px;border-radius:var(--radius-full);background:var(--success-bg);border:2px solid var(--success);display:flex;align-items:center;justify-content:center;font-size:1.5rem;animation:successPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes successPop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.add-view{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg-primary)}.add-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);padding-top:max(var(--space-md),env(safe-area-inset-top));flex-shrink:0}.add-back{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-primary);font-size:1.25rem;cursor:pointer;transition:all var(--transition-base);font-family:inherit}.add-back:active{transform:scale(.9)}.add-title{font-family:DM Sans,sans-serif;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.add-content{padding:0 var(--space-xl);padding-bottom:var(--space-3xl)}.add-amount-area{display:flex;flex-direction:column;align-items:center;padding:var(--space-xl) 0 var(--space-lg)}.add-amount-row{display:flex;align-items:baseline}.add-currency{font-family:DM Sans,sans-serif;font-size:2.5rem;font-weight:300;color:var(--text-muted);margin-right:var(--space-xs)}.add-amount-input{font-family:DM Sans,sans-serif;font-size:3.5rem;font-weight:800;color:var(--text-primary);background:transparent;border:none;outline:none;text-align:left;width:180px;letter-spacing:-.04em;caret-color:var(--accent)}.add-amount-input::placeholder{color:var(--text-muted);opacity:.2}.add-section-label{display:none}.add-tag-row{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-sm)}.add-tag{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--bg-secondary);border:1.5px solid transparent;font-size:1.25rem;cursor:pointer;transition:all var(--transition-base);font-family:inherit}.add-tag:active{transform:scale(.9)}.add-tag.active{background:var(--accent-subtle);border-color:var(--accent)}.add-autocomplete{position:relative;margin-bottom:var(--space-sm)}.add-hints{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-top:4px;z-index:20;overflow:hidden;box-shadow:0 8px 24px #0000004d}.add-hint{display:block;width:100%;padding:.625rem var(--space-md);background:transparent;border:none;border-bottom:1px solid var(--glass-border);color:var(--text-primary);font-size:.875rem;font-family:inherit;text-align:left;cursor:pointer;transition:background var(--transition-base)}.add-hint:last-child{border-bottom:none}.add-hint:active{background:var(--accent-subtle)}.add-note-secondary{margin-top:var(--space-sm)}.add-note-input{width:100%;padding:var(--space-md);background:var(--bg-secondary);border:1.5px solid transparent;border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;font-family:inherit;outline:none;transition:border-color var(--transition-base)}.add-note-input:focus{border-color:var(--accent)}.add-note-input::placeholder{color:var(--text-muted);opacity:.5}.add-error{color:var(--error);font-size:.8125rem;text-align:center;padding:var(--space-md) 0}.add-submit{width:100%;min-height:52px;font-size:1rem;border-radius:var(--radius-lg);margin-top:var(--space-xl)}.add-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--success)}.add-success-icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--success-bg);border:2px solid var(--success);display:flex;align-items:center;justify-content:center;font-size:1.75rem;animation:successPop .4s cubic-bezier(.34,1.56,.64,1)}.add-success-text{font-size:1.25rem;font-weight:600}.expense-item-wrapper{position:relative;overflow:hidden;border-radius:var(--radius-lg)}.expense-item-delete-bg{position:absolute;right:0;top:0;bottom:0;width:80px;background:var(--error);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;border-radius:var(--radius-lg)}.expense-item-swipeable{position:relative;z-index:1;transition:transform .2s ease;touch-action:pan-y}.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3xl)}.dash-register-btn{height:42px;padding:0 1.5rem;border-radius:var(--radius-full);background:var(--accent);border:none;color:#1a1714;font-family:inherit;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.dash-register-btn:active{transform:scale(.95);opacity:.9}.dash-header-left{display:flex;align-items:center;gap:var(--space-sm)}.dash-header-avatar{display:none}.profile-avatar{width:42px;height:42px;border-radius:var(--radius-full);background:var(--bg-secondary);border:2px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;padding:0;transition:border-color var(--transition-base);flex-shrink:0}.profile-avatar:active{border-color:var(--accent);transform:scale(.93)}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{font-size:1.125rem;line-height:1}.crop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;animation:sheetFadeIn .2s ease-out}.crop-modal{background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--glass-border);padding:var(--space-xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);width:calc(100% - 2 * var(--space-xl));max-width:340px}.crop-title{font-family:DM Sans,sans-serif;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.crop-canvas-wrap{border-radius:var(--radius-lg);overflow:hidden;line-height:0}.crop-canvas{display:block;cursor:grab}.crop-canvas:active{cursor:grabbing}.crop-slider{width:100%;accent-color:var(--accent);height:4px}.crop-actions{display:flex;gap:var(--space-sm);width:100%}.crop-btn{flex:1;padding:.75rem;border-radius:var(--radius-lg);font-family:inherit;font-size:.9375rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-base)}.crop-btn:active{transform:scale(.96)}.crop-btn-cancel{background:var(--bg-secondary);color:var(--text-secondary)}.crop-btn-confirm{background:var(--accent-gradient);color:#1a1714}.dash-header-title{font-family:DM Sans,sans-serif;font-size:1.375rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.dash-month-nav{display:flex;align-items:center;gap:var(--space-sm)}.dash-month-label{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.dash-balance{margin-bottom:var(--space-xl)}.dash-balance-label{font-family:DM Sans,sans-serif;font-size:1.25rem;font-weight:500;color:var(--text-primary);margin-bottom:2px}.dash-balance-row{display:flex;align-items:center;gap:var(--space-md)}.dash-balance-amount{font-family:DM Sans,sans-serif;font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.dash-chart-btn{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-secondary);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.dash-chart-btn:active{transform:scale(.9);background:var(--accent-subtle)}.dash-chart-btn svg{width:20px;height:20px;stroke:var(--text-secondary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.month-nav-btn{width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);font-family:inherit}.month-nav-btn:hover{border-color:var(--accent);color:var(--text-accent)}.month-nav-btn:active{transform:scale(.9)}.dash-hero{background:var(--accent-gradient);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-xl) var(--space-lg);margin-bottom:var(--space-lg);text-align:center;position:relative;overflow:hidden;box-shadow:0 8px 32px var(--accent-glow)}.dash-hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.15) 0%,transparent 50%);pointer-events:none}.dash-hero-avatars{display:flex;justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-md);position:relative}.dash-hero-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;font-size:1rem}.dash-hero-amount{font-family:DM Sans,sans-serif;font-size:2.75rem;font-weight:800;color:#1a1714;letter-spacing:-.04em;font-variant-numeric:tabular-nums;position:relative}.dash-hero-subtitle{font-size:.8125rem;color:#1a171499;font-weight:500;margin-bottom:var(--space-lg);position:relative}.dash-hero-bar{height:6px;background:rgba(0,0,0,.15);border-radius:var(--radius-full);overflow:hidden;position:relative}.dash-hero-bar-fill{height:100%;background:rgba(26,23,20,.35);border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1)}.dash-hero-warning{font-size:.75rem;color:#1a1714b3;font-weight:600;margin-top:var(--space-sm);position:relative}.dash-accounts{display:flex;gap:var(--space-md);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;margin-bottom:var(--space-sm)}.dash-accounts::-webkit-scrollbar{display:none}.dash-account-card{flex-shrink:0;width:85%;border-radius:var(--radius-xl);overflow:hidden;scroll-snap-align:start;border:1px solid var(--glass-border)}.dash-account-header{height:56px;background:linear-gradient(135deg,#8bdc6b,#6bc98b);position:relative}.dash-account-header-orange{background:linear-gradient(135deg,#f5a623,#e8913a)}.dash-account-wave{position:absolute;bottom:-1px;left:0;right:0;height:20px;background:var(--bg-secondary);border-radius:50% 50% 0 0/100% 100% 0 0}.dash-account-body{background:var(--bg-secondary);padding:var(--space-lg);padding-top:var(--space-sm)}.dash-account-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.dash-account-name{font-family:DM Sans,sans-serif;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.dash-account-arrow{font-size:1.25rem;color:var(--text-muted)}.dash-account-amount{font-family:DM Sans,sans-serif;font-size:1rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-lg)}.dash-account-details{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.dash-account-line{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--text-secondary)}.dash-account-line span:last-child{font-weight:600;color:var(--text-primary)}.month-nav-btn-sm{width:28px;height:28px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);font-family:inherit}.month-nav-btn-sm:active{transform:scale(.9)}.dash-accounts-dots{display:flex;justify-content:center;gap:6px;margin-bottom:var(--space-xl)}.dash-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--text-muted);opacity:.3;transition:all var(--transition-base)}.dash-dot.active{background:var(--accent);opacity:1}.dash-account-data-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.5rem 1rem;border-radius:var(--radius-full);background:var(--bg-primary);border:1px solid var(--glass-border);color:var(--text-secondary);font-family:inherit;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-sm)}.dash-account-data-btn:active{transform:scale(.95);background:var(--bg-tertiary)}.dash-trend-summary{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-md);margin-top:calc(-1 * var(--space-sm))}.donut-chart{flex-shrink:0}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.donut-center-value{font-family:DM Sans,sans-serif;font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.donut-center-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.donut-segment{animation:donutFadeIn .5s ease-out backwards}@keyframes donutFadeIn{0%{opacity:0}to{opacity:1}}.donut-legend{display:flex;flex-direction:column;gap:var(--space-sm);flex:1;min-width:0}.donut-legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:.8125rem}.donut-legend-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.donut-legend-label{flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.donut-legend-value{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.donut-legend-pct{color:var(--text-muted);font-size:.75rem;width:2.5rem;text-align:right}.spending-trend{overflow:hidden;border-radius:var(--radius-sm)}.trend-bar{animation:trendGrow .4s cubic-bezier(.34,1.56,.64,1) backwards;transform-origin:bottom}@keyframes trendGrow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.budget-details{padding:0}.budget-details>summary{padding:var(--space-lg) var(--space-xl);list-style:none;cursor:pointer}.budget-details>summary::-webkit-details-marker{display:none}.budget-details>summary:after{content:"▾";color:var(--text-muted);transition:transform var(--transition-base)}.budget-details[open]>summary:after{transform:rotate(180deg)}.budget-breakdown{padding:0 var(--space-xl) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm)}.budget-line{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary);padding:var(--space-xs) 0}.budget-line-highlight{color:var(--text-accent);font-weight:600;padding-top:var(--space-sm);margin-top:var(--space-xs);border-top:1px solid var(--border)}.skeleton-loader{display:flex;flex-direction:column;gap:var(--space-lg);padding-top:var(--space-lg)}.skeleton-block{background:linear-gradient(90deg,var(--bg-secondary) 25%,rgba(255,255,255,.03) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}.skeleton-header{height:48px;width:60%}.skeleton-card{height:180px}.skeleton-card-sm{height:100px}.history-summary{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.summary-pill{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-md) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.summary-pill-accent{border-color:#ff8c6b26;background:rgba(255,140,107,.06)}.summary-pill-value{font-family:DM Sans,sans-serif;font-size:1.125rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.summary-pill-accent .summary-pill-value{color:var(--text-accent)}.summary-pill-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.filter-row{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.filter-chips{display:flex;gap:var(--space-xs);overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.filter-chips::-webkit-scrollbar{display:none}.filter-chip{padding:.375rem .75rem;border-radius:var(--radius-full);background:transparent;border:1px solid var(--border);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all var(--transition-base);font-family:inherit}.filter-chip:hover{border-color:#ff8c6b4d}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:var(--bg-base);font-weight:600}.filter-divider{width:1px;background:var(--border);margin:0 var(--space-xs);flex-shrink:0}.date-group{margin-bottom:var(--space-lg)}.date-group-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0;margin-bottom:var(--space-sm)}.date-group-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.date-group-total{font-size:.75rem;font-weight:600;color:var(--text-muted);font-variant-numeric:tabular-nums}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-lg);text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-lg);opacity:.5}.empty-state-text{font-size:.9375rem;color:var(--text-muted);max-width:240px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-lg)}.settings-grid>.settings-field:first-child{grid-column:1 / -1}.settings-field{display:flex;flex-direction:column;gap:var(--space-xs)}.settings-label{font-size:.75rem;font-weight:500;color:var(--text-muted)}.settings-input-wrap{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-base);overflow:hidden}.settings-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.settings-input-prefix{padding:0 0 0 .75rem;color:var(--text-muted);font-size:.875rem;font-weight:500}.settings-input{flex:1;background:transparent;border:none;outline:none;padding:.625rem .75rem;color:var(--text-primary);font-size:1rem;font-family:inherit;font-variant-numeric:tabular-nums;min-width:0}.settings-input::-webkit-outer-spin-button,.settings-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.settings-input[type=number]{-moz-appearance:textfield}.settings-available{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-xl);font-size:.9375rem;color:var(--text-secondary)}.settings-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-2xl)}.settings-action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);font-family:inherit}.settings-action-btn span:first-child{font-size:1.5rem}.settings-action-btn:hover{border-color:var(--accent);color:var(--text-accent)}.settings-action-btn:active{transform:scale(.97)}.settings-action-danger:hover{border-color:var(--error);color:var(--error)}.settings-footer{text-align:center;padding:var(--space-xl) 0;font-size:.75rem;color:var(--text-muted);display:flex;flex-direction:column;gap:var(--space-xs)}.toast{position:fixed;top:var(--space-xl);left:50%;transform:translate(-50%);padding:.625rem 1.25rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;z-index:200;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg)}.toast-success{background:rgba(166,199,156,.15);border:1px solid rgba(166,199,156,.3);color:var(--success)}.toast-error{background:rgba(232,124,124,.15);border:1px solid rgba(232,124,124,.3);color:var(--error)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-10px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}
