@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-brand: #6C63FF;--color-brand-dark: #5A52D5;--color-brand-light: #8B85FF;--color-brand-subtle: rgba(108, 99, 255, .15);--color-accent: #6C63FF;--color-accent-subtle: rgba(108, 99, 255, .1);--color-surface: #0a0a0a;--color-surface-raised: #121212;--color-surface-overlay: #1a1a1a;--color-surface-composer: #121212;--color-border: rgba(255, 255, 255, .08);--color-border-strong: rgba(255, 255, 255, .15);--color-text-primary: #FFFFFE;--color-text-secondary: #A8B2D0;--color-text-tertiary: #6E6E80;--color-text-inverse: #0a0a0a;--color-success: #22C55E;--color-success-subtle: rgba(34, 197, 94, .15);--color-error: #EF4444;--color-error-subtle: rgba(239, 68, 68, .15);--color-warning: #F59E0B;--color-warning-subtle: rgba(245, 158, 11, .15);--color-food: #F59E0B;--color-food-subtle: rgba(245, 158, 11, .15);--color-transport: #3B82F6;--color-transport-subtle: rgba(59, 130, 246, .15);--color-shopping: #EC4899;--color-shopping-subtle: rgba(236, 72, 153, .15);--color-entertainment: #8B5CF6;--color-entertainment-subtle: rgba(139, 92, 246, .15);--color-health: #22C55E;--color-health-subtle: rgba(34, 197, 94, .15);--color-utility: #6B7280;--color-utility-subtle: rgba(107, 114, 128, .15);--color-education: #06B6D4;--color-education-subtle: rgba(6, 182, 212, .15);--color-other: #64748B;--color-other-subtle: rgba(100, 116, 139, .15);--topbar-height: 56px;--nav-height-mobile: 64px;--sidebar-width: 260px;--content-max-mobile: 100%;--content-max-desktop: 960px;--chat-max-width: 960px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4);--shadow-brand: 0 2px 8px rgba(108, 99, 255, .2);--shadow-composer: 0 0 0 1px rgba(255, 255, 255, .05), 0 4px 16px rgba(0, 0, 0, .4);--shadow-composer-focus: 0 0 0 1px rgba(108, 99, 255, .3), 0 8px 28px rgba(108, 99, 255, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-composer: 26px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;height:100dvh}body{margin:0;padding:0;background-color:var(--color-surface);color:var(--color-text-primary);min-height:100dvh;overscroll-behavior:none;letter-spacing:-.01em}.text-page-title{font-size:20px;font-weight:600;line-height:1.3;color:var(--color-text-primary)}.text-section-heading{font-size:16px;font-weight:600;line-height:1.4;color:var(--color-text-primary)}.text-body{font-size:14px;font-weight:400;line-height:1.5;color:var(--color-text-primary)}.text-caption{font-size:12px;font-weight:400;line-height:1.4;color:var(--color-text-secondary)}.text-amount{font-size:24px;font-weight:700;line-height:1.2}:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:2px}input,textarea,select{font-size:16px!important;font-family:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}.mobile-only{display:block}.desktop-only,.desktop-only-flex,.desktop-only-block{display:none}@media(min-width:768px){.mobile-only{display:none}.desktop-only,.desktop-only-block{display:block}.desktop-only-flex{display:flex}}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}.container-app{width:100%;max-width:100%;margin:0 auto;padding:0 16px}.chat-layout{width:100%;max-width:var(--chat-max-width);margin:0 auto}@media(min-width:768px){.container-app{padding:0 40px;max-width:min(var(--content-max-desktop),100%);margin-left:0;margin-right:auto}}.app-shell{display:flex;min-height:100dvh;background:var(--color-surface)}.app-shell-body{display:flex;flex-direction:column;flex:1;min-width:0;min-height:100dvh}.app-main{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;padding-top:calc(var(--topbar-height) + var(--safe-top));padding-bottom:calc(var(--nav-height-mobile) + var(--safe-bottom))}.app-main-inner{padding-top:20px;padding-bottom:28px}@media(min-width:768px){.app-shell-body{margin-left:var(--sidebar-width)}.app-main{padding-top:0;padding-bottom:0}.app-main-inner{padding-top:32px;padding-bottom:40px}}.app-logo{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:0}.app-logo-mark{background:var(--color-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-logo-wordmark{font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px;white-space:nowrap}.topbar-hamburger-btn{background:none;border:none;cursor:pointer;color:var(--color-text-primary);padding:8px;margin-left:-8px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent}.topbar-hamburger-btn:hover{background:var(--color-surface-overlay)}.app-topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:12px;height:calc(var(--topbar-height) + var(--safe-top));padding:var(--safe-top) 16px 0;background:color-mix(in srgb,var(--color-surface) 88%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}@media(min-width:768px){.app-topbar{display:none}}.app-topbar-title{margin:0;font-size:17px;font-weight:600;color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-topbar-actions{flex-shrink:0;display:flex;align-items:center}.page-title-desktop-only{display:none}@media(min-width:768px){.page-title-desktop-only{display:block}}.pb-safe{padding-bottom:calc(var(--nav-height-mobile) + var(--safe-bottom))}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes micPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.animate-slide-up{animation:slideUp var(--transition-slow) forwards}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.skeleton{background:linear-gradient(90deg,var(--color-surface-overlay) 25%,var(--color-border) 50%,var(--color-surface-overlay) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height-mobile) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:color-mix(in srgb,var(--color-surface) 90%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--color-border);display:flex;align-items:stretch;z-index:50;box-shadow:0 -4px 20px #0000000f}@media(min-width:768px){.bottom-nav{display:none}}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:44px;padding:6px 4px 4px;color:var(--color-text-tertiary);text-decoration:none;border:none;background:none;cursor:pointer;font-family:inherit;position:relative;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-nav-item--active{color:var(--color-text-primary)}.bottom-nav-item--disabled{cursor:not-allowed;color:var(--color-border-strong)}.bottom-nav-label{font-size:10px;font-weight:500;letter-spacing:.02em}.bottom-nav-item--active .bottom-nav-label{font-weight:600}.bottom-nav-badge{position:absolute;top:6px;right:18%;background:var(--color-brand-subtle);color:var(--color-brand);font-size:9px;font-weight:700;padding:1px 5px;border-radius:var(--radius-full);line-height:1.4}.sidebar{display:none;width:var(--sidebar-width);position:fixed;top:0;left:0;bottom:0;flex-direction:column;background:var(--color-surface);border-right:1px solid var(--color-border);z-index:60;overflow-y:auto}@media(min-width:768px){.sidebar{display:flex}}.sidebar-header{padding:20px;border-bottom:1px solid var(--color-border)}.sidebar-nav{padding:12px 10px;flex:1;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:400;border:none;background:transparent;cursor:pointer;font-family:inherit;width:100%;text-align:left;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-nav-item:hover:not(.sidebar-nav-item--disabled):not(:disabled){background:var(--color-surface-overlay);color:var(--color-text-primary)}.sidebar-nav-item--active{color:var(--color-text-primary);background:var(--color-surface-overlay);font-weight:600}.sidebar-nav-item--disabled{cursor:not-allowed;color:var(--color-border-strong)}.sidebar-nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-nav-badge{margin-left:auto;background:var(--color-brand-subtle);color:var(--color-brand);font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full)}.sidebar-footer{padding:12px 10px 16px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:4px}.sidebar-account{display:flex;align-items:center;gap:10px;padding:8px 12px;font-size:13px;color:var(--color-text-secondary);font-weight:500}.sidebar-signout-btn:hover{background:var(--color-error-subtle);color:var(--color-error)}.card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;min-width:44px;padding:10px 20px;border:none;border-radius:var(--radius-full);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-brand);color:var(--color-text-inverse);box-shadow:none}.btn-primary:hover:not(:disabled){background:var(--color-brand-dark);transform:none;box-shadow:none}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:var(--color-surface-overlay);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-overlay);color:var(--color-text-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.form-textarea{width:100%;border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:14px 16px;font-size:16px;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);resize:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);line-height:1.6}.form-textarea:focus{outline:none;border-color:var(--color-brand);box-shadow:0 0 0 3px #6c63ff26}.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-input{width:100%;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:16px;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-border-strong);box-shadow:0 0 0 3px #0000000f}.ai-composer{position:relative;margin-bottom:28px}.ai-composer-box{display:flex;align-items:flex-end;gap:8px;padding:12px 12px 12px 18px;background:var(--color-surface-composer);border:1px solid var(--color-border);border-radius:var(--radius-composer);box-shadow:var(--shadow-composer);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.ai-composer-box:focus-within{border-color:var(--color-border-strong);box-shadow:var(--shadow-composer-focus)}.ai-composer-input{flex:1;min-height:24px;max-height:200px;padding:6px 0;border:none;background:transparent;resize:none;font-size:16px;line-height:1.5;color:var(--color-text-primary);font-family:inherit}.ai-composer-input:focus{outline:none;box-shadow:none}.ai-composer-input::placeholder{color:var(--color-text-tertiary)}.ai-composer-send{flex-shrink:0;width:36px;height:36px;border:none;border-radius:50%;background:var(--color-brand);color:var(--color-text-inverse);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),opacity var(--transition-fast),transform var(--transition-fast);-webkit-tap-highlight-color:transparent}.ai-composer-mic{flex-shrink:0;width:36px;height:36px;border:1px solid var(--color-border);border-radius:50%;background:var(--color-surface-overlay);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);-webkit-tap-highlight-color:transparent}.ai-composer-mic:hover:not(:disabled){border-color:var(--color-border-strong);color:var(--color-text-primary)}.ai-composer-mic:disabled{cursor:not-allowed;opacity:.5}.ai-composer-mic--listening{background:var(--color-error-subtle);border-color:#ef444473;color:var(--color-error);animation:micPulse 1.3s ease-in-out infinite}.ai-composer-mic-dot{width:11px;height:11px;border-radius:50%;background:currentColor;box-shadow:0 0 0 5px #ef44441f}.ai-composer-send:hover:not(:disabled){background:var(--color-brand-dark)}.ai-composer-send:disabled{background:var(--color-border);cursor:not-allowed;opacity:.9}.ai-composer-hint{margin:10px 4px 0;font-size:12px;color:var(--color-text-tertiary);text-align:center;transition:text-align var(--transition-fast)}@media(min-width:768px){.ai-composer-hint{text-align:left;margin-left:12px}}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px;transition:justify-content var(--transition-fast)}@media(min-width:768px){.ai-suggestions{justify-content:flex-start}}.ai-suggestion-chip{padding:8px 14px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);-webkit-tap-highlight-color:transparent}.ai-suggestion-chip:hover{background:var(--color-surface-overlay);border-color:var(--color-border-strong);color:var(--color-text-primary)}.expenses-hero{text-align:center;padding:8px 0 24px;transition:text-align var(--transition-fast),padding var(--transition-fast)}@media(min-width:768px){.expenses-hero{text-align:left;padding:16px 0 32px}}.expenses-hero-title{margin:0 0 6px;font-size:22px;font-weight:600;letter-spacing:-.03em;color:var(--color-text-primary)}.expenses-hero-sub{margin:0;font-size:15px;color:var(--color-text-secondary);line-height:1.5}.expenses-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:8px 0 24px;border-bottom:1px solid var(--color-border);margin-bottom:24px}.expenses-stat-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px 20px;display:flex;flex-direction:column;gap:6px;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.expenses-stat-card:hover{transform:translateY(-2px);border-color:var(--color-brand);box-shadow:var(--shadow-md)}.expenses-stat-label{margin:0;font-size:12px;color:var(--color-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.expenses-stat-value{margin:0;font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--color-text-primary)}.expenses-section-label{margin:0 0 12px;font-size:13px;font-weight:500;color:var(--color-text-tertiary)}.filter-chip{padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:13px;font-family:inherit;font-weight:400;cursor:pointer;min-height:32px;white-space:nowrap;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.filter-chip:hover{background:var(--color-surface-overlay)}.filter-chip--active{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-text-inverse);font-weight:500}.expense-list{display:flex;flex-direction:column}.expense-row{display:flex;align-items:center;gap:14px;padding:14px 4px;border-bottom:1px solid var(--color-border);animation:fadeIn .2s ease forwards;position:relative}.expense-row:last-child{border-bottom:none}.expense-row-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.expense-row-body{flex:1;min-width:0}.expense-row-title{margin:0 0 4px;font-size:15px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-row-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.expense-row-amount{font-size:15px;font-weight:600;color:var(--color-text-primary);flex-shrink:0;font-variant-numeric:tabular-nums}.expense-row-menu-btn{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.expense-row-menu-btn:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.empty-state-icon{width:48px;height:48px;border-radius:12px;background:var(--color-surface-overlay);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--color-text-tertiary)}.empty-state-title{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--color-text-primary)}.empty-state-desc{margin:0;font-size:14px;color:var(--color-text-tertiary);max-width:280px;line-height:1.55}
