:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-card: rgba(30, 30, 55, .7);--bg-card-solid: #1e1e37;--bg-elevated: rgba(40, 40, 70, .6);--bg-input: rgba(255, 255, 255, .06);--bg-hover: rgba(255, 255, 255, .08);--text-primary: #f0f0f5;--text-secondary: #a0a0b8;--text-tertiary: #6b6b85;--text-inverse: #0f0f1a;--border-color: rgba(255, 255, 255, .08);--border-active: rgba(255, 255, 255, .2);--border-glass: rgba(255, 255, 255, .12);--accent-primary: #7c5cfc;--accent-primary-hover: #6a4ae8;--accent-primary-glow: rgba(124, 92, 252, .3);--accent-secondary: #9333ea;--accent-success: #10B981;--accent-danger: #ef4444;--accent-danger-hover: #dc2626;--accent-warning: #F59E0B;--danger: var(--accent-danger);--warning: var(--accent-warning);--card-bg: var(--bg-card);--glass-blur: 16px;--glass-bg: rgba(30, 30, 55, .65);--glass-border: rgba(255, 255, 255, .1);--cat-food: #FF6B6B;--cat-transport: #4ECDC4;--cat-shopping: #A78BFA;--cat-bills: #F59E0B;--cat-entertainment: #EC4899;--cat-health: #10B981;--cat-education: #6366F1;--cat-other: #94A3B8;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .6875rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-hero: 3rem;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.1;--line-height-normal: 1.5;--line-height-relaxed: 1.7;--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-primary-glow);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.175, .885, .32, 1.275);--nav-height: 64px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--content-max-width: 480px}[data-theme=light]{--bg-primary: #f5f5fa;--bg-secondary: #eeeef5;--bg-card: rgba(255, 255, 255, .85);--bg-card-solid: #ffffff;--bg-elevated: rgba(255, 255, 255, .9);--bg-input: rgba(0, 0, 0, .04);--bg-hover: rgba(0, 0, 0, .05);--text-primary: #1a1a2e;--text-secondary: #555570;--text-tertiary: #8888a0;--text-inverse: #f0f0f5;--border-color: rgba(0, 0, 0, .08);--border-active: rgba(0, 0, 0, .15);--border-glass: rgba(0, 0, 0, .06);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(0, 0, 0, .08);--danger: var(--accent-danger);--warning: var(--accent-warning);--card-bg: var(--bg-card);--accent-secondary: #7c3aed;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--text-primary);background:var(--bg-primary);min-height:100dvh;overflow-x:hidden;overscroll-behavior:none}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.glass-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-lg);box-shadow:var(--shadow-md)}.glass-card-subtle{background:var(--bg-card);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-color);border-radius:var(--radius-md)}.gradient-border{position:relative}.gradient-border:before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#7c5cfc4d,#ec489933,#4ecdc433);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.page-container{flex:1;padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--safe-area-bottom) + var(--space-xl));max-width:var(--content-max-width);margin:0 auto;width:100%}.page-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-lg);letter-spacing:-.02em}.section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:var(--space-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);transition:all var(--transition-base);min-height:44px;min-width:44px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{background:var(--accent-primary-hover)}.btn-primary:active{transform:scale(.97)}.btn-ghost{background:var(--bg-input);color:var(--text-primary)}.btn-ghost:hover{background:var(--bg-hover)}.btn-danger{background:var(--accent-danger);color:#fff}.btn-danger:hover{background:var(--accent-danger-hover)}.chip{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:var(--bg-input);color:var(--text-secondary);border:1px solid transparent;transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;white-space:nowrap;min-height:36px}.chip:hover{background:var(--bg-hover)}.chip.active{background:var(--accent-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-glow)}.input-field{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md);transition:border-color var(--transition-fast);outline:none;min-height:48px}.input-field::placeholder{color:var(--text-tertiary)}.input-field:focus{border-color:var(--accent-primary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideOutBottom{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}@keyframes checkmark{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) both}.animate-fade-in{animation:fadeIn var(--transition-base) both}.animate-scale-in{animation:scaleIn var(--transition-spring) both}.animate-shake{animation:shake .4s ease-in-out}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.stagger-children>*:nth-child(7){animation-delay:.3s}.stagger-children>*:nth-child(8){animation-delay:.35s}.skeleton{background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-hover) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn var(--transition-fast) both}.modal-content{background:var(--bg-card-solid);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:var(--content-max-width);max-height:90dvh;overflow-y:auto;animation:slideInBottom var(--transition-base) both;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + var(--safe-area-bottom))}.react-datepicker-wrapper{width:100%}.react-datepicker__input-container input{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);min-height:44px;outline:none}.react-datepicker__input-container input:focus{border-color:var(--accent-primary)}.react-datepicker{font-family:var(--font-family)!important;background:var(--bg-card-solid)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.react-datepicker__header{background:var(--bg-elevated)!important;border-bottom:1px solid var(--border-color)!important}.react-datepicker__current-month,.react-datepicker__day-name{color:var(--text-primary)!important}.react-datepicker__day{color:var(--text-primary)!important;border-radius:var(--radius-sm)!important}.react-datepicker__day:hover{background:var(--bg-hover)!important}.react-datepicker__day--selected,.react-datepicker__day--in-range{background:var(--accent-primary)!important;color:#fff!important}.react-datepicker__day--in-selecting-range{background:var(--accent-primary-glow)!important}.react-datepicker__day--disabled{color:var(--text-tertiary)!important}.react-datepicker__navigation-icon:before{border-color:var(--text-secondary)!important}.react-datepicker__triangle{display:none!important}.recharts-cartesian-axis-tick-value{fill:var(--text-tertiary)!important;font-size:var(--font-size-xs)!important}.recharts-default-tooltip{background:var(--bg-card-solid)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-md)!important}.recharts-tooltip-label{color:var(--text-primary)!important}.recharts-tooltip-item{color:var(--text-secondary)!important}.success-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;animation:fadeIn var(--transition-fast) both}.success-checkmark{width:80px;height:80px;border-radius:50%;background:var(--accent-success);display:flex;align-items:center;justify-content:center;animation:scaleIn var(--transition-spring) both;box-shadow:0 0 40px #10b98166}.success-checkmark svg{width:40px;height:40px;stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;fill:none}.success-checkmark path{stroke-dasharray:24;animation:checkmark .4s .2s ease-in-out both}.swipeable{position:relative;overflow:hidden;touch-action:pan-y}.swipe-bg{position:absolute;top:0;right:0;bottom:0;width:100px;background:var(--accent-danger);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);border-radius:0 var(--radius-md) var(--radius-md) 0}.swipe-content{position:relative;z-index:1;background:var(--bg-card-solid);transition:transform var(--transition-base)}.fab{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#6a4ae8);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #7c5cfc66,0 0 24px #7c5cfc33;transition:all var(--transition-base);position:relative;top:-12px;-webkit-tap-highlight-color:transparent}.fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #7c5cfc80,0 0 32px #7c5cfc4d}.fab:active{transform:scale(.95)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);padding-bottom:var(--safe-area-bottom);background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-around;z-index:50;max-width:var(--content-max-width);margin:0 auto}@supports (width: 100dvw){.bottom-nav{left:50%;transform:translate(-50%);width:100%;max-width:var(--content-max-width)}}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-xs);min-width:64px;min-height:44px;border-radius:var(--radius-md);color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;text-decoration:none}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--accent-primary)}.nav-item.active svg{filter:drop-shadow(0 0 6px var(--accent-primary-glow))}.nav-fab-slot{position:relative;min-width:auto}.layout{display:flex;flex-direction:column;min-height:100dvh;position:relative}.layout-main{flex:1;position:relative}
