:root{--color-primary:#407088;--color-primary-light:#5a8fa8;--color-primary-lighter:#d0e4ed;--color-primary-dark:#2d5060;--color-primary-bg:#edf4f7;--color-bg:#f0f2f5;--color-surface:#fff;--color-surface-hover:#e8ebf0;--color-surface-variant:#e4e8ed;--color-border:#d0d5dd;--color-border-light:#e0e4ea;--color-text:#131a26;--color-text-secondary:#556070;--color-text-muted:#7d8a9a;--color-text-inverse:#fff;--color-success:#2d8a6a;--color-success-bg:#d5f0e5;--color-warning:#c4842a;--color-warning-bg:#fae8d0;--color-danger:#c75b5b;--color-danger-bg:#f8d8d8;--color-info:#4a7db8;--color-info-bg:#d8e6f5;--font-family:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.125rem;--text-xl:1.3125rem;--text-2xl:1.625rem;--text-3xl:2rem;--text-4xl:2.75rem;--text-5xl:3.5rem;--text-massive:4.5rem;--font-light:300;--font-regular:400;--font-medium:500;--font-semibold:600;--font-bold:700;--font-extrabold:800;--leading-tight:1.1;--leading-snug:1.25;--leading-normal:1.5;--leading-relaxed:1.7;--tracking-tight:-.025em;--tracking-normal:0;--tracking-wide:.025em;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px #1a23320a;--shadow-sm:0 2px 8px #1a23320f;--shadow-md:0 4px 16px #1a233214;--shadow-lg:0 8px 32px #1a23321a;--shadow-xl:0 16px 48px #1a23321f;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--nav-height:72px;--safe-area-bottom:env(safe-area-inset-bottom,0px);--container-padding:var(--space-5)}[data-theme=dark]{--color-bg:#111822;--color-surface:#1a2332;--color-surface-hover:#232f41;--color-surface-variant:#1e2a3a;--color-border:#2a374a;--color-border-light:#222d3d;--color-text:#f0f2f5;--color-text-secondary:#9aa8b8;--color-text-muted:#6b7a8d;--color-text-inverse:#1a2332;--color-primary-bg:#1c2b36;--color-success:#3a9d7c;--color-success-bg:#162c23;--color-warning:#d4943a;--color-warning-bg:#302213;--color-danger:#c75b5b;--color-danger-bg:#2d1717;--color-info:#5b8ec7;--color-info-bg:#1b2636}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:16px}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-regular);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit;background:0 0;border:none;outline:none}ul,ol{list-style:none}img,svg{max-width:100%;display:block}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.page-content{padding-bottom:calc(var(--safe-area-bottom) + var(--space-4));-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-overlay{-webkit-backdrop-filter:blur(10px);z-index:9999;background:#000000d9;justify-content:center;align-items:center;padding:24px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.3}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.amount-container{white-space:nowrap;align-items:baseline;display:inline-flex}.amount-currency{opacity:.5;text-transform:uppercase;letter-spacing:.05em;margin-right:.3em;font-size:.65em;font-weight:600}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.suggestion-dropdown{border:1.5px solid var(--color-border);z-index:9999;background:#111822;border-radius:18px;margin-top:4px;animation:.2s ease-out slideDown;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 12px 40px #0009}.suggestion-item{text-align:left;color:#fff;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #ffffff0a;align-items:center;gap:12px;width:100%;padding:16px 20px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.suggestion-item:active{background:#ffffff14;transform:scale(.99)}.suggestion-item:last-child{border-bottom:none}.bottom-nav{height:var(--nav-height);background:var(--color-surface);border-top:1px solid var(--color-border-light);padding-bottom:var(--safe-area-bottom);z-index:100;-webkit-backdrop-filter:blur(20px);background:#ffffffeb;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.nav-item span{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.nav-item.active span{color:var(--color-primary);font-weight:var(--font-semibold)}.nav-item.active svg{color:var(--color-primary)}.nav-item svg{color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.nav-item-center{justify-content:center;align-items:center;display:flex;position:relative}.nav-item-center-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));width:56px;height:56px;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;margin-top:-20px;display:flex;box-shadow:0 4px 20px #40708859}.nav-item-center-btn:active{transform:scale(.92);box-shadow:0 2px 12px #40708840}.nav-item-center-btn svg{color:#fff}.numpad-display{text-align:center;padding:var(--space-8) var(--space-5) var(--space-4)}.numpad-display-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;margin-bottom:var(--space-2)}.numpad-display-amount{font-size:var(--text-5xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);font-variant-numeric:tabular-nums;transition:transform var(--duration-fast) var(--ease-spring)}.numpad-display-amount.pulse{animation:pulse var(--duration-normal) var(--ease-spring)}.numpad-display-currency{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-right:var(--space-2)}.numpad-grid{gap:var(--space-2);padding:var(--space-3) var(--space-4);grid-template-columns:repeat(3,1fr);max-width:380px;margin:0 auto;display:grid}.numpad-key{border-radius:var(--radius-lg);height:64px;font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-text);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border:1px solid var(--color-border-light);justify-content:center;align-items:center;display:flex}.numpad-key:active{background:var(--color-primary-lighter);border-color:var(--color-primary-light);transform:scale(.95)}.numpad-key--action{background:var(--color-bg);color:var(--color-text-secondary)}.numpad-key--action:active{background:var(--color-primary-lighter)}.category-picker{padding:var(--space-3) var(--space-4) var(--space-2)}.category-input-wrapper{position:relative}.category-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);transition:border-color var(--duration-fast) var(--ease-out)}.category-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4070881a}.category-input::placeholder{color:var(--color-text-muted)}.category-chips{gap:var(--space-2);padding:var(--space-3) 0 var(--space-1);flex-wrap:wrap;display:flex}.category-chip{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);border:1.5px solid var(--color-border);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;white-space:nowrap;display:flex}.category-chip:active{transform:scale(.95)}.category-chip.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.category-chip-icon{font-size:var(--text-base)}.category-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;margin-top:var(--space-1);max-height:200px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.category-dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-base);transition:background var(--duration-fast);cursor:pointer;display:flex}.category-dropdown-item:hover,.category-dropdown-item:active{background:var(--color-primary-bg)}.card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-xs);border:1px solid var(--color-border-light)}.card-hero{color:#fff;background:linear-gradient(135deg,#000,#2c3e50);border:none;box-shadow:0 8px 32px #00000040}.card-hero .card-label{color:#ffffffbf}.card-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.card-amount{font-size:var(--text-4xl);font-weight:var(--font-extrabold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);font-variant-numeric:tabular-nums}.card-amount-sm{font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);font-variant-numeric:tabular-nums}.transaction-list{gap:var(--space-1);flex-direction:column;display:flex}.transaction-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);transition:background var(--duration-fast);-webkit-tap-highlight-color:transparent;display:flex}.transaction-item:active{background:var(--color-surface-hover)}.transaction-icon{border-radius:var(--radius-md);width:44px;height:44px;font-size:var(--text-xl);flex-shrink:0;justify-content:center;align-items:center;display:flex}.transaction-details{flex:1;min-width:0}.transaction-category{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text)}.transaction-note{font-size:var(--text-sm);color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.transaction-amount{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);font-variant-numeric:tabular-nums;text-align:right;flex-shrink:0}.transaction-date{font-size:var(--text-xs);color:var(--color-text-muted);text-align:right}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;white-space:nowrap;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;border:none;box-shadow:0 8px 24px #4070884d}.btn-primary:active{transform:scale(.96);box-shadow:0 4px 12px #40708833}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:active{background:var(--color-surface-hover);transform:scale(.96)}.btn-ghost{color:var(--color-primary);background:0 0}.btn-danger{background:var(--color-danger);color:#fff}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-xl)}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-md);width:48px;height:48px;padding:0}.btn-icon-round{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding:0;display:flex}.btn-icon-round:active{background:var(--color-primary-bg);border-color:var(--color-primary-light)}.action-toolbar{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-4);display:flex}.section-header{padding:var(--space-5) var(--space-5) var(--space-3);justify-content:space-between;align-items:center;display:flex}.section-title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.section-action{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary)}.page-header{padding:var(--space-6) var(--space-5) var(--space-2)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.category-suggestion-menu{-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-xl);z-index:200;animation:slideUp .3s var(--ease-spring);background:#fffffff2;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:hidden;box-shadow:0 15px 35px #00000026}.category-suggestion-item{text-align:left;cursor:pointer;width:100%;color:var(--color-text);background:0 0;border:none;align-items:center;gap:12px;padding:14px 18px;font-size:15px;font-weight:500;transition:all .2s;display:flex}.category-suggestion-item:active,.category-suggestion-item:hover{background:var(--color-primary-bg);color:var(--color-primary)}.category-suggestion-item .icon-wrapper{background:var(--color-bg);width:32px;height:32px;color:var(--color-primary);border-radius:8px;justify-content:center;align-items:center;display:flex}.filter-tabs{gap:var(--space-2);padding:var(--space-2) var(--space-5);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);background:var(--color-surface);border:1.5px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;-webkit-tap-highlight-color:transparent}.filter-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.filter-tab:active{transform:scale(.95)}.sheet-backdrop{z-index:200;animation:fadeIn var(--duration-normal) var(--ease-out);-webkit-tap-highlight-color:transparent;background:#0000004d;position:fixed;inset:0}.sheet{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;z-index:201;padding:var(--space-4) var(--space-5) calc(var(--space-8) + var(--safe-area-bottom));animation:slideUp var(--duration-slow) var(--ease-out);max-height:80vh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.sheet-handle{background:var(--color-border);border-radius:var(--radius-full);width:36px;height:4px;margin:0 auto var(--space-5)}.sheet-title{font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-4)}.splash-dialog{background:var(--color-surface);border-radius:var(--radius-3xl);z-index:1001;width:calc(100% - 40px);max-width:380px;padding:var(--space-8) var(--space-6);animation:splashIn .4s var(--ease-spring);border:1px solid var(--color-border-light);gap:var(--space-4);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 25px 70px #00000059}.splash-close-btn{background:var(--color-bg);border:1px solid var(--color-border-light);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);z-index:10;-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.splash-close-btn:hover{background:var(--color-surface-hover);color:var(--color-text);transform:rotate(90deg)}.splash-close-btn:active{transform:scale(.9)rotate(90deg)}@keyframes splashIn{0%{opacity:0;transform:translate(-50%,-45%)scale(.92)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.splash-icon{background:var(--color-primary-bg);width:64px;height:64px;color:var(--color-primary);margin:0 auto var(--space-2);border-radius:50%;justify-content:center;align-items:center;display:flex}.splash-title{font-size:var(--text-2xl);text-align:center;color:var(--color-text);margin:0;font-weight:800}.splash-description{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;max-width:280px;margin:0 auto;line-height:1.5}.form-group{margin-bottom:var(--space-5)}.form-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:var(--tracking-wide);display:block}.form-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text);transition:border-color var(--duration-fast) var(--ease-out)}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4070881a}.form-select{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text);appearance:none;cursor:pointer}.liquidity-bar-wrapper{padding:var(--space-3) 0}.liquidity-bar-bg{background:var(--color-border-light);border-radius:var(--radius-full);height:8px;overflow:hidden}.liquidity-bar-fill{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--color-primary-light), var(--color-primary));height:100%;transition:width var(--duration-slow) var(--ease-out)}.liquidity-labels{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);justify-content:space-between;display:flex}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-4);opacity:.6;font-size:3rem}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-state-text{font-size:var(--text-sm);color:var(--color-text-muted);max-width:260px}.payment-badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);background:var(--color-bg);color:var(--color-text-secondary);display:inline-flex}.settings-list{flex-direction:column;display:flex}.settings-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;background:0 0;width:100%;display:flex}.settings-item:last-child{border-bottom:none}.settings-item:active{background:var(--color-surface-hover)}@media (hover:hover){.settings-item:hover{background:var(--color-surface-hover)}}.settings-icon{width:44px;height:44px;box-shadow:var(--shadow-xs);transition:transform var(--duration-fast) var(--ease-out);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-item:active .settings-icon{transform:scale(.92)}.settings-content{text-align:left;flex:1}.settings-label{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);line-height:1.2}.settings-description{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.settings-value{font-size:var(--text-sm);font-weight:var(--font-extrabold);color:var(--color-primary);background:var(--color-primary-bg);border-radius:var(--radius-sm);padding:2px 8px}.settings-section-header{padding:var(--space-4) var(--container-padding) var(--space-2);align-items:center;gap:var(--space-2);display:flex}.settings-section-title{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:800}.settings-card{background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);margin-bottom:var(--space-4);overflow:hidden}.success-overlay{z-index:300;animation:fadeIn var(--duration-fast) var(--ease-out);background:#fffffff2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.success-content{text-align:center;animation:scaleIn var(--duration-normal) var(--ease-spring)}.success-icon{background:var(--color-success-bg);width:80px;height:80px;margin:0 auto var(--space-4);border-radius:50%;justify-content:center;align-items:center;display:flex}.success-text{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.success-subtext{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.stats-grid{gap:var(--space-3);padding:var(--space-2) var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border-light)}.stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);font-variant-numeric:tabular-nums}.stat-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium);margin-top:var(--space-1)}.bill-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border-light);display:flex}.bill-info{flex:1}.bill-name{font-size:var(--text-base);font-weight:var(--font-semibold)}.bill-due{font-size:var(--text-xs);color:var(--color-text-muted)}.bill-amount{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-danger);font-variant-numeric:tabular-nums}.savings-card{background:linear-gradient(135deg, var(--color-success-bg), var(--color-surface));border-radius:var(--radius-xl);padding:var(--space-5);border:1px solid #3a9d7c26}.savings-emoji{margin-bottom:var(--space-3);font-size:2rem}.savings-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.savings-amount{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-success)}.savings-description{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2);line-height:var(--leading-relaxed)}.speech-indicator{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-danger-bg);border-radius:var(--radius-lg);margin:var(--space-2) var(--space-4);display:flex}.speech-dot{background:var(--color-danger);border-radius:50%;width:10px;height:10px;animation:1s ease-in-out infinite pulse}.speech-text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);flex:1}.chart-container{padding:var(--space-3) var(--space-5)}.chart-wrapper{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-4);border:1px solid var(--color-border-light)}.dashboard-big-card{align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-xl);border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;text-align:left;cursor:pointer;width:100%;display:flex}.dashboard-big-card:active{box-shadow:var(--shadow-xs);border-color:var(--color-border);transform:scale(.98)}.dashboard-big-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.dashboard-big-card-content{flex:1;padding:4px 0}.card-plus-btn{background:var(--color-surface);width:50px;height:50px;color:var(--color-primary);border:1px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out);z-index:20;cursor:pointer;border-radius:16px;justify-content:center;align-items:center;display:flex;position:absolute;bottom:18px;right:18px;box-shadow:0 4px 12px #0000000d}.card-plus-btn:active{background:var(--color-primary-bg);transform:scale(.9)}.card-plus-btn svg{stroke-width:2.5px}.dashboard-big-card-content{flex:1;min-width:0}.dashboard-big-card-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:2px}.dashboard-big-card-amount{font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);font-variant-numeric:tabular-nums}.dashboard-big-card-sub{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.dashboard-big-card-arrow{opacity:.4;flex-shrink:0}.slide-menu-trigger{border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);width:44px;height:44px;color:var(--color-text-primary);transition:all .2s var(--ease-out);cursor:pointer;justify-content:center;align-items:center;display:flex}.floating-menu-container .slide-menu-trigger{color:#fff!important;background:0 0!important;border-color:#0000!important}.slide-menu-trigger:active{background:var(--color-primary-bg);transform:scale(.93)}.slide-menu-backdrop{-webkit-backdrop-filter:blur(4px);z-index:500;animation:fadeIn var(--duration-normal) var(--ease-out);background:#00000059;position:fixed;inset:0}.slide-menu-panel{background:var(--color-surface);z-index:501;width:300px;max-width:85vw;transition:transform var(--duration-slow) var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-8px 0 32px #0000001a}.slide-menu-panel.open{transform:translate(0)}.slide-menu-header{padding:var(--space-6) var(--space-5) var(--space-4);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.slide-menu-brand{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-primary)}.slide-menu-brand-sub{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium)}.slide-menu-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.slide-menu-item{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-4);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;text-align:left;width:100%;display:flex}.slide-menu-item:active{background:var(--color-surface-hover);transform:scale(.97)}.slide-menu-item.active{background:var(--color-primary-bg)}.slide-menu-item.active .slide-menu-item-label{color:var(--color-primary);font-weight:var(--font-semibold)}.slide-menu-item-icon{border-radius:var(--radius-md);background:var(--color-bg);width:40px;height:40px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.slide-menu-item-icon.highlight{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff}.slide-menu-item-label{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);flex:1}.slide-menu-item-arrow{color:var(--color-text-muted);opacity:.4}.slide-menu-footer{padding:var(--space-5);border-top:1px solid var(--color-border-light);text-align:center}.dashboard-fullscreen{background:var(--color-bg);flex-direction:column;min-height:100dvh;display:flex}.dashboard-hero-surface{color:#fff;padding-bottom:var(--space-6);padding-top:var(--safe-area-top);border-bottom-left-radius:var(--radius-3xl);border-bottom-right-radius:var(--radius-3xl);margin-bottom:var(--space-4);z-index:10;background:linear-gradient(135deg,#000 0%,#343a40 100%);flex-shrink:0;box-shadow:0 12px 40px #0000004d}.dashboard-hero-surface .slide-menu-trigger{color:#fff;background:#ffffff26;border-color:#0000}.dashboard-hero-surface .slide-menu-trigger:active{background:#ffffff40}.dashboard-header{padding:var(--space-5) var(--space-5);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.dashboard-hero-label{font-size:var(--text-sm);font-weight:var(--font-medium);opacity:.75;text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-1)}.dashboard-hero-amount{font-size:var(--text-4xl);font-weight:var(--font-extrabold);letter-spacing:normal;line-height:var(--leading-tight);font-variant-numeric:tabular-nums;margin-bottom:var(--space-4)}.dashboard-hero-stats{align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.dashboard-hero-stat{align-items:center;gap:var(--space-2);flex:1;display:flex}.dashboard-hero-stat-label{font-size:var(--text-xs);opacity:.7;font-weight:var(--font-medium)}.dashboard-hero-stat-value{font-size:var(--text-base);font-weight:var(--font-bold);font-variant-numeric:tabular-nums}.dashboard-hero-divider{background:#fff3;width:1px;height:32px}.dashboard-hero-bar-wrapper{margin-top:var(--space-1)}.dashboard-hero-bar-bg{border-radius:var(--radius-full);background:#ffffff26;height:6px;overflow:hidden}.dashboard-hero-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-out)}.dashboard-hero-bar-label{font-size:var(--text-xs);opacity:.6;margin-top:var(--space-1);text-align:right}.dashboard-cards{gap:var(--space-3);padding:0 var(--space-5);flex-direction:column;padding-bottom:120px;display:flex}.dashboard-cards .dashboard-big-card{height:140px;padding:var(--space-5);text-align:left;flex-direction:column;flex:none;justify-content:flex-start;align-items:stretch;display:flex;position:relative;overflow:hidden}.input-group{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.input-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wide);padding-left:var(--space-1);font-weight:600}.input-field{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);width:100%;height:52px;padding:0 var(--space-4);font-size:var(--text-base);color:var(--color-text);transition:all var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-xs)}.input-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #4070881a, var(--shadow-sm);background:var(--color-surface)}.input-field::placeholder{color:var(--color-text-muted)}.hero-glass{-webkit-backdrop-filter:blur(12px);background:#ffffff1a;border:1px solid #fff3}.spinner{border:4px solid #4070881a;border-left-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite rotate}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.switch{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--color-border);border-radius:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0000001a}input:checked+.slider{background-color:var(--color-success)}input:checked+.slider:before{transform:translate(20px)}
