:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: rgba(99, 102, 241, .12);--primary-glow: rgba(99, 102, 241, .2);--secondary: #64748b;--secondary-hover: #475569;--success: #10b981;--success-light: rgba(16, 185, 129, .12);--danger: #ef4444;--danger-light: rgba(239, 68, 68, .12);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .12);--info: #3b82f6;--info-light: rgba(59, 130, 246, .12);--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-hover: rgba(255, 255, 255, .05);--bg-elevated: #273449;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--text-soft: #475569;--border-color: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .12);--border-focus: rgba(99, 102, 241, .5);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .35);--shadow-glow: 0 0 32px var(--primary-glow);--sidebar-width: 240px;--header-height: 56px;--navbar-height: 64px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-max: 32px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--theme-transition: background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease}[data-theme=light]{--primary: #1f7c93;--primary-hover: #4338ca;--primary-light: rgba(79, 70, 229, .1);--primary-glow: rgba(79, 70, 229, .15);--success: #059669;--success-light: rgba(5, 150, 105, .1);--danger: #dc2626;--danger-light: rgba(220, 38, 38, .1);--warning: #d97706;--warning-light: rgba(217, 119, 6, .1);--info: #2563eb;--info-light: rgba(37, 99, 235, .1);--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-hover: rgba(0, 0, 0, .04);--bg-elevated: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-soft: #94a3b8;--border-color: #e2e8f0;--border-light: #cbd5e1;--border-focus: rgba(79, 70, 229, .5);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px var(--primary-glow)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:var(--theme-transition)}body.menu-open{overflow:hidden}.sidebar,.main-content,.card,.modal,.dropdown-menu,.nav-item,.btn{transition:var(--theme-transition)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.app{min-height:100vh}.app-layout{display:flex;min-height:100vh}.app-layout-topnav{flex-direction:column}.main-content-topnav{flex:1;margin-top:var(--navbar-height, 64px);padding:24px 32px;min-height:calc(100vh - var(--navbar-height, 64px));background-color:var(--bg-primary);max-width:1400px;width:100%;margin-left:auto;margin-right:auto}@media(max-width:1024px){.main-content-topnav{padding:24px 20px}}@media(max-width:640px){.main-content-topnav{padding:16px}}.main-content{flex:1;padding:24px 32px;min-height:100vh;background-color:var(--bg-primary);transition:margin-left var(--transition-normal)}@media(max-width:1024px){.main-content{margin-left:0;padding:24px 20px;padding-top:calc(var(--header-height) + 24px)}}@media(max-width:640px){.main-content{padding:16px}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:250;padding:0 16px}.mobile-header-content{display:flex;justify-content:space-between;align-items:center;height:100%;max-width:100%}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.mobile-header-actions{display:flex;align-items:center;gap:var(--space-2)}@media(max-width:1024px){.mobile-header{display:block}}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:200;transition:transform var(--transition-normal);overflow:visible}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#0009;z-index:150;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media(max-width:1024px){.sidebar{transform:translate(-100%);top:var(--header-height);height:calc(100vh - var(--header-height));height:calc(100dvh - var(--header-height));border-right:3px solid var(--primary)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;top:var(--header-height)}.sidebar-header-desktop{display:none!important}.sidebar-header-mobile{display:block!important;padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border-color)}.nav-section-desktop-only{display:none!important}.nav-section-mobile-bottom{display:block!important;padding-top:var(--space-4);border-top:1px solid var(--border-color)}.nav-section-mobile-main{display:block!important}.sidebar-mobile-bottom-wrapper{display:flex!important;flex-direction:column;margin-top:auto}.nav-section-mobile-bottom-fixed{display:block!important;padding:var(--space-3);border-top:1px solid var(--border-color)}.nav-section-mobile-bottom-fixed .nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);margin-bottom:2px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.nav-section-mobile-bottom-fixed .nav-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.nav-section-mobile-bottom-fixed .nav-item.active{background-color:var(--primary-light);color:var(--primary)}.sidebar-settings-desktop,.sidebar-footer-desktop{display:none!important}.sidebar-footer-mobile{display:flex!important}.sidebar-nav-section-title-desktop{display:none!important}}.sidebar-header{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border-color)}.sidebar-header-desktop{display:block}.sidebar-header-mobile{display:none}.mobile-user-header{display:flex;align-items:center;gap:var(--space-4);text-decoration:none;padding:var(--space-2);margin:calc(-1 * var(--space-2));border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.mobile-user-avatar{width:48px;height:48px;font-size:1.1rem}.nav-section-mobile-bottom,.nav-section-mobile-main,.sidebar-mobile-bottom-wrapper,.nav-section-mobile-bottom-fixed{display:none}.nav-item-logout{width:100%;background:transparent;border:none;cursor:pointer;color:var(--danger)}.nav-item-logout:hover{background-color:var(--danger-light);color:var(--danger)}.nav-item-logout .nav-icon{opacity:1}.nav-item-logout .nav-icon svg{stroke:var(--danger)}.sidebar-footer-mobile{display:none;flex-direction:column;align-items:flex-start;gap:var(--space-1);padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border-color)}.sidebar-footer-mobile-logo{display:flex;align-items:center;gap:var(--space-2)}.sidebar-footer-mobile-dot{width:8px;height:8px;border-radius:50%;background-color:var(--primary)}.sidebar-footer-mobile-brand{font-size:.9rem;font-weight:600;color:var(--text-primary)}.sidebar-footer-mobile-version{font-size:.7rem;color:var(--text-muted);margin-left:calc(8px + var(--space-2))}.logo{display:flex;align-items:center;gap:var(--space-3)}.logo-img{width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 2px 8px var(--primary-glow))}.logo-icon{font-size:28px}.logo-text{font-size:1.125rem;font-weight:700;letter-spacing:-.01em;background:linear-gradient(135deg,#a5b4fc,var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-3)}.nav-section{margin-bottom:var(--space-4)}.nav-section:last-child{margin-bottom:0}.nav-section-title{display:block;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);margin-bottom:2px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.nav-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-light);color:var(--primary)}.nav-item.active .nav-icon{opacity:1}.nav-icon{font-size:1.1rem;width:20px;height:20px;text-align:center;opacity:.7;transition:opacity var(--transition-fast);display:flex;align-items:center;justify-content:center}.nav-icon svg{width:20px;height:20px;stroke:currentColor}.nav-item:hover .nav-icon{opacity:1}.nav-label{font-size:.875rem;font-weight:500}.sidebar-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);display:flex;align-items:center;gap:var(--space-3);background-color:var(--bg-elevated);flex-shrink:0}@media(max-width:1024px){.sidebar-footer{padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}}.sidebar-footer .user-info,.user-info{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.user-info-link{text-decoration:none;border-radius:var(--radius-md);padding:var(--space-2);margin:calc(-1 * var(--space-2));transition:background-color var(--transition-fast);cursor:pointer}.user-info-link:hover{background-color:var(--bg-hover)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#a78bfa);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff;flex-shrink:0;box-shadow:0 2px 8px var(--primary-glow)}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:var(--text-muted)}.logout-btn{padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;display:flex;align-items:center;justify-content:center}.logout-btn:hover{background-color:var(--danger-light);border-color:var(--danger);color:var(--danger)}.logout-btn .nav-icon{font-size:1.1rem}.sidebar-language{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.language-selector{position:relative;display:inline-flex}.language-selector-btn{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:.85rem;font-weight:500;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-width:70px}.language-selector-btn:hover{background-color:var(--bg-elevated);border-color:var(--border-light)}.language-selector-btn:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.language-selector-btn .language-flag{font-size:1rem;line-height:1}.language-code{font-weight:600;letter-spacing:.02em}.language-chevron{color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0}.language-chevron.open{transform:rotate(180deg)}.language-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;min-width:160px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden;animation:dropdownSlideUp .15s ease-out}.language-selector.dropdown-down .language-dropdown{bottom:auto;top:calc(100% + 6px);animation:dropdownSlideDown .15s ease-out}.mobile-header .language-dropdown,.mobile-header-actions .language-dropdown{bottom:auto;top:calc(100% + 4px);animation:dropdownSlideDown .15s ease-out}@keyframes dropdownSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.language-option{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:.9rem;color:var(--text-primary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);text-align:left;min-height:44px}.language-option:hover{background-color:var(--bg-hover)}.language-option.active{background-color:var(--primary-light);color:var(--primary)}.language-flag{font-size:1.1rem;line-height:1}.language-name{flex:1}.language-check-icon{color:var(--primary);flex-shrink:0}.language-selector--minimal .language-selector-btn{background-color:transparent;border:1px solid transparent;padding:var(--space-2) var(--space-3);gap:var(--space-2);border-radius:var(--radius-max)}.language-selector--minimal .language-selector-btn:hover{background-color:rgba(var(--text-primary-rgb),.08);border-color:transparent}.language-selector--minimal .language-selector-btn:focus{background-color:rgba(var(--text-primary-rgb),.08);box-shadow:none;border-color:transparent}.language-selector--minimal .language-dropdown{min-width:180px;border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026,0 2px 10px #0000001a}[data-theme=dark] .language-selector--minimal .language-dropdown{box-shadow:0 10px 40px #0006,0 2px 10px #0003;border-color:var(--border-light)}.sidebar-language .language-selector{width:100%}.sidebar-language .language-selector-btn{width:100%;justify-content:center;background-color:var(--bg-tertiary)}.theme-switcher{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--theme-transition),transform var(--transition-fast)}.theme-switcher:hover{background-color:var(--bg-elevated);border-color:var(--border-light);transform:scale(1.05)}.theme-switcher:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.theme-icon{font-size:1.2rem;line-height:1;transition:transform var(--transition-normal)}.theme-switcher:hover .theme-icon{transform:rotate(15deg)}.theme-toggle{display:flex;background-color:var(--bg-tertiary);border-radius:999px;padding:3px;gap:0;border:1px solid var(--border-color)}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;padding:8px 12px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .3s ease;position:relative;z-index:1}.theme-toggle-btn:hover:not(.active){color:var(--text-secondary);background-color:rgba(var(--text-primary-rgb),.05)}.theme-toggle-btn.active.light{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;box-shadow:0 2px 8px #f59e0b59}.theme-toggle-btn.active.dark{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 2px 8px #6366f159}.theme-toggle-icon{font-size:1rem;line-height:1}.landing-nav-actions .theme-toggle{background-color:transparent;border-color:transparent}.landing-nav-actions .theme-toggle-btn{padding:8px 10px}.landing-nav-actions .theme-toggle-btn:hover:not(.active){background-color:rgba(var(--text-primary-rgb),.08)}.sidebar-settings{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background-color:var(--bg-secondary);overflow:visible;position:relative;z-index:201}.sidebar-settings .language-selector{flex:1}.sidebar-settings .language-selector-btn{width:100%;height:40px;justify-content:center}.sidebar-settings .language-dropdown{position:absolute;bottom:calc(100% + 8px);left:0;right:0;top:auto;z-index:9999;min-width:140px}.sidebar-settings .theme-switcher{flex-shrink:0}@media(max-width:1024px){.sidebar-settings{display:none}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);gap:var(--space-4);flex-wrap:wrap}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1);letter-spacing:-.02em}.page-subtitle{color:var(--text-secondary);font-size:.875rem}@media(max-width:640px){.page-header{align-items:stretch;margin-bottom:var(--space-6)}.page-header h1{font-size:1.375rem}.theme-switcher{height:36px;width:36px}}.onboarding-tip{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-6);background:var(--bg-secondary);border:1px solid var(--border-primary);border-left:3px solid var(--primary);border-radius:var(--radius-lg);animation:tipSlideIn .3s ease-out}@keyframes tipSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.onboarding-tip-content{display:flex;align-items:center;gap:var(--space-3);font-size:.875rem;color:var(--text-secondary);flex-wrap:wrap}.onboarding-tip-icon{display:flex;align-items:center;color:var(--primary);flex-shrink:0}.onboarding-tip-link{color:var(--primary);font-weight:600;text-decoration:none;white-space:nowrap}.onboarding-tip-link:hover{text-decoration:underline}.onboarding-tip-dismiss{background:none;border:none;cursor:pointer;padding:var(--space-1);color:var(--text-tertiary);flex-shrink:0;display:flex;align-items:center;border-radius:var(--radius-sm);transition:color .15s,background .15s}.onboarding-tip-dismiss:hover{color:var(--text-primary);background:var(--bg-tertiary)}@media(max-width:640px){.onboarding-tip{padding:var(--space-3)}.sidebar.open{width:100%}.onboarding-tip-content{font-size:.8125rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius-max);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-fast)}.btn svg{flex-shrink:0;width:18px;height:18px}.btn:hover:after{opacity:1}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,#a78bfa 100%);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--border-light);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,#fca5a5 100%);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8rem}.btn-lg{padding:var(--space-4) var(--space-6);font-size:.95rem}.btn-icon{font-size:1.1em}.btn-block{width:100%}.btn-icon-action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon-action:hover{background-color:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-light)}.btn-icon-edit:hover{background-color:var(--primary-light);color:var(--primary);border-color:var(--primary)}.btn-icon-delete:hover{background-color:var(--danger-light);color:var(--danger);border-color:var(--danger)}.dropdown{position:relative;width:100%;min-width:150px}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;font-size:.95rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-max);cursor:pointer;transition:all var(--transition-fast);text-align:left}.dropdown-trigger:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--border-light)}.dropdown-trigger:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.dropdown-trigger:disabled{opacity:.6;cursor:not-allowed}.dropdown.open .dropdown-trigger{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.dropdown-value{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0;overflow:hidden}.dropdown-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-placeholder{color:var(--text-muted)}.dropdown-icon{font-size:1rem;flex-shrink:0}.dropdown-badge{font-size:.7rem;padding:2px 6px;background-color:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);flex-shrink:0}.dropdown-arrow{display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0;margin-left:var(--space-2)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease-out}.dropdown-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-bottom:1px solid var(--border-color)}.dropdown-search-icon{color:var(--text-muted);flex-shrink:0}.dropdown-search-input{flex:1;padding:var(--space-2);font-size:.9rem;color:var(--text-primary);background:transparent;border:none;outline:none}.dropdown-search-input::placeholder{color:var(--text-muted)}.dropdown-list{list-style:none;margin:0;padding:var(--space-1);max-height:250px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-3);font-size:.9rem;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.dropdown-item:hover,.dropdown-item.highlighted{background-color:var(--bg-hover)}.dropdown-item.selected{background-color:var(--primary-light);color:var(--primary)}.dropdown-item.disabled{opacity:.5;cursor:not-allowed}.dropdown-item-icon{font-size:1rem;flex-shrink:0}.dropdown-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-item-badge{font-size:.7rem;padding:2px 6px;background-color:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);flex-shrink:0}.dropdown-check{color:var(--primary);flex-shrink:0;margin-left:auto}.dropdown-empty{padding:var(--space-4);text-align:center;color:var(--text-muted);font-size:.9rem}.form-group .dropdown{width:100%;max-height:46px}.dropdown-compact .dropdown-trigger{padding:6px 10px;font-size:.85rem;min-height:auto}.dropdown-compact .dropdown-arrow{margin-left:var(--space-1)}.dropdown-compact .dropdown-menu{min-width:150px}.dropdown-compact .dropdown-item{padding:var(--space-2) var(--space-3);font-size:.85rem}.dropdown-warning .dropdown-trigger{border-color:var(--warning);background-color:var(--warning-light)}.dropdown-warning .dropdown-trigger:focus,.dropdown-warning.open .dropdown-trigger{border-color:var(--warning);box-shadow:0 0 0 3px #f59e0b33}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:var(--transition-fast)}.card:hover{border-color:var(--border-light)}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-8)}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr;gap:var(--space-4)}}.stat-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;gap:var(--space-4);transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:transparent;transition:background var(--transition-normal)}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.stat-card.total-balance{background:linear-gradient(135deg,#818cf814,#a78bfa0a);border-color:#818cf833}.stat-card.total-balance:before{background:linear-gradient(90deg,var(--primary),#a78bfa)}.stat-card.total-balance:hover{box-shadow:0 8px 32px #818cf833}.stat-card.total-balance .stat-value{background:linear-gradient(135deg,var(--primary),#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}.stat-card.income{background:linear-gradient(135deg,#34d3990f,#34d39905);border-color:#34d39926}.stat-card.income:before{background:var(--success)}.stat-card.income:hover{box-shadow:0 8px 24px #34d39926}.stat-card.income .stat-value{color:var(--success)}.stat-card.expenses{background:linear-gradient(135deg,#f871710f,#f8717105);border-color:#f8717126}.stat-card.expenses:before{background:var(--danger)}.stat-card.expenses:hover{box-shadow:0 8px 24px #f8717126}.stat-card.expenses .stat-value{color:var(--danger)}.stat-card.wallets{background:var(--bg-card)}.stat-card.wallets:before{background:var(--secondary)}.stat-card.warning{background:linear-gradient(135deg,rgba(245,158,11,.06) 0%,transparent 100%);border-color:#f59e0b4d}.stat-card.warning:before{background:var(--warning)}.stat-card.warning:hover{box-shadow:0 8px 24px #f59e0b26}.stat-card.success{background:linear-gradient(135deg,rgba(16,185,129,.06) 0%,transparent 100%);border-color:#10b9814d}.stat-card.success:before{background:var(--success)}.stat-card.success:hover{box-shadow:0 8px 24px #10b98126}.stat-card.info{background:linear-gradient(135deg,rgba(59,130,246,.06) 0%,transparent 100%);border-color:#3b82f64d}.stat-card.info:before{background:var(--info)}.stat-card.info:hover{box-shadow:0 8px 24px #3b82f626}.stat-card.error{background:linear-gradient(135deg,rgba(239,68,68,.06) 0%,transparent 100%);border-color:#ef44444d}.stat-card.error:before{background:var(--danger)}.stat-card.error:hover{box-shadow:0 8px 24px #ef444426}.stat-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border-radius:var(--radius-md);flex-shrink:0;opacity:.9}.stat-icon svg{width:24px;height:24px}.stat-card.wallets .stat-icon{background:linear-gradient(135deg,#6366f126,#a855f726)}.stat-card.wallets .stat-icon svg{stroke:var(--primary)}.stat-content{display:flex;flex-direction:column;justify-content:center;min-width:0}.stat-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.02em}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}.stat-change{font-size:.75rem;display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-1);font-weight:500}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.stat-change.neutral{color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:30% 1fr;gap:var(--space-5);margin-bottom:var(--space-8)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition-normal)}.dashboard-section:hover{border-color:var(--border-light)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.section-header h2{font-size:.95rem;font-weight:600;color:var(--text-primary)}.section-link{font-size:.8rem;color:var(--primary);font-weight:500;transition:all var(--transition-fast);opacity:.9}.section-link:hover{opacity:1;text-decoration:underline}.wallets-list{display:flex;flex-direction:column;gap:var(--space-3)}.wallet-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-normal);border:1px solid transparent}.wallet-item:hover{background-color:var(--bg-elevated);border-color:var(--border-light);transform:translate(4px)}.wallet-item-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),#a78bfa);border-radius:var(--radius-md);font-size:1rem;font-weight:700;color:#fff;flex-shrink:0}.wallet-item-info{flex:1;min-width:0}.wallet-item-name{display:block;font-weight:600;font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wallet-item-currency{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.wallet-item-balance{font-weight:700;font-size:.95rem}.wallet-item-balance.positive{color:var(--success)}.wallet-item-balance.negative{color:var(--danger)}.transactions-list-compact{display:flex;flex-direction:column;gap:var(--space-3)}.transaction-item-compact{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-normal);border:1px solid transparent}.transaction-item-compact:hover{background-color:var(--bg-elevated);border-color:var(--border-light)}.transaction-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:.85rem;font-weight:600}.transaction-icon.credit{background-color:#34d39926;color:var(--success)}.transaction-icon.debit{background-color:#f8717126;color:var(--danger)}.transaction-details{flex:1;min-width:0}.transaction-category{display:block;font-weight:600;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-date{font-size:.7rem;color:var(--text-muted)}.transaction-amount{font-weight:700;font-size:.9rem}.quick-actions{margin-bottom:var(--space-8)}.quick-actions h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-4)}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media(max-width:1024px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.quick-actions-grid{grid-template-columns:1fr}}.quick-action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-5);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.quick-action-card:hover{background-color:var(--bg-elevated);border-color:var(--primary);transform:translateY(-3px);box-shadow:0 8px 24px #00000026}.quick-action-icon{font-size:1.5rem;opacity:.9;transition:transform var(--transition-normal);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.quick-action-icon svg{width:24px;height:24px;stroke:var(--primary)}.quick-action-card:hover .quick-action-icon{transform:scale(1.1)}.quick-action-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-align:center}.quick-action-card:hover .quick-action-label{color:var(--text-primary)}.quick-tools-section{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--space-5);margin-bottom:var(--space-6)}@media(max-width:1024px){.quick-tools-section{grid-template-columns:1fr}}.quick-tool-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-normal)}.quick-tool-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}.quick-tool-card:first-child{background:linear-gradient(135deg,#818cf80f,#a78bfa08);border-color:#818cf826;position:relative;overflow:hidden}.quick-tool-card:first-child:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);opacity:.3;pointer-events:none}.quick-tool-card:first-child:hover{border-color:#818cf84d;box-shadow:0 8px 32px #818cf826}.quick-tool-header{margin-bottom:var(--space-4);position:relative;z-index:1}.quick-tool-header h3{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1);display:flex;align-items:center;gap:var(--space-2)}.quick-tool-description{font-size:.8rem;color:var(--text-secondary);margin:0;line-height:1.5}.quick-tool-content{position:relative;z-index:1}.quick-add-section{margin-bottom:var(--space-4);padding:var(--space-4);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-3xl);transition:all var(--transition-normal)}.quick-add-section:has(.quick-add-input:focus),.quick-add-section:has(.btn-voice.listening),.quick-add-section:has(.btn-receipt.scanning){background-color:var(--bg-elevated);border-color:var(--primary-light)}.smart-input-hint{margin:0 0 var(--space-3) 0;padding:0;font-size:.8rem;color:var(--text-muted);text-align:center;line-height:1.4}.quick-add-input-wrapper{display:flex;gap:var(--space-2);align-items:center}.quick-add-input-wrapper .btn-secondary{white-space:nowrap;min-width:auto;flex-shrink:0}.quick-add-input-wrapper .btn-secondary:not(:disabled){background-color:var(--primary);color:#fff;border-color:var(--primary)}.quick-add-input-wrapper .btn-secondary:not(:disabled):hover{background-color:var(--primary-hover);border-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.quick-add-input{flex:1;padding:var(--space-3) var(--space-4);font-size:.9rem;font-family:inherit;color:var(--text-primary);background-color:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-normal)}.quick-add-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.quick-add-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--bg-tertiary)}.quick-add-input::placeholder{color:var(--text-muted)}.quick-add-input-wrapper:has(.btn-voice.listening) .quick-add-input{border-color:var(--danger);box-shadow:0 0 0 3px #f871711a;background-color:var(--bg-elevated)}.quick-add-input-wrapper .btn-secondary:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.quick-add-input-group{display:flex;flex-direction:column;gap:var(--space-3)}.quick-add-textarea{width:100%;padding:var(--space-4);font-size:.9rem;font-family:inherit;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);resize:none;min-height:72px;transition:all var(--transition-normal);line-height:1.5}.quick-add-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light),0 4px 12px #818cf81a;background-color:var(--bg-elevated)}.quick-add-textarea:disabled{opacity:.6;cursor:not-allowed}.quick-add-textarea::placeholder{color:var(--text-muted);font-style:italic}.quick-add-actions{display:flex;gap:var(--space-3);justify-content:flex-end;align-items:center}.voice-hint{margin:var(--space-2) 0 0 0;padding:0;font-size:.75rem;color:var(--text-muted);text-align:center;font-style:italic}.quick-add-section-v2{margin-bottom:var(--space-4)}.quick-add-input-container{display:flex;gap:var(--space-3);align-items:center;flex-wrap:nowrap}.quick-add-input-field{flex:1;min-width:0;position:relative;display:flex;align-items:center;background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:50px;padding:var(--space-2) var(--space-3);transition:all var(--transition-normal)}.quick-add-input-field:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px #6366f11a}.quick-add-input-v2{flex:1;border:none;background:transparent;font-size:.95rem;font-family:inherit;color:var(--text-primary);padding:var(--space-2) var(--space-2);outline:none}.quick-add-input-v2::placeholder{color:var(--text-muted)}.quick-add-input-v2:disabled{opacity:.6;cursor:not-allowed}.btn-voice-v2{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:none;border-radius:50%;color:var(--primary);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.btn-voice-v2:hover:not(:disabled){background:linear-gradient(135deg,#6366f133,#8b5cf633);transform:scale(1.05)}.btn-voice-v2:disabled{opacity:.5;cursor:not-allowed}.btn-voice-v2.listening{background:linear-gradient(135deg,#f8717133,#ef444433);color:var(--danger);animation:voicePulseV2 1.5s ease-in-out infinite}@keyframes voicePulseV2{0%,to{box-shadow:0 0 #f8717166;transform:scale(1)}50%{box-shadow:0 0 0 8px #f8717100;transform:scale(1.05)}}.btn-receipt-v2{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:none;border-radius:50%;color:var(--primary);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.btn-receipt-v2:hover:not(:disabled){background:linear-gradient(135deg,#6366f133,#8b5cf633);transform:scale(1.05)}.btn-receipt-v2:disabled{opacity:.5;cursor:not-allowed}.btn-receipt-v2.scanning{background:linear-gradient(135deg,#6366f133,#8b5cf633);color:var(--primary);animation:receiptPulseV2 1.5s ease-in-out infinite}@keyframes receiptPulseV2{0%,to{box-shadow:0 0 #6366f166;transform:scale(1)}50%{box-shadow:0 0 0 8px #6366f100;transform:scale(1.05)}}.btn-process-v2{display:flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50px;color:#fff;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all var(--transition-normal);box-shadow:0 2px 8px #6366f140}.btn-process-v2:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #6366f159}.btn-process-v2:active:not(:disabled){transform:translateY(0)}.btn-process-v2:disabled{opacity:.5;cursor:not-allowed;transform:none}.voice-hint-v2{margin:var(--space-3) 0 0 0;padding:0;font-size:.8rem;color:var(--text-muted);text-align:center}@media(max-width:480px){.quick-add-input-container{flex-direction:column;gap:var(--space-2)}.quick-add-input-field{width:100%}.btn-process-v2{width:100%;padding:var(--space-3)}}.btn-voice{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal);position:relative}.btn-voice:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--primary);color:var(--primary);transform:scale(1.05)}.btn-voice:disabled{opacity:.5;cursor:not-allowed}.btn-voice.listening{background-color:var(--danger-light);border-color:var(--danger);color:var(--danger);animation:voicePulse 1.5s ease-in-out infinite}@keyframes voicePulse{0%,to{box-shadow:0 0 #f8717166;transform:scale(1)}50%{box-shadow:0 0 0 12px #f8717100;transform:scale(1.02)}}.btn-receipt{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.btn-receipt:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--primary);color:var(--primary);transform:scale(1.05)}.btn-receipt:disabled{opacity:.5;cursor:not-allowed}.btn-receipt.scanning{background-color:var(--primary-light);border-color:var(--primary);color:var(--primary);animation:receiptPulse 1.5s ease-in-out infinite}.btn-receipt-spinner{width:18px;height:18px;border:2px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes receiptPulse{0%,to{box-shadow:0 0 #6366f14d;transform:scale(1)}50%{box-shadow:0 0 0 10px #6366f100;transform:scale(1.02)}}.quick-add-attachment-preview{position:relative;display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-2) var(--space-3);background-color:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);min-height:48px}.quick-add-attachment-preview .attachment-preview-img{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);flex-shrink:0}.quick-add-attachment-preview .attachment-preview-img.clickable{cursor:pointer;transition:opacity var(--transition-normal)}.quick-add-attachment-preview .attachment-preview-img.clickable:hover{opacity:.7}.quick-add-attachment-preview .attachment-preview-file{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.quick-add-attachment-preview .attachment-file-name{font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-add-attachment-preview .attachment-scanning-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background-color:#ffffffe6;border-radius:var(--radius-md);font-size:.78rem;color:var(--primary);font-weight:500}[data-theme=dark] .quick-add-attachment-preview .attachment-scanning-overlay{background-color:#1e1e28e6}.quick-add-attachment-preview .attachment-remove-btn,.quick-add-attachment-preview .attachment-remove-btn:hover:not(:disabled){position:static;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;background-color:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-sm);font-size:18px;line-height:1;cursor:pointer;padding:0;flex-shrink:0;margin-left:auto;transform:none;transition:all var(--transition-normal)}.quick-add-attachment-preview .attachment-remove-btn:hover:not(:disabled){color:var(--danger);background-color:var(--bg-tertiary)}.quick-add-attachment-preview .attachment-remove-btn:disabled{opacity:.3;cursor:not-allowed}.listening-indicator{position:absolute;top:-3px;right:-3px;width:10px;height:10px;background-color:var(--danger);border-radius:50%;border:2px solid var(--bg-card);animation:indicatorBlink .8s ease-in-out infinite}@keyframes indicatorBlink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.9)}}.csv-import-group{display:flex;gap:12px;align-items:center}@media(max-width:480px){.csv-import-group{flex-direction:column;align-items:stretch}}.file-input-wrapper{flex:1;position:relative}.file-input-hidden{position:absolute;width:0;height:0;opacity:0;overflow:hidden}.file-input-label{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:.9rem;color:var(--text-secondary);background-color:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-input-label:hover{background-color:var(--bg-hover);border-color:var(--primary);color:var(--text-primary)}.file-input-label svg{flex-shrink:0;color:var(--text-muted)}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@media(max-width:640px){.quick-add-section{padding:var(--space-3)}.quick-add-input-wrapper{flex-wrap:wrap}.quick-add-input{width:100%;flex:1 1 100%}.btn-voice{width:40px;height:40px}.quick-add-actions{flex-direction:column}.quick-add-actions .btn{width:100%;justify-content:center}.btn-voice{width:100%;height:44px}}.empty-state{text-align:center;padding:60px 20px;background-color:var(--bg-card);border:2px dashed var(--border-color);border-radius:var(--radius-lg)}.empty-state-icon{font-size:4rem;margin-bottom:16px;display:flex;align-items:center;justify-content:center}.empty-state-icon svg{width:64px;height:64px;stroke:var(--primary);opacity:.8}.empty-state h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-secondary);margin-bottom:24px}.empty-state-small{text-align:center;padding:32px;color:var(--text-secondary)}.empty-state-small p{margin-bottom:16px}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--text-secondary)}.spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:.9rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;font-size:.95rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-max);transition:var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}input[type=date]{position:relative;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:40px;cursor:pointer;font-family:inherit;font-variant-numeric:tabular-nums}[data-theme=dark] input[type=date]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")}input[type=date]:hover{border-color:var(--primary-light)}input[type=date]:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")}input[type=date]::-webkit-calendar-picker-indicator{position:absolute;right:0;top:0;width:40px;height:100%;margin:0;padding:0;cursor:pointer;opacity:0}input[type=date]::-webkit-datetime-edit{padding:0}input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}input[type=date]::-webkit-datetime-edit-text{color:var(--text-muted);padding:0 2px}input[type=date]::-webkit-datetime-edit-month-field,input[type=date]::-webkit-datetime-edit-day-field,input[type=date]::-webkit-datetime-edit-year-field{padding:2px 4px;border-radius:4px;transition:background-color .2s}input[type=date]::-webkit-datetime-edit-month-field:focus,input[type=date]::-webkit-datetime-edit-day-field:focus,input[type=date]::-webkit-datetime-edit-year-field:focus{background-color:var(--primary-light);color:var(--primary);outline:none}input[type=date]::-moz-focus-inner{border:0;padding:0}input[type=date]:invalid:not(:focus){color:var(--text-muted)}input[type=date]:valid{color:var(--text-primary)}input[type=date]:disabled{cursor:not-allowed;opacity:.6;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' opacity='0.5'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")}.filter-item input[type=date],.form-compact input[type=date]{font-size:.85rem;padding:8px 36px 8px 12px;background-size:16px;background-position:right 10px center}.filter-item input[type=date]::-webkit-calendar-picker-indicator,.form-compact input[type=date]::-webkit-calendar-picker-indicator{width:36px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.input-with-button{display:flex;gap:8px}.input-with-button select,.input-with-button input{flex:1}.input-with-button .btn{flex-shrink:0;padding:12px 16px}.modal-overlay{position:fixed;inset:0;width:100%;height:100vh;height:100dvh;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom));animation:fadeIn .2s ease;overflow:hidden;box-sizing:border-box}@supports (height: 100dvh){.modal-overlay{height:100dvh}}.modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:calc(100vh - 120px);max-height:calc(100dvh - 120px);display:flex;flex-direction:column;padding:32px;animation:slideUp .3s ease;overflow:visible;position:relative}.modal.modal-with-pickers{max-width:480px;max-height:85vh;overflow:visible}.modal.modal-with-pickers form{overflow:visible}.modal.modal-with-pickers .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:8px}.modal.modal-with-pickers .form-row .form-group{margin-bottom:0}@supports (max-height: 100dvh){.modal{max-height:calc(100dvh - 120px)}}.modal.modal-large{max-width:800px}.modal.modal-xlarge{max-width:95vw;width:1400px;max-height:calc(100vh - 120px);max-height:calc(100dvh - 120px);display:flex;flex-direction:column;padding:0}@supports (max-height: 100dvh){.modal.modal-xlarge{max-height:calc(100dvh - 120px)}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 32px;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header-content{display:flex;flex-direction:column;gap:12px}.modal-header h2{margin-bottom:0}.modal-close{background:transparent;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:4px 8px;line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px 32px;flex:1;overflow-y:auto}.modal-description{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem;line-height:1.5}.modal-footer{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 32px;border-top:1px solid var(--border-color);background-color:var(--bg-tertiary);flex-shrink:0;border-radius:0 0 16px 16px}.modal-footer-info{flex:1;text-align:center;color:var(--text-secondary);font-size:.9rem}.import-summary{display:flex;flex-wrap:wrap;gap:16px}.import-summary-item{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background-color:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-secondary)}.import-summary-item.valid{background-color:var(--success-light);color:var(--success)}.import-summary-item.invalid{background-color:var(--danger-light);color:var(--danger)}.import-header-info{display:flex;flex-direction:column;gap:12px}.import-file-info{display:flex;flex-direction:column;gap:8px}.import-file-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.import-info-item{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-secondary)}.import-info-item .import-info-icon{font-size:1rem}.import-info-item.bank-badge{padding:4px 12px;background-color:var(--primary-light);color:var(--primary);border-radius:var(--radius-md);font-weight:500}.import-info-item.period-info{font-size:.85rem;color:var(--text-muted)}.import-warnings{background-color:var(--warning-light);border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-md);padding:12px 16px}.import-warnings-header{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--warning);margin-bottom:8px}.import-warnings-icon{font-size:1.1rem}.import-warnings-list{margin:0;padding-left:24px;color:var(--text-primary);font-size:.9rem}.import-warnings-list li{margin-bottom:4px}.import-warnings-list li:last-child{margin-bottom:0}.import-preview-body{padding:16px 24px;display:flex;flex-direction:column;gap:16px;overflow:hidden;min-height:0;flex:1}.import-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.import-filters{display:flex;gap:4px;background-color:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md)}.btn-filter-tab{padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-filter-tab:hover{color:var(--text-primary);background-color:var(--bg-hover)}.btn-filter-tab.active{color:var(--primary);background-color:var(--primary-light)}.import-actions{display:flex;gap:8px}.import-table-container{overflow-x:auto;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-lg);flex:1;min-height:0}.import-table{width:100%;border-collapse:collapse;font-size:.85rem}.import-table thead{position:sticky;top:0;z-index:10}.import-table th{background-color:var(--bg-tertiary);padding:12px 8px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-bottom:1px solid var(--border-color)}.import-table td{padding:8px;border-bottom:1px solid var(--border-color);vertical-align:middle}.import-table tbody tr{background-color:var(--bg-card);transition:background-color var(--transition-fast)}.import-table tbody tr:hover{background-color:var(--bg-hover)}.import-table tbody tr.selected{background-color:#818cf814}.import-table tbody tr.has-error{background-color:#f871710d}.import-table tbody tr.has-error:hover{background-color:#f871711a}.col-checkbox{width:40px;text-align:center}.col-line{width:50px;text-align:center;color:var(--text-muted)}.col-date{width:130px}.col-description{min-width:200px}.col-amount,.col-type{width:100px}.col-category,.col-subcategory{width:150px}.col-status{width:50px;text-align:center}.import-table input[type=text],.import-table input[type=number],.import-table input[type=date],.import-table select{width:100%;padding:6px 8px;font-size:.85rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.import-table input[type=date]{padding-right:30px;background-size:14px;background-position:right 8px center}.import-table input[type=date]::-webkit-calendar-picker-indicator{width:30px}.import-table input:focus,.import-table select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.import-table input.input-warning,.import-table select.input-warning{border-color:var(--warning);background-color:var(--warning-light)}.import-table input[type=checkbox]{width:18px;height:18px;cursor:pointer}.status-badge{display:inline-flex;align-items:center;justify-content:center;height:24px;border-radius:50%;font-size:.75rem;width:auto}.status-badge.valid{background-color:var(--success-light);color:var(--success)}.status-badge.warning{background-color:var(--warning-light);color:var(--warning)}.status-badge.error{background-color:var(--danger-light);color:var(--danger);cursor:help}.import-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}.file-input-large{flex-direction:column;padding:32px 24px;text-align:center;gap:12px;border:2px dashed var(--border-light);background-color:var(--bg-tertiary);align-items:center;justify-content:center}.file-input-large:hover{border-color:var(--primary);background-color:var(--primary-light)}.file-input-large svg{width:32px;height:32px;color:var(--text-muted);display:block;margin:0 auto}.file-input-large span{font-size:.95rem;color:var(--text-primary);font-weight:500;display:block;width:100%}.file-input-large small{font-size:.8rem;color:var(--text-muted);display:block;width:100%}.btn-import-large{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;font-size:.95rem}.import-formats-hint{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:12px}.import-info-box{display:flex;gap:12px;padding:16px;margin-top:16px;background-color:var(--info-light);border:1px solid var(--info);border-radius:var(--radius-md);align-items:flex-start}.import-info-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.import-info-content{flex:1;display:flex;flex-direction:column;gap:8px}.import-info-content p{margin:0;font-size:.875rem;color:var(--text-primary);line-height:1.5}.import-info-content strong{font-weight:600;color:var(--text-primary)}.import-bar{display:flex;align-items:center;justify-content:space-between;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);transition:all var(--transition-normal)}.import-bar:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm)}.import-bar-info{display:flex;align-items:center;gap:var(--space-3)}.import-bar-icon{font-size:1.25rem}.import-bar-text{display:flex;align-items:center;gap:var(--space-5)}.import-bar-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.import-bar-hint{font-size:.8rem;color:var(--text-muted)}.btn-import-compact{display:flex;align-items:center;gap:8px;padding:8px 20px;font-size:.85rem;white-space:nowrap;flex-shrink:0}@media(max-width:576px){.import-bar{flex-direction:column;gap:var(--space-3);align-items:stretch}.import-bar-text{flex-direction:column;align-items:flex-start;gap:2px}.btn-import-compact{justify-content:center}}.wallet-selected-info{display:flex;align-items:center;gap:10px;padding:12px 16px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem}.wallet-selected-info .wallet-icon{font-size:1.2rem}.alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);font-size:.9rem;margin-bottom:16px}.alert-error{background-color:var(--danger-light);color:var(--danger);border:1px solid rgba(248,113,113,.3)}.alert-upgrade-link{display:inline-flex;align-items:center;margin-left:auto;padding:6px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;text-decoration:none;border-radius:6px;font-size:.85rem;font-weight:600;white-space:nowrap;transition:transform .2s,box-shadow .2s}.alert-upgrade-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}@media(max-width:1200px){.modal.modal-xlarge{max-width:98vw}.col-description{min-width:150px}}@media(max-width:768px){.modal.modal-xlarge{max-height:100vh;border-radius:0}.modal-header,.modal-body{padding:16px}.modal-footer{padding:16px;flex-direction:column}.import-toolbar{flex-direction:column;align-items:stretch}.import-filters,.import-actions{justify-content:center}.import-table{font-size:.75rem}.import-table th,.import-table td{padding:6px 4px}}.modal h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.modal>form,.modal-content{overflow-y:auto;overflow-x:hidden;max-height:calc(90vh - 64px);padding-right:4px}.modal>form::-webkit-scrollbar,.modal-content::-webkit-scrollbar{width:6px}.modal>form::-webkit-scrollbar-track,.modal-content::-webkit-scrollbar-track{background:transparent}.modal>form::-webkit-scrollbar-thumb,.modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.modal>form::-webkit-scrollbar-thumb:hover,.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.modal-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.modal-actions-right{display:flex;gap:12px;margin-left:auto}.modal-actions.modal-actions-fixed{flex-shrink:0;margin-top:0;padding-top:20px;background-color:var(--bg-secondary);position:relative;z-index:1}.modal.modal-compact{padding:24px;overflow:hidden;display:flex;flex-direction:column;max-height:90vh;max-height:90dvh}.modal.modal-compact .modal-header-row{flex-shrink:0}.modal.modal-compact .modal-scroll-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;margin:0 -24px;padding:0 24px}.modal.modal-compact .modal-actions{margin-top:20px;padding-top:16px}.modal.modal-compact .modal-actions.modal-actions-fixed{margin-top:0}.modal-scroll-content{flex:1;overflow-y:auto;overflow-x:hidden;margin:0 -24px;padding:0 24px;min-height:0}.modal:not(.modal-compact) .modal-scroll-content{max-height:calc(100dvh - 180px);max-height:calc(100vh - 180px)}@supports (max-height: 100dvh){.modal:not(.modal-compact) .modal-scroll-content{max-height:calc(100dvh - 180px)}}.modal-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-header-row h2{margin-bottom:0;font-size:1.25rem}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:1rem;line-height:1}.modal-close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.receipt-modal{max-width:860px;width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.receipt-modal .modal-header-row{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border-color);gap:16px}.receipt-modal-title{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.receipt-modal-title-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background-color:var(--primary-light);color:var(--primary);flex-shrink:0}.receipt-modal-title h2{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;margin:0}.receipt-modal-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.receipt-download-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:500;font-family:inherit;color:var(--primary);background-color:var(--primary-light);border:1px solid transparent;border-radius:8px;cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.receipt-download-btn:hover{background-color:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f140}.receipt-modal-content{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:24px;min-height:300px;background:repeating-conic-gradient(var(--bg-tertiary) 0% 25%,var(--bg-secondary) 0% 50%) 0 0 / 20px 20px}.receipt-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 24px #0000001f}.receipt-iframe{width:100%;height:70vh;border:none;border-radius:8px;box-shadow:0 4px 24px #0000001f}.receipt-loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-secondary);font-size:.85rem}.receipt-loading-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:receipt-spin .7s linear infinite}@keyframes receipt-spin{to{transform:rotate(360deg)}}@media(max-width:600px){.receipt-modal{width:95vw;max-height:95vh}.receipt-modal-content{padding:12px}.receipt-image{max-height:60vh}.receipt-iframe{height:60vh}.receipt-download-btn span{display:none}.receipt-download-btn{padding:6px 8px}}.wallet-type-row{display:flex;align-items:flex-end;gap:var(--space-3);margin-bottom:12px}.wallet-selector-inline{flex:1;min-width:0}.wallet-selector-inline label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.transaction-type-toggle{display:flex;background-color:var(--bg-tertiary);border-radius:999px;padding:4px;gap:0;margin-bottom:0;position:relative;flex-shrink:0}.quick-add-section+form>.transaction-type-toggle,form:has(.quick-add-section)>.transaction-type-toggle{margin-top:var(--space-2)}@media(max-width:540px){.wallet-type-row{flex-direction:column;align-items:stretch}.transaction-type-toggle{margin-bottom:12px}}.transaction-type-toggle .type-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .4s ease,color .3s ease,box-shadow .4s ease,transform .2s ease;position:relative;z-index:1}.transaction-type-toggle .type-toggle-btn:hover:not(.active){color:var(--text-secondary)}.transaction-type-toggle .type-toggle-btn.active.expense{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff;box-shadow:0 4px 14px #ef444459;transform:scale(1)}.transaction-type-toggle .type-toggle-btn.active.income{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;box-shadow:0 4px 14px #10b98159;transform:scale(1)}.transaction-type-toggle .type-toggle-btn:not(.active){background:transparent;box-shadow:none}.transaction-type-toggle .type-toggle-icon{font-size:1rem}.amount-hero{text-align:center;margin-bottom:16px;padding:12px 0}.amount-hero-label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.amount-hero-input{display:flex;align-items:baseline;justify-content:center;gap:4px;padding-right:14px}.amount-hero-currency{font-size:1.3rem;font-weight:300;color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0}.amount-hero-input input{background:transparent;border:none;outline:none;font-size:2.4rem;font-weight:200;color:var(--text-primary);text-align:center;width:10ch;min-width:4ch;max-width:20ch;field-sizing:content;padding:0;font-family:inherit;letter-spacing:-.02em}.amount-hero-input input:placeholder-shown{min-width:4ch}.amount-hero-input input::placeholder{color:var(--text-soft)}.amount-hero-divider{width:48px;height:2px;background:var(--border-light);margin:10px auto 0;border-radius:999px}.transaction-form-fields{display:flex;flex-direction:column;gap:0}.transaction-form-fields .form-group{margin-bottom:14px}.transaction-form-fields .form-row{gap:12px}.transaction-modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}[data-theme=light] .transaction-type-toggle .type-toggle-btn.active.expense{box-shadow:0 4px 14px #ef444440}[data-theme=light] .transaction-type-toggle .type-toggle-btn.active.income{box-shadow:0 4px 14px #10b98140}.toast{position:fixed;bottom:24px;right:24px;min-width:320px;max-width:420px;padding:16px 40px 16px 16px;background-color:var(--bg-card);border:1px solid var(--border-color);border-left:4px solid transparent;border-radius:var(--radius-xl);color:var(--text-primary);display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-xl);z-index:2000;animation:toastSlideIn .3s cubic-bezier(.21,1.02,.73,1);overflow:hidden}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-warning{border-left-color:var(--warning)}.toast-info{border-left-color:var(--info)}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.toast-icon-wrapper{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.toast-icon{width:20px;height:20px}.toast-success .toast-icon-wrapper{background-color:var(--success-light);color:var(--success)}.toast-error .toast-icon-wrapper{background-color:var(--danger-light);color:var(--danger)}.toast-warning .toast-icon-wrapper{background-color:var(--warning-light);color:var(--warning)}.toast-info .toast-icon-wrapper{background-color:var(--info-light);color:var(--info)}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:.9375rem;color:var(--text-primary);margin-bottom:4px;line-height:1.3}.toast-message{font-size:.8125rem;color:var(--text-secondary);line-height:1.45}.toast-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.toast-action{padding:8px 16px;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none}.toast-action-primary{background-color:var(--primary);color:#fff}.toast-action-primary:hover{background-color:var(--primary-hover)}.toast-action-secondary{background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.toast-action-secondary:hover{background-color:var(--bg-hover);color:var(--text-primary)}.toast-error .toast-action-primary{background-color:transparent;color:var(--danger);padding:0;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.025em}.toast-error .toast-action-primary:hover{text-decoration:underline}.toast-close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--text-muted);padding:4px;cursor:pointer;line-height:1;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.toast-close svg{width:18px;height:18px}.toast-close:hover{color:var(--text-primary);background-color:var(--bg-hover)}[data-theme=light] .toast{background-color:#fff;box-shadow:0 4px 24px #0000001f,0 0 0 1px #0000000a}@media(max-width:640px){.toast{left:16px;right:16px;bottom:16px;min-width:auto;max-width:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--bg-primary),var(--bg-secondary));position:relative}.auth-language-selector{position:absolute;top:20px;right:120px;z-index:10}.auth-language-selector .language-dropdown{bottom:auto;top:calc(100% + 4px)}.auth-container{width:100%;max-width:440px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:48px 40px;box-shadow:var(--shadow-xl)}@media(max-width:480px){.auth-container{padding:32px 24px}}.auth-header{text-align:center;margin-bottom:40px}.auth-logo{font-size:3rem;margin-bottom:16px;display:flex;justify-content:center;align-items:center}.auth-logo-img{max-width:180px;max-height:80px;width:auto;height:auto;margin-bottom:16px;object-fit:contain}.auth-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.auth-subtitle{color:var(--text-secondary);font-size:.95rem}.auth-form{margin-bottom:24px;display:flex;flex-direction:column;align-items:stretch}.auth-form .form-group,.auth-form .btn{width:100%}.auth-footer{text-align:center;color:var(--text-secondary);font-size:.9rem}.auth-footer a{color:var(--primary);font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-success-message{background-color:var(--success-light);border:1px solid var(--success);border-radius:var(--radius-md);padding:16px;margin-bottom:24px;text-align:center}.auth-success-message p{color:var(--text-primary);font-size:.9rem;line-height:1.5}.auth-resend-section{text-align:center;margin-bottom:24px;padding:16px;background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.auth-resend-section p{color:var(--text-secondary);font-size:.9rem;margin-bottom:12px}.auth-verification-warning{background-color:var(--warning-light);border:1px solid var(--warning);border-radius:var(--radius-md);padding:16px;margin-bottom:16px;text-align:center}.auth-verification-warning p{color:var(--text-primary);font-size:.9rem;margin-bottom:12px}.auth-verification-warning p:last-child{margin-bottom:0}.auth-hint{color:var(--text-secondary);font-size:.85rem;font-style:italic}.auth-forgot-password{text-align:center;margin-top:16px}.auth-forgot-password a{color:var(--text-secondary);font-size:.9rem}.auth-forgot-password a:hover{color:var(--primary);text-decoration:underline}.auth-icon{font-size:4rem;margin-bottom:16px}.auth-icon.loading-icon{animation:pulse 2s ease-in-out infinite}.auth-icon.success-icon{color:var(--success)}.auth-icon.error-icon{color:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.auth-container--verify .auth-header{margin-bottom:16px}.auth-verify-content{text-align:center}.auth-verify-content h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.auth-verify-content .auth-subtitle{margin-bottom:28px}.auth-verify-content .auth-icon{margin-bottom:20px}.auth-verify-content .btn{margin-top:8px}.resend-verification{display:flex;flex-direction:column;align-items:center;gap:8px}.resend-success{color:var(--success);font-size:.9rem}.resend-error{color:var(--danger);font-size:.85rem;margin-bottom:8px}.wallets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}@media(max-width:640px){.wallets-grid{grid-template-columns:1fr}}W .wallets-page-modern{padding-bottom:var(--space-8)}.wallets-page-modern .page-header{margin-bottom:var(--space-6)}.wallets-total-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);margin-bottom:var(--space-6);text-align:center}.wallets-total-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-2)}.wallets-total-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}@media(max-width:640px){.wallets-total-value{font-size:2rem}}.wallets-filters{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.wallets-filters-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.wallets-filter-tabs{display:flex;gap:var(--space-2);flex-wrap:wrap}.wallets-filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition-fast)}.wallets-filter-tab:hover{background-color:var(--bg-hover);color:var(--text-primary)}.wallets-filter-tab.active{background-color:var(--primary);color:#fff}.wallets-grid-modern{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}@media(max-width:640px){.wallets-grid-modern{grid-template-columns:1fr}}.wallet-card-add{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;background-color:var(--bg-card);border:2px dashed var(--border-light);border-radius:var(--radius-xl);padding:var(--space-6);cursor:pointer;transition:var(--transition-fast)}.wallet-card-add:hover{border-color:var(--primary);background-color:var(--primary-light)}.wallet-card-add-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-light);border-radius:50%;margin-bottom:var(--space-4);color:var(--text-secondary);transition:var(--transition-fast)}.wallet-card-add:hover .wallet-card-add-icon{border-color:var(--primary);color:var(--primary)}.wallet-card-add-text{font-size:.9rem;font-weight:500;color:var(--text-secondary);text-align:center}.wallet-card-add:hover .wallet-card-add-text{color:var(--primary)}.wallet-card-modern{display:flex;flex-direction:column;min-height:220px;border-radius:var(--radius-xl);padding:var(--space-5);color:#fff;text-decoration:none;position:relative;overflow:hidden;transition:var(--transition-fast)}.wallet-card-modern:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.wallet-card-modern-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3)}.wallet-card-modern-name{font-size:1.1rem;font-weight:600;color:#fff;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.1)}.wallet-card-modern-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:var(--radius-md);color:#fff}.wallet-card-modern-balance{margin-bottom:auto}.wallet-card-modern-balance-label{display:block;font-size:.75rem;color:#fffc;margin-bottom:var(--space-1)}.wallet-card-modern-balance-value{font-size:1.5rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.wallet-card-modern-chart{flex:1;display:flex;align-items:flex-end;margin:var(--space-3) calc(-1 * var(--space-5));margin-bottom:0;min-height:40px}.wallet-card-chart{width:100%}.wallet-card-modern-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-2);margin-top:var(--space-2);border-top:1px solid rgba(255,255,255,.2)}.wallet-card-modern-history{font-size:.75rem;color:#ffffffb3}.wallet-card-modern-edit{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:var(--radius-sm);color:#ffffffb3;cursor:pointer;transition:var(--transition-fast);opacity:0}.wallet-card-modern:hover .wallet-card-modern-edit{opacity:1}.wallet-card-modern-edit:hover{background:#ffffff40;color:#fff}.wallet-color-picker{display:flex;gap:var(--space-2);flex-wrap:wrap}.wallet-color-option{width:40px;height:40px;border-radius:var(--radius-md);border:3px solid transparent;cursor:pointer;transition:var(--transition-fast)}.wallet-color-option:hover{transform:scale(1.1)}.wallet-color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--primary)}.wallets-empty-filter{text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary)}.wallets-empty-filter p{font-size:.9rem}.wallet-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:var(--transition-fast);display:block}.wallet-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.wallet-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.wallet-card-header .btn-icon-action{opacity:.7;transition:all var(--transition-fast)}.wallet-card:hover .wallet-card-header .btn-icon-action{opacity:1}.wallet-card-header .btn-icon-action:hover{opacity:1;background-color:var(--primary-light);color:var(--primary);border-color:var(--primary);transform:scale(1.05)}.wallet-card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),#818cf8);border-radius:var(--radius-md);font-size:1.5rem;color:#fff}.wallet-card h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.wallet-card .currency-badge{display:inline-block;padding:4px 10px;background-color:var(--bg-tertiary);border-radius:20px;font-size:.75rem;color:var(--text-secondary)}.wallet-card-balance{font-size:1.75rem;font-weight:700}.wallet-card-balance.positive{color:var(--success)}.wallet-card-balance.negative{color:var(--danger)}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.875rem;font-weight:500;margin-bottom:20px;transition:var(--transition-fast);padding:6px 12px;margin-left:-12px;border-radius:var(--radius-md)}.back-link:hover{color:var(--primary);background-color:var(--primary-light)}.back-link svg{flex-shrink:0}.wallet-header{background:linear-gradient(135deg,#818cf814,#a78bfa0a);border:1px solid rgba(129,140,248,.15);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-6);margin-bottom:var(--space-6);position:relative;overflow:hidden}.wallet-header:before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);opacity:.4;pointer-events:none}.wallet-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4);position:relative;z-index:1}.wallet-header-info{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.wallet-header-info h1{margin:0}.wallet-header-info .btn-edit{opacity:0;transition:opacity var(--transition-fast)}.wallet-header:hover .wallet-header-info .btn-edit{opacity:1}.btn-edit:hover{background-color:var(--primary-light);color:var(--primary);border-color:var(--primary)}.wallet-header h1{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.wallet-balance-large{font-size:2.25rem;font-weight:700;background:linear-gradient(135deg,#a5b4fc,var(--primary),#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;margin:0;letter-spacing:-.02em;text-shadow:0 0 40px var(--primary-glow)}@media(max-width:640px){.wallet-header{padding:var(--space-5)}.wallet-header-content{flex-direction:column;align-items:flex-start}.wallet-balance-large{font-size:1.75rem}}.filters-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px;max-width:250px}.filters-section h3{font-size:.9rem;color:var(--text-secondary);margin-bottom:16px}.filters-row{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end}.filters-row .form-group{margin-bottom:0;min-width:160px;flex:1}@media(max-width:768px){.filters-row{flex-direction:column}.filters-row .form-group{width:100%}}.transactions-list{display:flex;flex-direction:column}.transaction-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background-color:var(--bg-card);border-bottom:1px solid var(--border-color);transition:all var(--transition-normal);border-left:none;border-radius:0}.transaction-item:last-child{border-bottom:none}.transaction-item:hover{background-color:#ffffff05}.transaction-icon-wrapper{flex-shrink:0}.transaction-type-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;transition:transform var(--transition-fast)}.transaction-item:hover .transaction-type-icon{transform:scale(1.05)}.transaction-type-icon.credit{background-color:#34d39926;color:var(--success)}.transaction-type-icon.debit{background-color:#f8717126;color:var(--danger)}.transaction-info{flex:1;min-width:0}.transaction-main{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:2px}.transaction-category{font-weight:600;font-size:.875rem;color:var(--text-primary)}.transaction-subcategory{font-size:.8rem;color:var(--text-muted);font-weight:400}.transaction-description{font-size:.75rem;color:var(--text-secondary);margin:var(--space-1) 0 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.transaction-date{font-size:.7rem;color:var(--text-muted);margin-top:var(--space-1);font-weight:500}.transaction-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.transaction-amount{font-size:.95rem;font-weight:700;white-space:nowrap;letter-spacing:-.01em}.transaction-amount.credit{color:var(--success)}.transaction-amount.debit{color:var(--danger)}.transactions-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.section-toolbar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);flex-wrap:wrap;gap:12px}.toolbar-left{display:flex;align-items:center;gap:10px}.toolbar-left h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.transactions-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background-color:var(--bg-tertiary);border-radius:12px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.toolbar-right{display:flex;align-items:center;gap:10px}.btn-filter{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:.85rem;font-weight:500;color:var(--text-secondary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);position:relative}.btn-filter:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.btn-filter.active{background-color:var(--primary-light);color:var(--primary);border-color:var(--primary)}.btn-filter.has-filters .filter-badge{position:absolute;top:-4px;right:-4px;width:10px;height:10px;background-color:var(--primary);border-radius:50%;border:2px solid var(--bg-secondary)}.btn-filter svg{flex-shrink:0}.filters-panel{padding:16px 20px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filters-grid{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.filter-item{display:flex;flex-direction:column;gap:6px;min-width:140px;flex:1;max-width:200px}.filter-item label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.filter-item input[type=date]{padding:8px 12px;font-size:.85rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-fast)}.filter-item input[type=date]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filter-item .dropdown-trigger{padding:8px 12px;font-size:.85rem}.btn-clear-filters{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:.8rem;font-weight:500;color:var(--danger);background-color:var(--danger-light);border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;margin-left:auto}.btn-clear-filters:hover{background-color:var(--danger);color:#fff}.categories-list{display:flex;flex-direction:column;gap:var(--space-3)}.category-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.category-card:hover{border-color:var(--border-light)}.category-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);cursor:pointer;transition:background-color var(--transition-fast);gap:var(--space-4)}.category-header:hover{background-color:var(--bg-hover)}.category-info{display:flex;flex-direction:column;align-items:start;gap:var(--space-1);flex-wrap:wrap;flex:1;min-width:0}.expand-icon{font-size:.75rem;color:var(--text-muted);flex-shrink:0;width:16px}.category-name{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-type{font-size:.75rem;font-weight:500;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);white-space:nowrap}.category-type.debit{background-color:var(--danger-light);color:var(--danger)}.category-type.credit{background-color:var(--success-light);color:var(--success)}.category-badge{font-size:.7rem;font-weight:500;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background-color:var(--primary-light);color:var(--primary);white-space:nowrap}.category-badge.default{background-color:var(--info-light);color:var(--info)}.category-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.category-actions .btn-secondary{padding:6px 16px}.subcategory-count{font-size:.85rem;color:var(--text-muted);white-space:nowrap;padding:var(--space-1) var(--space-2);background-color:var(--bg-tertiary);border-radius:var(--radius-sm)}.subcategories-list{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--space-2)}.subcategory-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);margin-left:var(--space-6);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.subcategory-item:hover:not(.empty){background-color:var(--bg-hover)}.subcategory-item.empty{color:var(--text-muted);font-style:italic;justify-content:center}.subcategory-name{font-size:.9rem;color:var(--text-secondary)}.hidden-items-section{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--border-color)}.hidden-items-list{margin-top:var(--space-4);padding:var(--space-5);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.hidden-items-list h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);margin-top:var(--space-4)}.hidden-items-list h3:first-child{margin-top:0}.hidden-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.hidden-item span{color:var(--text-secondary)}.categories-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-5);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.toolbar-filters{flex:1;min-width:0}.toolbar-filters .form-group{margin-bottom:0;max-width:250px}.toolbar-actions{display:flex;gap:var(--space-3);flex-shrink:0}@media(max-width:768px){.categories-toolbar{flex-direction:column;align-items:stretch}.toolbar-filters .form-group{max-width:100%}.toolbar-actions{justify-content:flex-end}}@media(max-width:640px){.toolbar-actions{flex-direction:column}.toolbar-actions .btn{width:100%}.category-header{flex-wrap:wrap;padding:var(--space-3) var(--space-4)}.category-info{width:100%;margin-bottom:var(--space-2)}.category-actions{width:100%;justify-content:flex-end}.subcategory-item{margin-left:var(--space-3);padding:var(--space-2) var(--space-3)}}.reports-page{max-width:1400px}.reports-filters{display:flex;gap:var(--space-5);margin-bottom:var(--space-8);padding:var(--space-6);background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-xl);flex-wrap:wrap;box-shadow:0 2px 8px #0000000a}.reports-filters .filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:200px;flex:1}.reports-filters .filter-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.reports-filters .filter-group .dropdown{min-width:200px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);margin-bottom:var(--space-10)}@media(max-width:1200px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.metrics-grid{grid-template-columns:1fr}}.metric-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;align-items:flex-start;gap:var(--space-4);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000a}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:transparent;transition:all .3s ease}.metric-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:transparent}.metric-card.income{background:linear-gradient(135deg,rgba(16,185,129,.08) 0%,var(--bg-card) 50%);border-color:#10b9814d}.metric-card.income:before{background:linear-gradient(90deg,var(--success),#34d399)}.metric-card.expenses{background:linear-gradient(135deg,rgba(239,68,68,.08) 0%,var(--bg-card) 50%);border-color:#ef44444d}.metric-card.expenses:before{background:linear-gradient(90deg,var(--danger),#f87171)}.metric-card.balance{background:linear-gradient(135deg,rgba(99,102,241,.08) 0%,var(--bg-card) 50%);border-color:#6366f14d}.metric-card.balance:before{background:linear-gradient(90deg,var(--primary),#818cf8)}.metric-card.savings{background:linear-gradient(135deg,rgba(245,158,11,.08) 0%,var(--bg-card) 50%);border-color:#f59e0b4d}.metric-card.savings:before{background:linear-gradient(90deg,var(--warning),#fbbf24)}.metric-icon{font-size:2.5rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.metric-content{display:flex;flex-direction:column;gap:var(--space-2);min-width:0;flex:1}.metric-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.875rem;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.metric-value.positive{color:var(--success)}.metric-value.negative{color:var(--danger)}.metric-value.success{color:var(--success)}.metric-value.warning{color:var(--warning)}.metric-value.danger{color:var(--danger)}.metric-sub{font-size:.8rem;color:var(--text-muted);font-weight:500}.metric-alert{font-size:.75rem;color:var(--danger);margin-top:var(--space-1)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);margin-bottom:var(--space-8)}.charts-grid .chart-card.full-width{grid-column:1 / -1}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.chart-card:hover{box-shadow:0 8px 24px #00000014;border-color:var(--border-light)}.chart-card h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-5) 0;padding-bottom:var(--space-3);border-bottom:2px solid var(--border-color)}.chart-container{width:100%;margin-top:var(--space-4)}.chart-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.95rem;font-style:italic;background:var(--bg-tertiary);border-radius:var(--radius-md);border:2px dashed var(--border-color)}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:0 4px 12px #00000026}.chart-tooltip-label{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.chart-tooltip p{margin:var(--space-1) 0;font-size:.8rem;font-weight:500}.chart-legend{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-sm);transition:background-color .2s}.legend-item:hover{background-color:var(--bg-hover)}.legend-color{width:14px;height:14px;border-radius:3px;flex-shrink:0}.legend-label{flex:1;font-size:.875rem;color:var(--text-secondary);font-weight:500}.legend-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.report-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:0 2px 8px #0000000a}.report-section h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-5) 0;padding-bottom:var(--space-3);border-bottom:2px solid var(--border-color)}.top-expenses-list{display:flex;flex-direction:column;gap:var(--space-3)}.top-expense-item{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all .2s}.top-expense-item:hover{background:var(--bg-hover);border-color:var(--primary);transform:translate(4px)}.expense-rank{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary-light);color:var(--primary);font-weight:700;font-size:.875rem;border-radius:var(--radius-md);flex-shrink:0}.expense-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.expense-category{font-size:.95rem;font-weight:600;color:var(--text-primary)}.expense-subcategory{font-size:.875rem;color:var(--text-secondary)}.expense-description{font-size:.85rem;color:var(--text-muted);margin:var(--space-1) 0 0 0;line-height:1.4}.expense-date{font-size:.8rem;color:var(--text-muted)}.expense-amount{font-size:1.125rem;font-weight:700;color:var(--danger);flex-shrink:0}.insights-section{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-secondary) 100%)}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}.insight-card{display:flex;gap:var(--space-3);padding:var(--space-5);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);border-left-width:4px;transition:all .3s}.insight-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.insight-card.success{border-left-color:var(--success);background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--bg-card) 100%)}.insight-card.warning{border-left-color:var(--warning);background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--bg-card) 100%)}.insight-card.info{border-left-color:var(--primary);background:linear-gradient(135deg,rgba(99,102,241,.05) 0%,var(--bg-card) 100%)}.insight-icon{font-size:1.75rem;flex-shrink:0}.insight-content{flex:1}.insight-content strong{display:block;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.insight-content p{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin:0}.budgets-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:900px){.budgets-list{grid-template-columns:1fr}}.budget-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-normal);position:relative;overflow:hidden}.budget-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--success)}.budget-card.warning:before{background:var(--warning)}.budget-card.danger:before{background:var(--danger)}.budget-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.budget-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.budget-info{display:flex;flex-direction:column;gap:var(--space-2)}.budget-category{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.budget-status{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;width:fit-content}.budget-status.success{background-color:var(--success-light);color:var(--success)}.budget-status.warning{background-color:var(--warning-light);color:var(--warning)}.budget-status.danger{background-color:var(--danger-light);color:var(--danger)}.budget-actions{display:flex;gap:var(--space-1)}.budget-actions .btn{padding:var(--space-2);font-size:.9rem}.budget-amounts{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.amount-row{display:flex;justify-content:space-between;align-items:center}.amount-row.remaining{padding-top:var(--space-2);border-top:1px solid var(--border-color);margin-top:var(--space-2)}.amount-label{font-size:.85rem;color:var(--text-secondary)}.amount-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}.amount-value.spent{color:var(--text-primary)}.amount-value.budgeted{color:var(--text-muted)}.amount-value.positive{color:var(--success)}.amount-value.negative{color:var(--danger)}.progress-bar{flex:1;height:8px;background-color:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:visible;position:relative}.progress-fill{height:100%;border-radius:var(--radius-sm);transition:width var(--transition-normal)}.progress-fill.success{background:linear-gradient(90deg,var(--success),#34d399)}.progress-fill.warning{background:linear-gradient(90deg,var(--warning),#fbbf24)}.progress-fill.danger{background:linear-gradient(90deg,var(--danger),#f87171)}.progress-overflow{position:absolute;top:0;left:100%;height:100%;background:linear-gradient(90deg,var(--danger),#dc2626);border-radius:0 var(--radius-sm) var(--radius-sm) 0;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.progress-text{font-size:.85rem;font-weight:600;color:var(--text-primary);min-width:45px;text-align:right}.copy-target{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md);margin:var(--space-4) 0}.copy-arrow{font-size:1.5rem;color:var(--primary)}.copy-target-text{font-size:1rem;font-weight:600;color:var(--text-primary)}.budget-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-5);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-wrap:wrap}.period-selector{display:flex;gap:var(--space-4);flex-wrap:wrap}.period-selector .filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:150px}.period-selector .filter-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.days-remaining{display:flex;flex-direction:column;align-items:center;padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-light) 0%,transparent 100%);border-radius:var(--radius-lg);border:1px solid rgba(99,102,241,.2)}.days-count{font-size:1.75rem;font-weight:700;color:var(--primary);line-height:1}.days-label{font-size:.75rem;color:var(--text-muted);text-transform:lowercase;letter-spacing:.03em}.budget-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}@media(max-width:1024px){.budget-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.budget-summary{grid-template-columns:1fr}}.summary-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-normal);position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--border-color)}.summary-card.total:before{background:var(--primary)}.summary-card.spent:before{background:var(--danger)}.summary-card.remaining:before{background:var(--success)}.summary-card.progress:before{background:var(--warning)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.summary-icon{font-size:1.5rem;flex-shrink:0}.summary-content{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.summary-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.summary-value.positive{color:var(--success)}.summary-value.negative{color:var(--danger)}.summary-value.success{color:var(--success)}.summary-value.warning{color:var(--warning)}.summary-value.danger{color:var(--danger)}.summary-alert{font-size:.75rem;color:var(--danger);margin-top:var(--space-1)}.budget-page-new{padding:0}.budget-header-new{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-6);background:linear-gradient(135deg,#1e3a5f,#2d5a87);border-radius:var(--radius-xl);color:#fff}.budget-month-nav{display:flex;align-items:center;gap:var(--space-4)}.month-nav-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background:#ffffff26;color:#fff;cursor:pointer;transition:all .2s ease}.month-nav-btn:hover{background:#ffffff40;transform:scale(1.1)}.month-display{text-align:center}.month-title{font-size:2rem;font-weight:700;margin:0;color:#fff;line-height:1.2}.month-subtitle{font-size:.9rem;margin:var(--space-1) 0 0;opacity:.8;color:#ffffffd9}.budget-header-right{display:flex;align-items:center;gap:var(--space-6)}.total-remaining{display:flex;flex-direction:column;align-items:flex-end}.total-remaining-label{font-size:.9rem;font-weight:500;color:#ffffffe6}.total-remaining-value{font-size:2rem;font-weight:700;line-height:1.2}.total-remaining-value.positive{color:#4ade80}.total-remaining-value.negative{color:#f87171}.add-transaction-btn{background:#10b981;color:#fff;font-weight:600;padding:var(--space-3) var(--space-5);border:none}.add-transaction-btn:hover{background:#059669}.budget-actions-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);gap:var(--space-3)}.days-remaining-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--primary-light);border-radius:9999px;font-size:.875rem}.days-remaining-badge .days-count{font-weight:700;color:var(--primary)}.days-remaining-badge .days-label{color:var(--primary);font-weight:500}.budget-content-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6)}@media(max-width:1200px){.budget-content-grid{grid-template-columns:1fr}}.budget-categories-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.section-title{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-5) 0}.budget-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media(max-width:1400px){.budget-cards-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.budget-cards-grid{grid-template-columns:1fr}}.budget-card-new{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);position:relative;transition:all .3s ease;cursor:pointer}.budget-card-new:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.budget-card-new:focus{outline:2px solid var(--primary);outline-offset:2px}.budget-card-new.danger{border-color:var(--danger);background:linear-gradient(135deg,rgba(239,68,68,.05) 0%,var(--bg-secondary) 100%)}.budget-card-new.warning{border-color:var(--warning);background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--bg-secondary) 100%)}.budget-card-new.add-budget-card{border:2px dashed var(--border-color);background:transparent;display:flex;align-items:center;justify-content:center;min-height:180px}.budget-card-new.add-budget-card:hover{border-color:var(--primary);background:rgba(var(--primary-rgb),.05)}.add-budget-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:var(--text-secondary)}.add-budget-icon{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:300;color:var(--text-secondary);transition:all .2s ease}.budget-card-new.add-budget-card:hover .add-budget-icon{background:var(--primary);color:#fff}.add-budget-text{font-size:.9375rem;font-weight:500}.budget-card-new.add-budget-card:hover .add-budget-text{color:var(--primary)}.budget-card-content{display:flex;align-items:center;gap:var(--space-4)}.circular-progress-container{position:relative;width:90px;height:90px;flex-shrink:0}.circular-progress{width:100%;height:100%}.circular-progress .progress-bg{stroke:var(--bg-tertiary)}.circular-progress .progress-value{transition:stroke-dashoffset .6s ease}.circular-progress .progress-value.success{stroke:var(--success)}.circular-progress .progress-value.warning{stroke:var(--warning)}.circular-progress .progress-value.danger{stroke:var(--danger)}.progress-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-percentage{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.category-info{flex:1;min-width:0}.category-icon-container{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;margin-bottom:var(--space-2)}.category-svg-icon{width:24px;height:24px}.subcategory-modal-body .category-svg-icon{width:20px;height:20px}.category-icon-small{width:32px;height:32px}.category-icon-small .category-svg-icon{width:16px;height:16px}.category-icon-medium{width:40px;height:40px}.category-icon-medium .category-svg-icon{width:20px;height:20px}.category-icon-large{width:48px;height:48px}.category-icon-large .category-svg-icon{width:24px;height:24px}.category-icon{font-size:1.5rem;display:block}.category-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-amounts{display:flex;flex-direction:column;gap:var(--space-1)}.spent-amount{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.budget-limit{font-size:.85rem;color:var(--text-muted)}.budget-alert{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.8rem;font-weight:600}.budget-alert.warning{background:var(--warning-light);color:var(--warning)}.budget-alert.danger{background:var(--danger-light);color:var(--danger)}.alert-icon{font-size:.9rem}.empty-state-compact{text-align:center;padding:var(--space-8)}.empty-state-compact .empty-state-icon{font-size:3rem;margin-bottom:var(--space-4)}.empty-state-compact h3{margin:0 0 var(--space-2);color:var(--text-primary)}.empty-state-compact p{color:var(--text-muted);margin:0 0 var(--space-4)}.budget-insights-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);height:fit-content}.insights-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}.insights-chart{margin-bottom:var(--space-4)}.insights-chart .trend-line{width:100%;height:auto}.insight-box{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-4)}.insight-box strong{display:block;font-size:.9rem;color:var(--text-primary);margin-bottom:var(--space-2)}.insight-box p{font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--space-3);line-height:1.5}.insight-link{font-size:.85rem;color:var(--primary);text-decoration:none;font-weight:500}.insight-link:hover{text-decoration:underline}.budget-summary-stats{display:flex;flex-direction:column;gap:var(--space-3)}.budget-summary-stats .stat-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.budget-summary-stats .stat-item.alert{background:var(--danger-light)}.budget-summary-stats .stat-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.budget-summary-stats .stat-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.budget-summary-stats .stat-value.spent{color:var(--text-primary)}.budget-summary-stats .stat-value.success{color:var(--success)}.budget-summary-stats .stat-value.warning{color:var(--warning)}.budget-summary-stats .stat-value.danger{color:var(--danger)}@media(max-width:900px){.budget-header-new{flex-direction:column;text-align:center}.budget-header-right{flex-direction:column;align-items:center}.total-remaining{align-items:center}.month-title,.total-remaining-value{font-size:1.5rem}}.suggestions-page{margin:0 auto}.suggestions-page .page-header-actions{display:flex;gap:var(--space-3);align-items:center}.suggestions-page .page-header-actions .btn-secondary{display:flex;align-items:center;gap:var(--space-2)}.others-suggestions-list{max-height:60vh;overflow-y:auto;padding-right:var(--space-2)}.others-suggestions-list::-webkit-scrollbar{width:6px}.others-suggestions-list::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.others-suggestions-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.others-suggestions-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.suggestion-card-readonly{cursor:default}.suggestion-card-readonly:hover{transform:none;border-color:var(--border-color);box-shadow:none}.suggestions-filters{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.suggestions-filters .filter-group{display:flex;align-items:center;gap:var(--space-3)}.suggestions-filters .filter-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.suggestions-count{font-size:.875rem;color:var(--text-muted)}.suggestions-list{display:flex;flex-direction:column;gap:var(--space-4)}.suggestion-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;transition:all var(--transition-fast)}.suggestion-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.suggestion-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.suggestion-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.suggestion-header-actions .btn-delete-action{opacity:0;transform:scale(.9);transition:all .2s cubic-bezier(.4,0,.2,1)}.suggestion-card:hover .suggestion-header-actions .btn-delete-action{opacity:1;transform:scale(1)}.spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}.suggestion-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.suggestion-description{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.suggestion-card-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.suggestion-meta{display:flex;align-items:center;gap:var(--space-2)}.suggestion-category{font-size:.75rem;padding:var(--space-1) var(--space-2);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary)}.suggestion-date{font-size:.8rem;color:var(--text-muted)}.suggestion-has-response{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color)}.response-indicator{font-size:.8rem;color:var(--info);font-weight:500}.status-badge{font-size:.75rem;font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-xl);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.status-pending{background-color:var(--warning-light);color:var(--warning)}.status-reviewed{background-color:var(--info-light);color:var(--info)}.status-accepted{background-color:var(--success-light);color:var(--success)}.status-rejected{background-color:var(--danger-light);color:var(--danger)}.status-implemented{background-color:#10b98133;color:#059669}.priority-badge{font-size:.7rem;font-weight:500;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.priority-low{background-color:var(--bg-tertiary);color:var(--text-muted)}.priority-medium{background-color:var(--warning-light);color:var(--warning)}.priority-high{background-color:var(--danger-light);color:var(--danger)}.suggestion-detail .detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4)}.suggestion-detail .detail-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.detail-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.edit-title-section,.edit-description-section{flex:1;width:100%}.edit-title-section .form-control,.edit-description-section .form-control{width:100%;font-size:1rem}.edit-title-section{margin-bottom:var(--space-4)}.suggestion-detail .detail-meta{display:flex;gap:var(--space-2);margin-bottom:var(--space-5)}.suggestion-detail .detail-section{margin-bottom:var(--space-5)}.suggestion-detail .detail-section h4{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.03em}.suggestion-detail .detail-description{color:var(--text-primary);line-height:1.7;white-space:pre-wrap}.admin-response-section{background-color:var(--info-light);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);padding:var(--space-4)}.admin-response-section h4{color:var(--info)!important}.admin-response-content{color:var(--text-primary);line-height:1.7;white-space:pre-wrap}.suggestion-detail .detail-dates{display:flex;gap:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.suggestion-detail .date-item{display:flex;flex-direction:column;gap:var(--space-1)}.suggestion-detail .date-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.suggestion-detail .date-value{font-size:.9rem;color:var(--text-secondary)}.input-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-1)}.char-count{font-size:.75rem;color:var(--text-muted)}.input-error{border-color:var(--danger)!important}.error-message{font-size:.75rem;color:var(--danger)}.modal-loading{display:flex;justify-content:center;align-items:center;min-height:200px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:768px){.suggestions-filters,.suggestions-filters .filter-group{flex-direction:column;align-items:stretch}.suggestion-card-header{flex-direction:column;gap:var(--space-2)}.suggestion-card-footer{flex-direction:column;align-items:flex-start}.suggestion-detail .detail-dates{flex-direction:column;gap:var(--space-3)}.form-row{grid-template-columns:1fr}}@media(max-width:640px){.suggestion-card{padding:var(--space-4)}.suggestion-title{font-size:1rem}}.profile-page{max-width:800px;margin:0 auto}.profile-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.profile-avatar-section{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-8);background:linear-gradient(135deg,var(--primary) 0%,#a78bfa 100%);color:#fff}.profile-avatar{width:80px;height:80px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;border:3px solid rgba(255,255,255,.3);flex-shrink:0}.profile-name h2{font-size:1.5rem;font-weight:700;margin:0 0 var(--space-1) 0}.profile-role{font-size:.875rem;opacity:.9}.profile-section-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.profile-section-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.profile-section-description{font-size:.875rem;color:var(--text-secondary);margin:var(--space-2) 0 0 0}.profile-info-section{padding:var(--space-6)}.profile-info-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--border-color)}.profile-info-item .profile-info-content{flex:1}.profile-info-item .btn{flex-shrink:0}.profile-info-item:last-child{border-bottom:none}.profile-info-icon{font-size:1.25rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-md);flex-shrink:0}.profile-info-content{display:flex;flex-direction:column;gap:var(--space-1)}.profile-info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.profile-info-value{font-size:1rem;color:var(--text-primary);font-weight:500}.profile-edit-form{padding:var(--space-6)}.profile-edit-form .form-group{margin-bottom:var(--space-5)}.profile-edit-form label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.profile-edit-form input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.profile-edit-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.profile-edit-form input.error{border-color:var(--danger)}.profile-edit-form input:disabled{opacity:.6;cursor:not-allowed}.profile-edit-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-color)}@media(max-width:640px){.profile-avatar-section{flex-direction:column;text-align:center;padding:var(--space-6)}.profile-avatar{width:64px;height:64px;font-size:1.5rem}.profile-name h2{font-size:1.25rem}.profile-edit-actions{flex-direction:column}.profile-edit-actions button{width:100%}}.profile-page-with-sidebar{max-width:1000px}.profile-layout{display:flex;gap:var(--space-6);margin-top:var(--space-6)}.profile-sidebar{width:220px;flex-shrink:0}.profile-nav{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2);position:sticky;top:calc(var(--navbar-height) + var(--space-4))}.profile-nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.profile-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.profile-nav-item.active{background:var(--primary-light);color:var(--primary)}.profile-nav-icon{font-size:1rem;width:24px;text-align:center}.profile-nav-label{flex:1}.profile-content{flex:1;min-width:0}.profile-avatar-section-inline{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.profile-avatar-section-inline .profile-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#a78bfa 100%);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;flex-shrink:0}.profile-name-inline{flex:1}.profile-name-inline h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0}.profile-email{font-size:.875rem;color:var(--text-secondary)}.profile-preference-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--border-color)}.profile-preference-item:last-child{border-bottom:none}.profile-preference-label{display:flex;align-items:center;gap:var(--space-3);font-size:.9375rem;color:var(--text-primary);font-weight:500}.profile-preference-control{display:flex;align-items:center}.preference-select{padding:var(--space-2) var(--space-4);padding-right:var(--space-8);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:180px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color var(--transition-fast)}.preference-select:hover{border-color:var(--border-light)}.preference-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.theme-pill-toggle{display:flex;background:var(--bg-tertiary);border-radius:999px;padding:4px;gap:0}.theme-pill-btn{padding:var(--space-2) var(--space-5);border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;border-radius:999px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.theme-pill-btn:hover:not(.active){color:var(--text-primary)}.theme-pill-btn.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.preference-language-selector{position:relative;display:inline-flex}.preference-language-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-width:160px}.preference-language-btn:hover{background-color:var(--bg-elevated);border-color:var(--border-light)}.preference-language-btn:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.preference-language-btn .language-flag{font-size:1.1rem}.preference-language-btn .language-name{flex:1;text-align:left}.preference-language-btn .language-arrow{font-size:.6rem;color:var(--text-muted);transition:transform var(--transition-fast)}.preference-language-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:180px;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden;animation:dropdownSlideDown .15s ease-out}.preference-language-dropdown .language-option{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:.875rem;color:var(--text-primary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);text-align:left}.preference-language-dropdown .language-option:hover{background-color:var(--bg-hover)}.preference-language-dropdown .language-option.active{background-color:var(--primary-light);color:var(--primary)}.preference-language-dropdown .language-flag{font-size:1.1rem}.preference-language-dropdown .language-name{flex:1}.preference-language-dropdown .language-check{color:var(--primary);font-weight:600}.profile-export-buttons{display:flex;gap:var(--space-3);flex-wrap:wrap}@media(max-width:768px){.profile-layout{flex-direction:column}.profile-sidebar{width:100%}.profile-nav{position:static;display:flex;flex-direction:row;overflow-x:auto;padding:var(--space-1);gap:var(--space-1)}.profile-nav-item{flex:0 0 auto;padding:var(--space-2) var(--space-3);white-space:nowrap}.profile-nav-label{display:inline}.profile-preference-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.profile-preference-control,.preference-select{width:100%}.theme-pill-toggle{width:100%;justify-content:center}.theme-pill-btn{flex:1;text-align:center}.profile-avatar-section-inline{flex-direction:column;text-align:center}.profile-avatar-section-inline .btn{width:100%}}.danger-zone-card{border-color:var(--danger)}.danger-zone-header{border-bottom-color:var(--danger)}.danger-zone-header h3{color:var(--danger)}.danger-zone-text{font-size:.875rem!important;color:var(--text-secondary)!important}.danger-zone-warning{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);margin-bottom:var(--space-5);background:#f8717114;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-md)}.danger-zone-warning-icon{font-size:1.25rem;flex-shrink:0;margin-top:2px}.danger-zone-warning p{font-size:.875rem;color:var(--text-primary);line-height:1.5;margin:0}.admin-page{max-width:1400px;margin:0 auto}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}@media(max-width:1200px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.admin-stats-grid{grid-template-columns:1fr}}.admin-stat-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);transition:all var(--transition-normal)}.admin-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.admin-stat-card.warning{border-color:#f59e0b4d;background:linear-gradient(135deg,rgba(245,158,11,.06) 0%,transparent 100%)}.admin-stat-card.error{border-color:#ef44444d;background:linear-gradient(135deg,rgba(239,68,68,.06) 0%,transparent 100%)}.admin-stat-card.success{border-color:#10b9814d;background:linear-gradient(135deg,rgba(16,185,129,.06) 0%,transparent 100%)}.admin-stat-card.info{border-color:#3b82f64d;background:linear-gradient(135deg,rgba(59,130,246,.06) 0%,transparent 100%)}.admin-stat-icon{font-size:2rem;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.admin-stat-content{display:flex;flex-direction:column;gap:var(--space-1)}.admin-stat-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em}.admin-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.admin-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.admin-section h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-5)}.admin-quick-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.admin-quick-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-normal);text-align:center;text-decoration:none}.admin-quick-link:hover{background-color:var(--bg-elevated);border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.admin-quick-link-icon{font-size:2rem}.admin-quick-link-label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.admin-table-container{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-6)}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background-color:var(--bg-tertiary)}.admin-table th{padding:var(--space-4);text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border-color)}.admin-table td{padding:var(--space-4);font-size:.9rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.admin-table tbody tr{transition:background-color var(--transition-fast)}.admin-table tbody tr:hover{background-color:var(--bg-hover)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table .user-name{display:flex;align-items:center;gap:var(--space-2)}.admin-table .clickable{cursor:pointer;color:var(--primary);font-weight:500;transition:color var(--transition-fast)}.admin-table .clickable:hover{color:var(--primary-hover);text-decoration:underline}.admin-filters{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-4);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:flex-end}.admin-filters .filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:180px}.admin-filters .filter-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.admin-filters .search-group{display:flex;flex-direction:row;gap:var(--space-2);flex:1;min-width:250px}.admin-filters .search-group input{flex:1;padding:var(--space-3);font-size:.9rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.admin-filters .search-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.action-buttons{display:flex;gap:var(--space-2);align-items:center;justify-content:center}.action-buttons .btn{padding:var(--space-2);min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1)}.action-buttons .btn svg{width:16px;height:16px;transition:all .2s}.action-buttons .btn-view{background:linear-gradient(135deg,#6366f114,#6366f105);border:1.5px solid rgba(99,102,241,.3);color:var(--primary)}.action-buttons .btn-view:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.action-buttons .btn-view:hover:not(:disabled) svg{transform:scale(1.1)}.action-buttons .btn-delete-action{background:linear-gradient(135deg,#ef444414,#ef444405);border:1.5px solid rgba(239,68,68,.3);color:var(--danger)}.action-buttons .btn-delete-action:hover:not(:disabled){background:var(--danger);border-color:var(--danger);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.action-buttons .btn-delete-action:hover:not(:disabled) svg{transform:scale(1.1)}.action-buttons .btn:active:not(:disabled){transform:translateY(0)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm);white-space:nowrap}.badge-primary{background-color:var(--primary-light);color:var(--primary)}.badge-success{background-color:var(--success-light);color:var(--success)}.badge-warning{background-color:var(--warning-light);color:var(--warning)}.badge-error{background-color:var(--danger-light);color:var(--danger)}.badge-info{background-color:var(--info-light);color:var(--info)}.badge-default,.badge-neutral{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-assigned{background-color:#ede9fe;color:#7c3aed;font-weight:600}.loading-state{display:flex;justify-content:center;align-items:center;padding:var(--space-12)}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-4)}.pagination .page-info{font-size:.9rem;color:var(--text-secondary)}.pagination-controls{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);background:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-top:var(--space-6);border:1px solid var(--border-color)}.pagination-info{font-size:.9rem;color:var(--text-secondary);text-align:center}.pagination-actions{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-6)}.page-size-selector{display:flex;align-items:center;gap:var(--space-3)}.page-size-selector label{font-size:.875rem;color:var(--text-secondary);white-space:nowrap}.page-size-selector .dropdown{min-width:80px}.pagination-buttons{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);vertical-align:middle}.btn-pagination{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0;font-size:1rem;font-weight:600;line-height:1;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);vertical-align:middle}.btn-pagination:hover:not(:disabled){background-color:var(--primary);color:#fff;border-color:var(--primary)}.btn-pagination:disabled{opacity:.4;cursor:not-allowed;background-color:var(--bg-tertiary);color:var(--text-muted)}.pagination-current{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 var(--space-4);font-size:.9rem;font-weight:500;line-height:1;color:var(--text-primary);white-space:nowrap;vertical-align:middle}@media(max-width:768px){.pagination-controls{padding:var(--space-4)}.pagination-actions{flex-direction:column;gap:var(--space-4)}.page-size-selector,.pagination-buttons{width:100%;justify-content:center}.btn-pagination{min-width:36px;height:36px;font-size:.9rem}.pagination-current{height:36px}}@media(max-width:480px){.pagination-current{height:32px;font-size:.8rem;padding:0 var(--space-2)}.btn-pagination{min-width:32px;height:32px;font-size:.85rem}}.detail-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border-color)}.detail-row:last-child,.detail-row:last-of-type{border-bottom:none}.detail-label{font-size:.85rem;font-weight:500;color:var(--text-secondary);min-width:120px}.description-text{font-size:.95rem;color:var(--text-primary);line-height:1.7;white-space:pre-wrap;background-color:var(--bg-tertiary);padding:var(--space-4);border-radius:var(--radius-md)}.form-control{width:100%;padding:var(--space-3);font-size:.95rem;color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}textarea.form-control{min-height:100px;resize:vertical}.text-muted{color:var(--text-muted)}.admin-table-container .empty-state{padding:var(--space-12);text-align:center;border:none;background:transparent}.admin-table-container .empty-icon{font-size:3rem;margin-bottom:var(--space-4);display:block}.admin-table-container .empty-subtitle{font-size:.9rem;color:var(--text-muted);margin:var(--space-2) 0 var(--space-4) 0;font-style:italic}.modal.modal-large{max-width:700px;padding:0}.modal.modal-large .modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.modal.modal-large .modal-header h2{margin-bottom:0}.modal.modal-large .modal-body{padding:var(--space-5) var(--space-6)}.modal.modal-large .modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);background-color:var(--bg-tertiary)}.modal.modal-lg{max-width:600px;max-height:90vh;padding:0;display:flex;flex-direction:column;overflow:hidden}.modal.modal-lg .modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);flex-shrink:0}.modal.modal-lg .modal-header h2{margin-bottom:0}.modal.modal-lg .modal-body{padding:var(--space-5) var(--space-6);overflow-y:auto;flex:1;min-height:0}.modal.modal-lg .modal-actions{padding:var(--space-4) var(--space-6);margin-top:0;border-top:1px solid var(--border-color);background-color:var(--bg-tertiary);flex-shrink:0}.required{color:var(--danger)}.suggestion-detail .detail-section,.detail-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border-color)}.suggestion-detail .detail-section h4,.detail-section h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3)}.upload-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border-color)}.upload-section h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3)}.upload-actions{margin-top:var(--space-4);display:flex;justify-content:flex-end}@media(max-width:1024px){.admin-filters{flex-direction:column}.admin-filters .filter-group,.admin-filters .search-group{width:100%}}@media(max-width:768px){.admin-table-container{overflow-x:auto}.admin-table{min-width:700px}.admin-table th,.admin-table td{padding:var(--space-3)}}.file-uploader{width:100%}.file-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;cursor:pointer;transition:all var(--transition-normal);background-color:var(--bg-secondary);display:flex;flex-direction:column;gap:var(--space-4);min-height:120px}.file-dropzone.has-files{padding:var(--space-4)}.file-dropzone:hover:not(.disabled){border-color:var(--primary);background-color:var(--primary-light)}.file-dropzone.dragover{border-color:var(--primary);background-color:var(--primary-light);transform:scale(1.01)}.file-dropzone.disabled{opacity:.6;cursor:not-allowed}.file-dropzone.has-error{border-color:var(--danger)}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.dropzone-content.compact{flex-direction:row;justify-content:center;gap:var(--space-3);padding:var(--space-2) 0}.dropzone-content.compact .dropzone-icon{font-size:1.5rem}.dropzone-content.compact .dropzone-text{font-size:.85rem}.dropzone-icon{font-size:2.5rem;opacity:.7}.dropzone-text{font-size:.95rem;color:var(--text-primary);font-weight:500}.dropzone-hint{font-size:.8rem;color:var(--text-muted)}.file-preview-list-inside{display:flex;flex-wrap:wrap;gap:var(--space-2);width:100%}.file-preview-item-compact{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);flex:1 1 auto;min-width:180px;max-width:100%}.file-preview-thumbnail-small{width:36px;height:36px;border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);flex-shrink:0}.file-preview-thumbnail-small img{width:100%;height:100%;object-fit:cover}.file-preview-thumbnail-small .file-icon{font-size:1.2rem}.file-preview-info-compact{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;text-align:left}.file-preview-info-compact .file-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-preview-info-compact .file-size{font-size:.7rem;color:var(--text-muted)}.file-remove-btn-small{width:22px;height:22px;border:none;border-radius:var(--radius-sm);background-color:var(--danger-light);color:var(--danger);font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.file-remove-btn-small:hover:not(:disabled){background-color:var(--danger);color:#fff}.file-remove-btn-small:disabled{opacity:.5;cursor:not-allowed}.file-counter-inside{display:flex;justify-content:center;align-items:center;gap:var(--space-2);font-size:.8rem;color:var(--text-secondary);padding-top:var(--space-2);border-top:1px solid var(--border-color);margin-top:auto}.file-counter-inside .at-limit{color:var(--warning);font-weight:500}.file-error{display:flex;align-items:flex-start;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-3);background-color:var(--danger-light);border-radius:var(--radius-sm);color:var(--danger);font-size:.85rem;text-align:left}.file-error .error-icon{font-size:1rem;flex-shrink:0}.file-counter{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-3);font-size:.85rem;color:var(--text-secondary)}.file-counter .at-limit{color:var(--warning);font-weight:500}.file-limit-hint{color:var(--text-muted)}.file-preview-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4)}.file-preview-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.file-preview-thumbnail{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);flex-shrink:0}.file-preview-thumbnail img{width:100%;height:100%;object-fit:cover}.file-preview-thumbnail .file-icon{font-size:1.5rem}.file-preview-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.file-preview-info .file-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-preview-info .file-size{font-size:.75rem;color:var(--text-muted)}.file-remove-btn{width:28px;height:28px;border:none;border-radius:var(--radius-sm);background-color:var(--danger-light);color:var(--danger);font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.file-remove-btn:hover:not(:disabled){background-color:var(--danger);color:#fff}.file-remove-btn:disabled{opacity:.5;cursor:not-allowed}.attachment-list{margin-top:var(--space-4);padding:var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.attachment-list-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.attachment-items{display:flex;flex-direction:column;gap:var(--space-2)}.attachment-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:all var(--transition-fast)}.attachment-item.clickable{cursor:pointer}.attachment-item.clickable:hover{background-color:var(--bg-hover);border-color:var(--primary)}.attachment-icon{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);flex-shrink:0}.attachment-thumbnail{width:100%;height:100%;object-fit:cover}.file-type-icon{font-size:1.5rem}.attachment-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.attachment-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-size{font-size:.75rem;color:var(--text-muted)}.attachment-actions{display:flex;gap:var(--space-2)}.btn-icon{min-width:36px;height:36px;padding:0 var(--space-2);border:1.5px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary);font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-1);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text-secondary);box-shadow:0 1px 3px #00000014;position:relative;overflow:hidden}.btn-icon:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .2s}.btn-icon:hover:not(:disabled):before{opacity:1}.btn-icon:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0000001f}.btn-icon.btn-download{color:var(--primary);border-color:var(--primary);background:linear-gradient(135deg,var(--primary-light) 0%,rgba(99,102,241,.05) 100%)}.btn-icon.btn-download:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px #6366f14d}.btn-icon.btn-delete{color:var(--danger);border-color:var(--danger);background:linear-gradient(135deg,var(--danger-light) 0%,rgba(239,68,68,.05) 100%)}.btn-icon.btn-delete:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 4px 12px #ef44444d}.btn-icon:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-icon:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.attachment-gallery-overlay{position:fixed;inset:0;background-color:#000000f2;z-index:9999;display:flex;align-items:center;justify-content:center}.gallery-container{width:100%;height:100%;display:flex;flex-direction:column;max-width:1400px;margin:0 auto}.gallery-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:1px solid rgba(255,255,255,.1)}.gallery-title{display:flex;flex-direction:column;gap:var(--space-1)}.gallery-filename{color:#fff;font-size:1rem;font-weight:500}.gallery-counter{color:#fff9;font-size:.85rem}.gallery-actions{display:flex;gap:var(--space-2)}.gallery-btn{width:40px;height:40px;border:none;border-radius:var(--radius-sm);background-color:#ffffff1a;color:#fff;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.gallery-btn:hover:not(:disabled){background-color:#fff3}.gallery-btn.gallery-close{font-size:1.4rem}.gallery-content{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:var(--space-4);min-height:0}.gallery-image-container{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.gallery-image{max-width:100%;max-height:calc(100vh - 200px);object-fit:contain;border-radius:var(--radius-md);box-shadow:0 4px 32px #00000080}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:none;border-radius:50%;background-color:#ffffff1a;color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);z-index:10}.gallery-nav:hover{background-color:#fff3}.gallery-nav-prev{left:var(--space-4)}.gallery-nav-next{right:var(--space-4)}.gallery-thumbnails{display:flex;justify-content:center;gap:var(--space-2);padding:var(--space-4);border-top:1px solid rgba(255,255,255,.1);overflow-x:auto}.gallery-thumbnail{width:64px;height:64px;border:2px solid transparent;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all var(--transition-fast);background:none;padding:0;flex-shrink:0}.gallery-thumbnail img{width:100%;height:100%;object-fit:cover}.gallery-thumbnail:hover{border-color:#ffffff80}.gallery-thumbnail.active{border-color:var(--primary)}.gallery-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:#fff}.gallery-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:#ffffffb3;gap:var(--space-2)}.gallery-error span{font-size:3rem}.gallery-error p{font-size:1rem}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#ffffff1a;font-size:1.5rem}@media(max-width:768px){.gallery-nav{width:36px;height:36px;font-size:1.5rem}.gallery-nav-prev{left:var(--space-2)}.gallery-nav-next{right:var(--space-2)}.gallery-thumbnail{width:48px;height:48px}.gallery-image{max-height:calc(100vh - 180px)}}.suggestion-attachments-indicator{display:flex;align-items:center;gap:var(--space-1);font-size:.8rem;color:var(--text-muted);margin-left:var(--space-3)}.suggestion-attachments-indicator:before{content:"📎"}div:where(.swal2-container){-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.swal2-popup{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-xl)!important;box-shadow:var(--shadow-xl)!important;padding:var(--space-8)!important}.swal2-title{color:var(--text-primary)!important;font-size:1.3rem!important;font-weight:600!important}.swal2-html-container{color:var(--text-secondary)!important;font-size:.95rem!important;line-height:1.6!important}.swal2-icon.swal2-warning{border-color:var(--warning)!important;color:var(--warning)!important}.swal2-icon.swal2-warning .swal2-icon-content{color:var(--warning)!important}.swal2-icon.swal2-error{border-color:var(--danger)!important;color:var(--danger)!important}.swal2-icon.swal2-success{border-color:var(--success)!important;color:var(--success)!important}.swal2-icon.swal2-success .swal2-success-ring{border-color:var(--success-light)!important}.swal2-icon.swal2-success [class^=swal2-success-line]{background-color:var(--success)!important}.swal2-actions{gap:var(--space-3)!important}.swal2-styled.swal2-confirm{background-color:var(--danger)!important;border-radius:var(--radius-max)!important;font-weight:500!important;padding:var(--space-2) var(--space-6)!important;font-size:.9rem!important;transition:opacity var(--transition-fast)!important;border:none!important;box-shadow:none!important}.swal2-styled.swal2-confirm:hover{opacity:.85!important}.swal2-styled.swal2-cancel{background-color:var(--bg-tertiary)!important;color:var(--text-primary)!important;border-radius:var(--radius-max)!important;font-weight:500!important;padding:var(--space-2) var(--space-6)!important;font-size:.9rem!important;transition:background-color var(--transition-fast)!important;border:1px solid var(--border-color)!important;box-shadow:none!important}.swal2-styled.swal2-cancel:hover{background-color:var(--bg-elevated)!important}.btn-outline-secondary.btn-attach{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border:2px dashed var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-tertiary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);justify-content:center}.btn-outline-secondary.btn-attach:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background-color:var(--primary-light)}.btn-outline-secondary.btn-attach:disabled{opacity:.5;cursor:not-allowed}.attachment-preview{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-tertiary)}.attachment-preview-img{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.attachment-preview-file{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.attachment-file-icon{font-size:1.5rem;flex-shrink:0}.attachment-file-name{font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-scanning-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);background-color:#0000008c;border-radius:var(--radius-md);z-index:2;color:#fff;font-size:.8rem;font-weight:500}.scanning-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.attachment-remove-btn{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;border:none;border-radius:50%;background-color:var(--danger);color:#fff;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.attachment-remove-btn:hover:not(:disabled){background-color:var(--danger-dark, #dc2626);transform:scale(1.1)}.attachment-remove-btn:disabled{opacity:.5;cursor:not-allowed}.transaction-meta{display:flex;align-items:center;gap:var(--space-2)}.transaction-attachment-link{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:500;font-family:inherit;color:var(--primary);text-decoration:none;padding:3px 10px 3px 8px;border:1px solid var(--primary-light);cursor:pointer;border-radius:999px;background-color:var(--primary-light);transition:all var(--transition-fast);letter-spacing:.01em}.transaction-attachment-link:hover{background-color:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f140;transform:translateY(-1px)}.transaction-attachment-link:active{transform:translateY(0);box-shadow:none}.transaction-attachment-link svg{flex-shrink:0;width:12px;height:12px}.legal-page{min-height:100vh;background:var(--bg-primary);padding:2rem 1rem}.legal-container{max-width:900px;margin:0 auto;background:var(--bg-card, var(--bg-secondary));border-radius:12px;padding:3rem 2rem;box-shadow:0 2px 8px #0000001a}.legal-container h1{font-size:2.5rem;color:var(--text-primary);margin-bottom:.5rem;font-weight:700}.legal-updated{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem;font-style:italic}.legal-container h2{font-size:1.75rem;color:var(--text-primary);margin-top:2.5rem;margin-bottom:1rem;font-weight:600;border-bottom:2px solid var(--primary);padding-bottom:.5rem}.legal-container h3{font-size:1.25rem;color:var(--text-primary);margin-top:1.5rem;margin-bottom:.75rem;font-weight:600}.legal-container section{margin-bottom:2rem}.legal-container p{color:var(--text-secondary);line-height:1.8;margin-bottom:1rem}.legal-container ul,.legal-container ol{color:var(--text-secondary);line-height:1.8;margin-bottom:1rem;padding-left:2rem}.legal-container li{margin-bottom:.5rem}.legal-container a{color:var(--primary);text-decoration:none;font-weight:500}.legal-container a:hover{text-decoration:underline}.legal-container strong{color:var(--text-primary);font-weight:600}.legal-container code{background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:var(--primary)}.legal-container table{width:100%;border-collapse:collapse;margin:1.5rem 0;background:var(--bg-tertiary);border-radius:8px;overflow:hidden}.legal-container table thead{background:var(--primary);color:#fff}.legal-container table th,.legal-container table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.legal-container table th{font-weight:600;font-size:.95rem}.legal-container table td{font-size:.9rem}.legal-container table tbody tr:last-child td{border-bottom:none}.legal-container table tbody tr:hover{background:var(--bg-hover)}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-bottom:2rem}.back-button:hover{background:var(--primary-hover);transform:translate(-4px)}.future-feature-notice{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:8px;margin:1rem 0 1.5rem;border-left:4px solid #fbbf24}.future-feature-notice p{color:#fff;margin:0;font-weight:500}.legal-acknowledgment{background:var(--success-light);border-left:4px solid var(--success);padding:1.5rem;border-radius:8px;margin-top:2rem}.legal-acknowledgment p{color:var(--text-primary);margin:0}.legal-note{background:var(--info-light);border-left:4px solid var(--info);padding:1.5rem;border-radius:8px;margin-top:2rem}.legal-note p,.legal-note ul{color:var(--text-primary)}body.cookie-banner-visible{padding-bottom:180px}.cookie-banner-overlay{position:fixed;bottom:0;left:0;right:0;z-index:10000;background-color:var(--bg-card, var(--bg-secondary, #ffffff));border-top:3px solid var(--primary, #6366f1);box-shadow:0 -8px 30px #00000059}.cookie-banner{background-color:transparent;padding:1.5rem;animation:slideUp .4s ease;max-width:100%}.cookie-banner-expanded{max-height:80vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-banner-content{margin:0 auto}.cookie-banner-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;position:relative}.cookie-banner-icon{font-size:2rem}.cookie-banner-header h3{font-size:1.5rem;color:var(--text-primary);margin:0;font-weight:600}.cookie-banner-close{position:absolute;right:0;top:0;background:transparent;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.cookie-banner-close:hover{background:var(--danger-light, rgba(220, 38, 38, .1));color:var(--danger, #dc2626)}.cookie-banner-description{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.cookie-banner-link{color:var(--primary, #6366f1);font-weight:500;text-decoration:underline}.cookie-banner-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end}.cookie-banner-actions button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-cookie-accept{background-color:var(--success, #22c55e);color:#fff}.btn-cookie-accept:hover{background-color:#16a34a;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e4d}.btn-cookie-reject{background-color:var(--bg-tertiary, #f3f4f6);color:var(--text-primary, #1f2937);border:2px solid var(--border-color, #e5e7eb)}.btn-cookie-reject:hover{background-color:var(--bg-hover, #e5e7eb);border-color:var(--text-secondary, #6b7280)}.btn-cookie-customize,.btn-cookie-save{background-color:var(--primary, #6366f1);color:#fff}.btn-cookie-customize:hover,.btn-cookie-save:hover{background-color:var(--primary-hover, #4f46e5);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.cookie-preferences{margin:1.5rem 0}.cookie-preference-item{background:var(--bg-tertiary);border-radius:8px;padding:1.25rem;margin-bottom:1rem;border:2px solid var(--border-color);transition:all .2s}.cookie-preference-item:hover{border-color:var(--primary)}.cookie-preference-header{margin-bottom:.5rem}.cookie-preference-header label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.cookie-preference-header input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer;accent-color:var(--primary)}.cookie-preference-header input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.cookie-preference-title{font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.cookie-preference-badge{font-size:.75rem;padding:.25rem .5rem;background:var(--info-light);color:var(--info);border-radius:4px;font-weight:500}.cookie-preference-description{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0;padding-left:2rem}.app-footer{border-top:1px solid var(--border-color);padding:3rem 2rem 1.5rem;margin-top:40px;position:relative;z-index:1}.public-layout{min-height:100vh;display:flex;flex-direction:column}.public-layout .app-footer{margin-top:0}.footer-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-section{display:flex;flex-direction:column}.footer-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.footer-description{color:var(--text-secondary);line-height:1.6;font-size:.9rem}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.footer-links li a,.footer-link-button{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s;display:inline-block}.footer-link-button{background:none;border:none;padding:0;cursor:pointer;text-align:left;font-family:inherit}.footer-links li a:hover,.footer-link-button:hover{color:var(--primary)}.footer-compliance{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.footer-compliance:before{content:"✓";color:var(--success);font-weight:700;font-size:1rem}.footer-bottom{max-width:1200px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-copyright,.footer-version{color:var(--text-secondary);font-size:.875rem;margin:0}@media(max-width:768px){.legal-container{padding:2rem 1.5rem}.legal-container h1{font-size:2rem}.legal-container h2{font-size:1.5rem}.cookie-banner{padding:1rem}.cookie-banner-actions{flex-direction:column}.cookie-banner-actions button{width:100%}.footer-container{grid-template-columns:1fr;gap:1.5rem}.footer-bottom{flex-direction:column;text-align:center}body.cookie-banner-visible{padding-bottom:280px}}@media(max-width:480px){.legal-page{padding:1rem .5rem}.legal-container{padding:1.5rem 1rem;border-radius:8px}.legal-container h1{font-size:1.75rem}.legal-container table{font-size:.85rem}.legal-container table th,.legal-container table td{padding:.75rem .5rem}}.wallet-header-new{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#818cf80f,#a78bfa08);border:1px solid rgba(129,140,248,.12);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);margin-bottom:var(--space-5)}.wallet-header-left{display:flex;align-items:center;gap:var(--space-3)}.wallet-title{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.btn-icon-subtle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition-fast)}.wallet-header-new:hover .btn-icon-subtle{opacity:1}.btn-icon-subtle:hover{background:var(--bg-hover);color:var(--primary)}.wallet-balance-hero{font-size:2.5rem;font-weight:700;margin:0;letter-spacing:-.02em}.wallet-balance-hero.positive{background:linear-gradient(135deg,#34d399,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.wallet-balance-hero.negative{background:linear-gradient(135deg,#f87171,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.import-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);border:2px dashed var(--border-color);border-radius:var(--radius-xl);background:var(--bg-card);margin-bottom:var(--space-5);transition:all var(--transition-normal);cursor:pointer}.import-dropzone:hover,.import-dropzone.dragging{border-color:var(--primary);background:#818cf80a}.import-dropzone.dragging{border-style:solid;transform:scale(1.01)}.dropzone-icon{color:var(--primary);opacity:.6;height:40px}.dropzone-text{font-size:.95rem;color:var(--text-secondary);margin:0}@media(max-width:640px){.import-dropzone{padding:var(--space-3);gap:var(--space-2)}.dropzone-desktop-only{display:none!important}.dropzone-mobile-only{display:flex!important}.import-dropzone.has-file{padding:var(--space-3)}.dropzone-file-info{padding:var(--space-3);gap:var(--space-3)}}.dropzone-mobile-only{display:none}.btn-dropzone{margin-top:var(--space-2);padding:10px 24px;border:1px solid var(--border-color);background:var(--bg-primary)}.btn-dropzone:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.btn-dropzone-mobile{padding:12px 24px;font-size:.95rem;width:100%}.import-dropzone.has-file{cursor:default;padding:var(--space-5)}.dropzone-file-selected{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);width:100%;justify-content:center}@media(max-width:640px){.dropzone-file-selected{flex-direction:column;gap:var(--space-3)}}.dropzone-file-info{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px}.dropzone-file-icon{color:var(--primary);flex-shrink:0;display:flex;align-items:center;justify-content:center}.dropzone-file-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.dropzone-file-name{font-size:.95rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropzone-file-size{font-size:.8rem;color:var(--text-muted)}.btn-remove-file{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.btn-remove-file:hover{background:var(--danger-light);color:var(--danger)}.btn-remove-file:disabled{opacity:.5;cursor:not-allowed}.dropzone-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--danger-light);color:var(--danger);border-radius:var(--radius-md);font-size:.85rem;width:100%;max-width:500px}.btn-analyze{min-width:160px;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.transactions-toolbar{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5)}.search-box{display:flex;align-items:center;gap:var(--space-2);flex:0 1 auto;min-width:220px;max-width:300px;padding:14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-box svg{color:var(--text-muted);flex-shrink:0;width:16px;height:16px}.search-box input{flex:1;border:none;background:transparent;font-size:.9rem;color:var(--text-primary);outline:none;min-width:0}.search-box input::placeholder{color:var(--text-muted)}.filter-dropdowns{display:flex;align-items:center;gap:8px}.filter-type-toggle{display:flex;background-color:var(--bg-card);border-radius:var(--radius-lg);padding:4px;gap:0;flex-shrink:0;border:1px solid var(--border-color)}.filter-type-toggle .type-toggle-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 10px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s ease,color .2s ease;white-space:nowrap;flex:1}.filter-type-toggle .type-toggle-btn:hover:not(.active){color:var(--text-secondary);background:var(--bg-elevated)}.filter-type-toggle .type-toggle-btn.active.expense{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff}.filter-type-toggle .type-toggle-btn.active.income{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.filter-type-toggle .type-toggle-btn.active.all{background:var(--primary);color:#fff}.filter-type-toggle .type-toggle-icon{font-size:.8rem}.filter-dropdowns .dropdown{flex-shrink:0;max-width:200px}.filter-dropdowns .dropdown-trigger{padding:10px 14px;font-size:.9rem;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-color);gap:8px;white-space:nowrap}.filter-dropdowns .dropdown-trigger:hover{background:var(--bg-tertiary);border-color:var(--primary)}.filter-dropdowns .dropdown.open .dropdown-trigger{background:var(--primary-light);border-color:var(--primary)}.filter-dropdowns .dropdown-label{font-weight:500}.filter-dropdowns .dropdown-icon{font-size:1rem;flex-shrink:0}.filter-dropdowns .dropdown-arrow{margin-left:4px;flex-shrink:0}.filter-dropdowns .dropdown-arrow svg{width:12px;height:12px}.btn-clear-filters{padding:10px 14px!important;font-size:.85rem!important;border-radius:var(--radius-lg)!important;white-space:nowrap}.filter-dropdowns .dropdown.filter-active .dropdown-trigger{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.filter-dropdowns .dropdown.filter-active .dropdown-trigger:hover{background:var(--primary-light);border-color:var(--primary)}.btn-new-transaction{display:flex;align-items:center;gap:8px;padding:10px 20px;font-weight:600;margin-left:auto}.transactions-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.transaction-date-group{border-bottom:1px solid var(--border-color)}.transaction-date-group:last-child{border-bottom:none}.date-group-header{font-size:.9rem;font-weight:600;color:var(--text-secondary);padding:var(--space-4) var(--space-5);margin:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.transactions-group-list{display:flex;flex-direction:column}.transaction-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color);transition:all var(--transition-fast)}.transaction-card:last-child{border-bottom:none}.transaction-card:hover{background:#818cf808}.transaction-card-icon{flex-shrink:0}.category-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);transition:transform var(--transition-fast)}.transaction-card:hover .category-icon{transform:scale(1.05)}.transaction-card-content{flex:1;min-width:0}.transaction-card-header{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.transaction-card-category{font-weight:600;font-size:.95rem;color:var(--text-primary)}.transaction-card-separator{color:var(--text-muted);font-size:.85rem}.transaction-card-subcategory{font-size:.85rem;color:var(--text-muted)}.transaction-card-description{font-size:.8rem;color:var(--text-secondary);margin:4px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-card-right{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}.transaction-card-amount{font-size:1rem;font-weight:700;white-space:nowrap}.transaction-card-amount.credit{color:var(--success)}.transaction-card-amount.debit{color:var(--danger)}.transaction-card-actions{display:flex;align-items:center;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast)}.transaction-card:hover .transaction-card-actions{opacity:1}.btn-card-action{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-card-action:hover{background:var(--bg-hover)}.btn-card-action.btn-edit:hover{color:var(--primary);background:var(--primary-light)}.btn-card-action.btn-delete:hover{color:var(--danger);background:#f871711a}@media(max-width:768px){.wallet-header-new{flex-direction:row;align-items:flex-start;gap:var(--space-4);padding:var(--space-5)}.wallet-header-new .wallet-header-left .add-transaction-btn-inline{display:none}.wallet-balance-hero{font-size:2rem}.transactions-toolbar{flex-direction:column;align-items:stretch}.filter-dropdowns{flex-wrap:wrap;gap:8px}.filter-type-toggle{flex:1 1 calc(50% - 4px);min-width:auto}.filter-type-toggle .type-toggle-btn{padding:8px;font-size:.8rem}.filter-dropdowns .dropdown{min-width:auto;flex:1 1 calc(50% - 4px)}.filter-dropdowns .search-box{flex:1 1 calc(50% - 4px);max-width:none;min-width:auto}.filter-dropdowns .dropdown-trigger{padding:10px 12px;font-size:.85rem}.filter-dropdowns .dropdown-icon{font-size:1rem}.filter-dropdowns .dropdown-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.filter-dropdowns .btn-clear-filters{flex:1 1 calc(50% - 4px)}.btn-new-transaction{margin-left:0;justify-content:center}.transaction-card{padding:var(--space-3) var(--space-4)}.transaction-card-actions{opacity:1}.import-dropzone{padding:var(--space-5)}}@media(max-width:480px){.wallet-title{font-size:1.35rem}.wallet-balance-hero{font-size:1.75rem}.category-icon{width:38px;height:38px;font-size:1rem}.transaction-card-amount{font-size:.9rem}.filter-dropdowns{width:100%;gap:6px;display:grid;grid-template-columns:repeat(2,1fr)}.filter-type-toggle{grid-column:span 2}.filter-type-toggle .type-toggle-btn{flex:1;padding:6px 8px;font-size:.75rem;gap:3px}.filter-type-toggle .type-toggle-icon{font-size:.75rem}.filter-dropdowns .dropdown{min-width:0}.filter-dropdowns .search-box{min-width:0;padding:8px 10px}.filter-dropdowns .search-box input{font-size:.8rem}.filter-dropdowns .search-box svg{width:14px;height:14px}.filter-dropdowns .dropdown-trigger{padding:8px 10px;font-size:.8rem;justify-content:flex-start}.filter-dropdowns .dropdown-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.filter-dropdowns .dropdown-icon{font-size:.9rem}.filter-dropdowns .dropdown-arrow svg{width:10px;height:10px}.btn-clear-filters{grid-column:span 2;justify-content:center!important;padding:8px 12px!important;font-size:.8rem!important}}.transactions-container+.modal-overlay .modal-header{flex-direction:row!important}.top-navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height, 64px);background-color:var(--bg-secondary);border-bottom:3px solid var(--primary);z-index:1000;box-shadow:var(--shadow-md)}.navbar-container{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:1400px;margin:0 auto;padding:0 var(--space-6)}.navbar-logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;flex-shrink:0}.navbar-logo-img{width:155px;height:auto;object-fit:contain;filter:drop-shadow(0 2px 8px var(--primary-glow))}.subscription-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm);margin-left:var(--space-2)}.subscription-badge.premium{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f2937}.subscription-badge.trial{background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff}.subscription-badge.free{background:var(--bg-tertiary);color:var(--text-secondary)}.navbar-nav{display:flex;align-items:center;gap:var(--space-1)}.navbar-link{display:flex;align-items:center;padding:var(--space-2) var(--space-4);font-size:.9rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.navbar-link:hover{color:var(--text-primary);background-color:var(--bg-hover)}.navbar-link.active{color:var(--primary);background-color:var(--primary-light)}.navbar-right{display:flex;align-items:center;gap:var(--space-3)}.user-menu-container{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary)}.user-menu-trigger:hover{background:var(--bg-hover);border-color:var(--border-light)}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#a78bfa);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;color:#fff;flex-shrink:0}.user-greeting{font-size:.875rem;font-weight:500;color:var(--text-primary)}.dropdown-arrow{transition:transform var(--transition-fast);color:var(--text-muted)}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;width:100%;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:dropdownFadeIn .15s ease-out;z-index:1001}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:.875rem;color:var(--text-primary);text-decoration:none;background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);text-align:left}.user-dropdown-item:hover{background-color:var(--bg-hover)}.user-dropdown-item.active{background-color:var(--primary-light);color:var(--primary)}.user-dropdown-item.logout{color:var(--danger)}.user-dropdown-item.logout:hover{background-color:var(--danger-light)}.user-dropdown-item svg{flex-shrink:0}.user-dropdown-divider{height:1px;background-color:var(--border-color);margin:var(--space-1) 0}.mobile-only{display:none!important}.desktop-nav{display:flex}.mobile-menu-overlay{display:none;position:fixed;inset:0;top:var(--navbar-height, 64px);background-color:#0009;z-index:998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;opacity:0;transition:opacity .3s ease}.mobile-menu{display:none;position:fixed;top:var(--navbar-height, 64px);left:0;right:0;bottom:0;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:999;height:calc(100vh - var(--navbar-height, 64px));height:calc(100dvh - var(--navbar-height, 64px));overflow-y:auto;transform:translateY(-100%);opacity:0;transition:transform .3s ease,opacity .3s ease}.mobile-menu.open{transform:translateY(0);opacity:1}.mobile-menu-content{display:flex;flex-direction:column;min-height:100%;padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px))}.mobile-nav-links{display:flex;flex-direction:column;gap:var(--space-1);margin-top:20px}.mobile-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:.95rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.mobile-nav-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.mobile-nav-link.active{background-color:var(--primary-light);color:var(--primary)}.mobile-nav-link .nav-icon{font-size:1.1rem;width:24px;text-align:center}.mobile-nav-links.secondary{margin-top:var(--space-2)}.mobile-menu-divider{height:1px;background-color:var(--border-color);margin:var(--space-4) 0}.mobile-settings{display:flex;flex-direction:column;gap:var(--space-3)}.mobile-settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);font-size:.9rem;color:var(--text-secondary)}.mobile-user-section{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--bg-elevated);border-radius:var(--radius-lg);margin-top:auto}.mobile-user-info{display:flex;align-items:center;gap:var(--space-3)}.mobile-user-details{display:flex;flex-direction:column;gap:var(--space-1)}.mobile-user-details .user-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.mobile-logout-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:.85rem;font-weight:500;color:var(--danger);background:var(--danger-light);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.mobile-logout-btn:hover{background:var(--danger);color:#fff}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;background:transparent;border:none;cursor:pointer}.hamburger-line{display:block;width:24px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:var(--transition-normal)}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media(max-width:1024px){.desktop-nav{display:none!important}.mobile-only{display:flex!important}.mobile-menu,.mobile-menu-overlay{display:block}.mobile-menu.open+.mobile-menu-overlay,body.menu-open .mobile-menu-overlay{pointer-events:auto;opacity:1}.navbar-container{padding:0 var(--space-4)}.subscription-badge{font-size:.6rem;padding:2px 6px}}@media(max-width:480px){.subscription-badge{margin-left:var(--space-2)}}.mobile-menu-header{padding:var(--space-4);border-bottom:1px solid var(--border-color)}.mobile-user-header{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;padding:var(--space-2);margin:calc(-1 * var(--space-2));border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.mobile-user-header:hover{background-color:var(--bg-hover)}.mobile-user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.mobile-user-info{display:flex;flex-direction:column;gap:2px}.mobile-user-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.mobile-user-tier{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.mobile-user-tier.premium{color:var(--success)}.mobile-user-tier.free{color:var(--text-muted)}.mobile-nav-link .nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.mobile-nav-link .nav-icon svg{color:var(--text-secondary)}.mobile-nav-link.active .nav-icon svg{color:var(--primary)}.mobile-menu-bottom{margin-top:auto;display:flex;flex-direction:column}.mobile-menu-bottom .mobile-nav-links.secondary{border-top:1px solid var(--border-color);padding-top:var(--space-3)}.mobile-logout-link{color:var(--danger)!important;background:transparent;border:none;width:100%;text-align:left;cursor:pointer}.mobile-logout-link:hover{background-color:var(--danger-light)!important}.mobile-logout-link .nav-icon svg{stroke:var(--danger)!important}.mobile-footer-logo{display:flex;align-items:center;gap:.5rem}.mobile-footer-dot{width:8px;height:8px;border-radius:50%;background-color:var(--primary)}.mobile-footer-brand{font-size:.9rem;font-weight:600;color:var(--text-primary)}.mobile-footer-version{font-size:.7rem;color:var(--text-muted);margin-left:calc(8px + .5rem)}.mobile-menu-content{display:flex;flex-direction:column;height:100%}.add-transaction-btn-global{position:fixed;top:20px;right:32px;z-index:100;display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #6366f140,0 4px 16px #6366f126;transition:all var(--transition-normal)}.add-transaction-btn-inline{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #6366f140,0 4px 16px #6366f126;transition:all var(--transition-normal)}.add-transaction-btn-inline:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159,0 8px 24px #6366f133}.add-transaction-btn-inline:active{transform:translateY(0)}.add-transaction-btn-inline:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-transaction-btn-inline svg{flex-shrink:0}.add-transaction-btn-global:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159,0 8px 24px #6366f133}.add-transaction-btn-global:active{transform:translateY(0)}.add-transaction-btn-global:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-transaction-btn-global svg{flex-shrink:0}.add-transaction-btn-text{white-space:nowrap;line-height:0}@media(max-width:1024px){.add-transaction-btn-global{top:auto;bottom:24px;right:24px;padding:14px 20px;border-radius:var(--radius-xl);box-shadow:0 4px 16px #6366f14d,0 8px 32px #0003}}@media(max-width:640px){.add-transaction-btn-global{bottom:20px;right:20px;padding:14px;border-radius:50%;width:56px;height:56px;justify-content:center}.add-transaction-btn-global .add-transaction-btn-text{display:none}.add-transaction-btn-global svg{width:24px;height:24px}}[data-theme=light] .add-transaction-btn-global{box-shadow:0 2px 8px #4f46e533,0 4px 16px #4f46e51f}[data-theme=light] .add-transaction-btn-global:hover{box-shadow:0 4px 12px #4f46e54d,0 8px 24px #4f46e526}[data-theme=light] .add-transaction-btn-inline{box-shadow:0 2px 8px #4f46e533,0 4px 16px #4f46e51f}[data-theme=light] .add-transaction-btn-inline:hover{box-shadow:0 4px 12px #4f46e54d,0 8px 24px #4f46e526}.add-transaction-btn-inline.add-transaction-btn-budget,.add-transaction-btn-global.add-transaction-btn-budget{background:linear-gradient(135deg,var(--primary) 0%,#4caf50 100%);box-shadow:0 2px 8px #4caf5040,0 4px 16px #4caf5026}.add-transaction-btn-inline.add-transaction-btn-budget:hover,.add-transaction-btn-global.add-transaction-btn-budget:hover{box-shadow:0 4px 12px #4caf5059,0 8px 24px #4caf5033}[data-theme=light] .add-transaction-btn-inline.add-transaction-btn-budget,[data-theme=light] .add-transaction-btn-global.add-transaction-btn-budget{box-shadow:0 2px 8px #4caf5033,0 4px 16px #4caf501f}[data-theme=light] .add-transaction-btn-inline.add-transaction-btn-budget:hover,[data-theme=light] .add-transaction-btn-global.add-transaction-btn-budget:hover{box-shadow:0 4px 12px #4caf504d,0 8px 24px #4caf5026}@media(max-width:640px){.add-transaction-btn-inline{padding:8px 14px;font-size:13px}.add-transaction-btn-inline svg{width:18px;height:18px}}@media(max-width:480px){.add-transaction-btn-inline{padding:10px;border-radius:var(--radius-md)}}.dashboard-page{max-width:1400px;margin:0 auto}.dashboard-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}@media(min-width:641px){.dashboard-page .page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}}.dashboard-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);margin-bottom:var(--space-6)}@media(max-width:1024px){.dashboard-stats-row{grid-template-columns:1fr;gap:var(--space-4)}.dashboard-stat-card .stat-sparkline{min-width:50%;height:70px}}@media(max-width:640px){.dashboard-stats-row{gap:var(--space-3)}.dashboard-stat-card{min-height:auto;padding:var(--space-4);flex-direction:row;align-items:center}.dashboard-stat-card .stat-content{flex:0;min-width:50%}.dashboard-stat-card .stat-value{font-size:1.5rem}.dashboard-stat-card .stat-sparkline{width:100%;min-width:50%;max-width:100px;height:50px;flex:0 0 auto}}.dashboard-stat-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:row;align-items:stretch;gap:var(--space-3);position:relative;overflow:hidden;transition:all var(--transition-normal);min-height:120px}.dashboard-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.dashboard-stat-card .stat-content{display:flex;flex-direction:column;justify-content:center;gap:var(--space-1);flex-shrink:0;z-index:1}.dashboard-stat-card .stat-header{display:flex;justify-content:space-between;align-items:flex-start}.dashboard-stat-card .stat-label{font-size:.85rem;font-weight:500;color:var(--text-secondary);margin:0}.dashboard-stat-card .stat-value{font-size:1.75rem;font-weight:700;line-height:1.2;margin:var(--space-1) 0;white-space:nowrap}.dashboard-stat-card .stat-subtitle{font-size:.8rem;color:var(--text-muted);margin:0;white-space:nowrap}.dashboard-stat-card .stat-sparkline{flex:1;min-width:50%;height:100%;opacity:.9;align-self:center}.dashboard-stat-card.balance{background:linear-gradient(135deg,#3b82f60a,#3b82f605);border-color:#3b82f626}.dashboard-stat-card.balance .stat-value{color:#2563eb}.dashboard-stat-card.income{background:linear-gradient(135deg,#22c55e0a,#22c55e05);border-color:#22c55e26}.dashboard-stat-card.income .stat-value{color:#16a34a}.dashboard-stat-card.expenses{background:linear-gradient(135deg,#ef44440a,#ef444405);border-color:#ef444426}.dashboard-stat-card.expenses .stat-value{color:#dc2626}.dashboard-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1100px){.dashboard-main-grid{grid-template-columns:1fr}}.dashboard-chart-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5)}.dashboard-chart-card h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-4) 0}.chart-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:300px;position:relative}@media(max-width:640px){.chart-container{min-height:250px}}.chart-center-label{position:absolute;top:200px;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;z-index:10}.chart-center-label .label{font-size:1rem;color:var(--text-muted);display:block;font-weight:500}.chart-center-label .value{font-size:1.85rem;font-weight:700;color:var(--text-primary);display:block;margin-top:var(--space-1)}@media(max-width:640px){.chart-center-label{top:125px}.chart-center-label .value{font-size:1.25rem}.chart-center-label .label{font-size:.85rem}}.category-legend{width:100%;display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.category-legend-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.category-legend-item:hover{background-color:var(--bg-tertiary)}.category-legend-color{width:12px;height:12px;border-radius:4px;flex-shrink:0}.category-legend-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.category-legend-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-legend-value{font-size:.8rem;color:var(--text-muted)}.category-legend-percent{font-size:.9rem;font-weight:600;color:var(--text-secondary);min-width:45px;text-align:right}.category-legend-more{font-size:.85rem;color:var(--text-muted);text-align:center;padding:var(--space-2);font-style:italic}.chart-quick-stats{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.chart-stat{text-align:center;padding:var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.chart-stat-value{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.chart-stat-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}@media(max-width:640px){.chart-quick-stats{grid-template-columns:1fr;gap:var(--space-2)}.chart-stat{padding:var(--space-2);display:flex;justify-content:space-between;align-items:center}.chart-stat-value{font-size:1rem;margin-bottom:0}.chart-stat-label{font-size:.65rem}}.dashboard-right-panel{display:flex;flex-direction:column;gap:var(--space-5)}.financial-health-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.financial-health-card h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-5) 0;display:flex;align-items:center;gap:var(--space-2)}.financial-health-card h2 svg{color:var(--text-muted)}.health-score-container{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-5)}.health-score-circle{position:relative;width:100px;height:100px;flex-shrink:0}.health-score-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.health-score-circle .circle-bg{fill:none;stroke:var(--bg-tertiary);stroke-width:8}.health-score-circle .circle-progress{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .5s ease-out}.health-score-circle .circle-progress.excellent{stroke:url(#healthGradientExcellent)}.health-score-circle .circle-progress.good{stroke:url(#healthGradientGood)}.health-score-circle .circle-progress.average{stroke:url(#healthGradientAverage)}.health-score-circle .circle-progress.poor{stroke:url(#healthGradientPoor)}.health-score-circle .circle-progress.critical{stroke:url(#healthGradientCritical)}.health-score-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.health-score-text .score-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;display:block}.health-score-text .score-percent{font-size:.85rem;color:var(--text-muted)}.health-info{flex:1}.health-status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:9999px;font-size:.85rem;font-weight:600;margin-bottom:var(--space-3)}.health-status-badge.excellent{background-color:#16a34a1a;color:#16a34a}.health-status-badge.good{background-color:#22c55e1a;color:#22c55e}.health-status-badge.average{background-color:#eab3081a;color:#ca8a04}.health-status-badge.poor{background-color:#f973161a;color:#ea580c}.health-status-badge.critical{background-color:#dc26261a;color:#dc2626}.health-status-badge svg{width:16px;height:16px}.health-message{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0}.health-progress-bar{height:10px;background-color:var(--bg-tertiary);border-radius:5px;overflow:hidden;margin-top:var(--space-4)}.health-progress-fill{height:100%;border-radius:5px;transition:width .5s ease-out}.health-progress-fill.excellent{background:linear-gradient(90deg,#3b82f6,#22c55e)}.health-progress-fill.good{background:linear-gradient(90deg,#3b82f6,#4ade80)}.health-progress-fill.average{background:linear-gradient(90deg,#3b82f6,#facc15)}.health-progress-fill.poor{background:linear-gradient(90deg,#3b82f6,#f97316)}.health-progress-fill.critical{background:linear-gradient(90deg,#3b82f6,#dc2626)}.health-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.health-metric{text-align:center}.health-metric-value{font-size:1.1rem;font-weight:700;color:var(--text-primary);display:block}.health-metric-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}@media(max-width:640px){.financial-health-card{padding:var(--space-4)}.health-score-container{flex-direction:column;text-align:center;gap:var(--space-3)}.health-score-circle{width:80px;height:80px}.health-score-text .score-value{font-size:1.5rem}.health-info{text-align:center}.health-metrics{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.health-metric-value{font-size:.95rem}.health-metric-label{font-size:.65rem}}.recent-transactions-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);flex:1}.recent-transactions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.recent-transactions-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.recent-transactions-header .view-all-btn{padding:var(--space-2) var(--space-4);font-size:.8rem;font-weight:500;color:var(--text-secondary);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.recent-transactions-header .view-all-btn:hover{background-color:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-light)}.transactions-table{width:100%;border-collapse:collapse;table-layout:fixed}.transactions-table thead th:nth-child(1),.transactions-table tbody td:nth-child(1){width:52px;padding-left:var(--space-2);padding-right:var(--space-2)}.transactions-table thead th:nth-child(2),.transactions-table tbody td:nth-child(2){width:100px}.transactions-table thead th:nth-child(3),.transactions-table tbody td:nth-child(3){width:auto}.transactions-table thead th:nth-child(4),.transactions-table tbody td:nth-child(4){width:120px}.transactions-table thead th:nth-child(5),.transactions-table tbody td:nth-child(5){width:100px}.transactions-table thead tr{box-shadow:inset 0 -1px 0 var(--border-color)}.transactions-table thead th{font-size:.75rem;font-weight:500;color:var(--text-muted);text-align:left;padding:var(--space-2) var(--space-3);text-transform:uppercase;letter-spacing:.03em;vertical-align:middle;background:var(--bg-card)}.transactions-table thead th:last-child{text-align:right}.transactions-table tbody tr{transition:background-color var(--transition-fast)}.transactions-table tbody tr:hover{background-color:var(--bg-tertiary)}.transactions-table tbody td{padding:var(--space-3);vertical-align:middle;border-bottom:1px solid var(--border-color)}.transactions-table tbody tr:last-child td{border-bottom:none}.transaction-row-icon{width:24px;height:24px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1rem}.transaction-row-icon.food{background-color:#fef3c7}.transaction-row-icon.income{background-color:#d1fae5}.transaction-row-icon.housing{background-color:#dbeafe}.transaction-row-icon.shopping{background-color:#fce7f3}.transaction-row-icon.transport{background-color:#fee2e2}.transaction-row-icon.entertainment{background-color:#e9d5ff}.transaction-row-icon.health{background-color:#ccfbf1}.transaction-row-icon.education{background-color:#cffafe}.transaction-row-icon.other{background-color:#f3f4f6}.transaction-date{font-size:.85rem;color:var(--text-primary);white-space:nowrap;vertical-align:middle}.transaction-description{font-size:.85rem;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-category-cell{font-size:.85rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-amount-cell{font-size:.9rem;font-weight:600;text-align:right;white-space:nowrap}.transaction-amount-cell.credit{color:#16a34a}.transaction-amount-cell.debit{color:#dc2626}.transactions-empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-muted)}.transactions-empty p{margin:0 0 var(--space-4) 0}.chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);margin-top:var(--space-4);justify-content:center}.chart-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:.8rem;color:var(--text-secondary)}.chart-legend-color{width:12px;height:12px;border-radius:3px}[data-theme=dark] .dashboard-stat-card.balance{background:linear-gradient(135deg,#3b82f614,#3b82f60a)}[data-theme=dark] .dashboard-stat-card.income{background:linear-gradient(135deg,#22c55e14,#22c55e0a)}[data-theme=dark] .dashboard-stat-card.expenses{background:linear-gradient(135deg,#ef444414,#ef44440a)}[data-theme=dark] .transaction-row-icon.food{background-color:#fef3c733}[data-theme=dark] .transaction-row-icon.income{background-color:#d1fae533}[data-theme=dark] .transaction-row-icon.housing{background-color:#dbeafe33}[data-theme=dark] .transaction-row-icon.shopping{background-color:#fce7f333}[data-theme=dark] .transaction-row-icon.transport{background-color:#fee2e233}[data-theme=dark] .transaction-row-icon.entertainment{background-color:#e9d5ff33}[data-theme=dark] .transaction-row-icon.health{background-color:#ccfbf133}[data-theme=dark] .transaction-row-icon.education{background-color:#cffafe33}[data-theme=dark] .transaction-row-icon.other{background-color:#f3f4f633}@media(max-width:768px){.transactions-table{table-layout:auto}.transactions-table thead{display:none}.transactions-table tbody tr{display:flex;flex-wrap:wrap;padding:var(--space-3);border-bottom:1px solid var(--border-color);gap:var(--space-2);align-items:center}.transactions-table tbody td{padding:0;border:none;width:auto!important}.transactions-table tbody td:first-child{width:auto!important}.transactions-table tbody td:nth-child(2){width:70px!important}.transactions-table tbody td:nth-child(3){flex:1;min-width:0}.transactions-table tbody td:nth-child(4){display:none}.transactions-table tbody td:last-child{margin-left:auto;width:auto!important}}@media(max-width:768px){body:has(.modal-overlay){overflow:hidden!important;position:fixed;width:100%;height:100%;top:0;left:0}.modal-overlay{overflow:hidden!important;padding:0!important;position:fixed!important;inset:0!important}}.import-mobile-cards{display:none;flex-direction:column;gap:12px;padding:0}.import-mobile-header-info,.import-mobile-toggle-filter,.import-file-badge-mobile{display:none}@media(max-width:768px){.modal.modal-xlarge .modal-header h2{font-size:1.15rem}}.import-tx-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:visible;transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.import-tx-card.has-error{border-color:#f871714d;background:#f8717108}.import-tx-card.selected{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary-light)}.import-tx-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0}.import-tx-card-checkbox{display:flex;align-items:center;gap:12px}.import-tx-card-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}.import-tx-card-date{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);font-weight:500}.import-tx-card-date-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-muted)}.import-tx-card-status{display:flex;align-items:center;gap:6px}.import-tx-card-status .status-badge-mobile{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:1rem}.status-badge-mobile.valid{background-color:var(--success-light);color:var(--success)}.status-badge-mobile.warning{background-color:var(--warning-light);color:var(--warning)}.status-badge-mobile.error{background-color:var(--danger-light);color:var(--danger)}.import-tx-card-status .validated-text{font-size:.75rem;color:var(--success);font-weight:500}.import-tx-card-body{padding:16px;display:flex;flex-direction:column;gap:12px}.import-tx-card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.import-tx-card-field{display:flex;flex-direction:column}.import-tx-card-field label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;letter-spacing:.03em}.import-tx-card-field.description-field{flex:1}.import-tx-card-field.value-field{flex-shrink:0;text-align:right}.import-tx-card-description-text{font-size:.9rem;color:var(--text-primary);line-height:1.4;word-break:break-word}.import-tx-card-amount-value{font-size:1rem;font-weight:600;padding:6px 12px;border-radius:var(--radius-md);display:inline-flex;align-items:center;gap:4px}.import-tx-card-amount-value.expense{background:#ef444426;color:#ef4444}.import-tx-card-amount-value.income{background:#10b98126;color:#10b981}.import-tx-amount-input{background:transparent;border:none;color:inherit;font-size:inherit;font-weight:inherit;width:80px;text-align:right;padding:0}.import-tx-amount-input:focus{outline:none}.import-tx-currency{font-weight:500}.import-tx-card-categories{display:flex;gap:12px}.import-tx-card-categories>div{flex:1}.import-tx-card-categories label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;letter-spacing:.03em}.import-tx-card-categories .dropdown{width:100%}.import-tx-card-categories .dropdown-trigger{width:100%;padding:10px 12px;font-size:.9rem}.import-mobile-footer{display:none;position:sticky;bottom:0;left:0;right:0;padding:16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:100}.import-mobile-footer .btn-primary{width:100%;padding:14px 24px;font-size:1rem;font-weight:600;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:8px}@media(max-width:768px){.import-table-container{display:none!important}.import-mobile-cards{display:flex}.import-mobile-header-info{display:block;margin-bottom:16px}.import-file-badge-mobile{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-secondary);margin-bottom:12px}.import-file-badge-mobile svg{color:var(--danger)}.import-mobile-toggle-filter{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:16px}.import-mobile-toggle-filter label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.toggle-switch{position:relative;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:26px;border:1px solid var(--border-color)}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary);border-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.modal.modal-xlarge .modal-footer{display:none!important}.import-mobile-footer{display:block}.import-toolbar{display:none!important}.import-header-info{display:none}.modal.modal-xlarge{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden;position:relative;margin:0;border-radius:0}.modal.modal-xlarge .modal-header{flex-direction:column;gap:8px;flex-shrink:0}.modal.modal-xlarge .modal-header h2{font-size:1.25rem}.modal.modal-xlarge .modal-body{padding:16px;flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.import-preview-body{display:flex;flex-direction:column;gap:0;height:100%;overflow:visible}.import-mobile-cards{flex:1;padding-bottom:80px;overflow:visible}.import-mobile-footer{position:fixed;bottom:0;left:0;right:0;z-index:1000}.import-tx-card input[type=date]{background:transparent;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:0;width:auto}.import-tx-card input[type=date]::-webkit-calendar-picker-indicator{display:none}.import-tx-card .dropdown{position:static}.import-tx-card .dropdown.open .dropdown-menu{position:fixed!important;inset:50% auto auto 50%!important;transform:translate(-50%,-50%)!important;width:calc(100vw - 48px);max-width:320px;max-height:70vh;border-radius:16px;z-index:10001;animation:scaleInModal .2s ease-out;box-shadow:0 8px 32px #0006}.import-tx-card .dropdown.open .dropdown-list{max-height:calc(70vh - 16px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 0}.import-tx-card .dropdown.open .dropdown-item{padding:14px 20px;font-size:1rem}.import-tx-card .dropdown.open:before{content:"";position:fixed;inset:0;width:100vw;height:100vh;background:#000000b3;z-index:10000;animation:fadeInBackdrop .15s ease-out}@keyframes scaleInModal{0%{transform:translate(-50%,-50%) scale(.9);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}}@media(max-width:768px){.import-warnings{margin-bottom:16px}}@media(max-width:768px){.import-empty{padding:32px 16px}}.icon-picker{position:relative;width:100%}.icon-picker-trigger{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease}.icon-picker-trigger:hover{border-color:var(--primary);background:var(--bg-tertiary)}.icon-picker-preview{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:currentColor}.icon-picker-preview svg{width:16px;height:16px;color:#fff;fill:#fff}.icon-picker-label{flex:1;text-align:left;font-size:14px;color:var(--text-secondary)}.icon-picker-arrow{color:var(--text-secondary)}.icon-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0003;z-index:1000;max-height:320px;overflow:hidden;display:flex;flex-direction:column}.icon-picker-search{padding:12px;border-bottom:1px solid var(--border-color)}.icon-picker-search input{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px}.icon-picker-search input:focus{outline:none;border-color:var(--primary)}.icon-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;padding:12px;overflow-y:auto;max-height:240px}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;padding:10px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .15s ease;color:var(--text-secondary)}.icon-picker-item:hover{background:var(--bg-hover);color:var(--text-primary);transform:scale(1.05)}.icon-picker-item.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.icon-picker-item svg{width:22px;height:22px}.icon-picker-empty{padding:24px;text-align:center;color:var(--text-secondary);font-size:14px}@media(max-width:480px){.icon-picker-grid{grid-template-columns:repeat(5,1fr)}}.color-picker{position:relative;width:100%}.color-picker-trigger{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease}.color-picker-trigger:hover{border-color:var(--primary);background:var(--bg-tertiary)}.color-picker-preview{width:28px;height:28px;border-radius:8px;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.color-picker-label{flex:1;text-align:left;font-size:14px;color:var(--text-secondary)}.color-picker-arrow{color:var(--text-secondary)}.color-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0003;z-index:1000;padding:16px}.color-picker-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:10px}.color-picker-item{width:100%;aspect-ratio:1;border-radius:10px;border:3px solid transparent;cursor:pointer;transition:all .15s ease;position:relative}.color-picker-item:hover{transform:scale(1.1)}.color-picker-item.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary)}.color-picker-item.selected:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d}.color-picker-custom{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.color-picker-custom label{font-size:13px;color:var(--text-secondary);white-space:nowrap;margin-bottom:3px}.color-picker-custom input[type=color]{flex:1;height:40px;border:none;border-radius:8px;cursor:pointer;background:transparent}.color-picker-custom input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-custom input[type=color]::-webkit-color-swatch{border:2px solid var(--border-color);border-radius:8px}.categories-page-new{margin:0 auto}.categories-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6);gap:var(--space-4)}.categories-page-header-left h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.categories-page-header-left p{font-size:.95rem;color:var(--text-secondary)}.categories-page-header-actions{display:flex;gap:var(--space-3);flex-shrink:0}.btn-new-category{display:flex;align-items:center;gap:var(--space-2);padding:10px 20px;font-size:.9rem;font-weight:600;color:#fff;background-color:#f97316;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.btn-new-category:hover{background-color:#ea580c;transform:translateY(-1px)}.btn-new-subcategory{display:flex;align-items:center;gap:var(--space-2);padding:10px 20px;font-size:.9rem;font-weight:500;color:var(--text-primary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.btn-new-subcategory:hover{background-color:var(--bg-hover);border-color:var(--border-light)}.categories-filters-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.categories-type-tabs{display:flex;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:4px;overflow:hidden}.category-type-tab{padding:10px 20px;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.category-type-tab:hover{color:var(--text-primary);background-color:var(--bg-hover)}.category-type-tab.active{color:var(--text-primary);background-color:var(--bg-secondary);box-shadow:var(--shadow-sm)}[data-theme=light] .category-type-tab.active{background-color:#fff;box-shadow:0 1px 3px #0000001a}.categories-search-box{position:relative;flex:1;max-width:280px;min-width:180px}.categories-search-box input{width:100%;padding:10px 16px 10px 42px;font-size:.9rem;color:var(--text-primary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.categories-search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.categories-search-box input::placeholder{color:var(--text-muted)}.categories-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.categories-action-buttons{display:flex;gap:var(--space-3);flex-shrink:0}.categories-section{margin-bottom:var(--space-8)}.categories-section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.categories-section-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.categories-section-subtitle{font-size:.85rem;font-weight:500;color:#f97316}.categories-section-subtitle.income{color:var(--success)}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.category-card-new{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);transition:all var(--transition-normal);position:relative}.category-card-new:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.category-card-header{display:flex;align-items:flex-start;gap:var(--space-4)}.category-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.category-card-icon svg{width:24px;height:24px}.category-card-info{flex:1;min-width:0}.category-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.category-card-description{font-size:.85rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.category-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.category-tag{padding:4px 10px;font-size:.75rem;font-weight:500;color:var(--text-secondary);background-color:var(--bg-tertiary);border-radius:var(--radius-max);white-space:nowrap}.category-tag.more{color:var(--text-muted);background-color:transparent;padding-left:4px}.category-budget-row{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);border-top:1px solid var(--border-color);margin-top:auto}.category-budget-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.category-budget-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.category-recurrence{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);border-top:1px solid var(--border-color)}.category-recurrence-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.category-recurrence-value{font-size:.85rem;font-weight:600;color:#f97316}.category-recurrence-value.variable{color:var(--primary)}.add-category-card{background-color:var(--bg-card);border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);min-height:200px;cursor:pointer;transition:all var(--transition-normal)}.add-category-card:hover{border-color:var(--primary);background-color:var(--bg-hover)}.add-category-icon{width:40px;height:40px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.5rem;transition:all var(--transition-fast)}.add-category-card:hover .add-category-icon{background-color:var(--primary-light);color:var(--primary)}.add-category-text{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.category-card-actions{position:absolute;top:var(--space-3);right:var(--space-3);display:flex;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast)}.category-card-action-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:none;background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.category-card-action-btn:hover{background-color:var(--danger-light);color:var(--danger)}.categories-hidden-toggle{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-color)}.categories-hidden-toggle .btn-link{background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;padding:var(--space-2) 0;display:flex;align-items:center;gap:var(--space-2)}.categories-hidden-toggle .btn-link:hover{color:var(--primary)}.categories-empty-state{text-align:center;padding:var(--space-12) var(--space-6);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.categories-empty-state p{color:var(--text-secondary);margin-bottom:var(--space-2)}.categories-empty-state p:first-child{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.subcategory-modal{max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column;padding:0;overflow:hidden;border-radius:var(--radius-xl)}.subcategory-modal-header{padding:var(--space-5) var(--space-5) var(--space-4);flex-shrink:0}.subcategory-modal-title-row{display:flex;flex-direction:column;gap:var(--space-1)}.subcategory-modal-title-row h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:var(--space-2)}.subcategory-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;font-size:.85rem;font-weight:600;color:#f97316;background-color:#fff7ed;border-radius:var(--radius-max)}[data-theme=dark] .subcategory-count{background-color:#f9731626}.subcategory-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.subcategory-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.subcategory-modal-subtitle{font-size:.9rem;color:var(--text-secondary);margin:0}.subcategory-modal-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5) var(--space-4);flex-shrink:0}.subcategory-search-box{position:relative;flex:1}.subcategory-search-box input{width:100%;padding:10px 14px 10px 40px;font-size:.9rem;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.subcategory-search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.subcategory-search-box input::placeholder{color:var(--text-muted)}@media(max-width:640px){.subcategory-search-box{width:100%}}.subcategory-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.btn-add-subcategory{display:flex;align-items:center;gap:var(--space-1);padding:10px 18px;font-size:.9rem;font-weight:600;color:#fff;background-color:#f97316;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.btn-add-subcategory:hover{background-color:#ea580c;transform:translateY(-1px)}.btn-add-subcategory:disabled{opacity:.6;cursor:not-allowed;transform:none}.subcategory-modal-category-info{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-4)}.subcategory-modal-category-info .subcategory-icon-box{width:48px;height:48px}.subcategory-modal-category-info .subcategory-icon-box svg{width:24px;height:24px}.subcategory-modal-category-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);flex:1}.subcategory-modal-category-info .subcategory-modal-close{margin-left:auto}.subcategory-modal-body{flex:1;overflow-y:auto;padding:0 var(--space-5) var(--space-5);min-height:300px;max-height:65vh}.subcategory-list{display:flex;flex-direction:column;gap:0}.subcategory-list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast)}.subcategory-list-item:last-child{border-bottom:none}.subcategory-list-item:hover{background-color:var(--bg-hover);border-radius:var(--radius-md)}.subcategory-item-content{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.subcategory-icon-box{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit}.subcategory-icon-box svg{width:20px;height:20px}.subcategory-item-name{font-size:.95rem;font-weight:500;color:var(--text-primary)}.subcategory-item-actions{display:flex;align-items:center;gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast)}.subcategory-list-item:hover .subcategory-item-actions{opacity:1}.subcategory-add-inline{background-color:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.subcategory-add-inline .subcategory-edit-row{width:100%}.subcategory-list-item .subcategory-edit-row{display:flex;align-items:center;gap:var(--space-3);width:100%}.subcategory-list-item .subcategory-edit-input{flex:1;padding:var(--space-2) var(--space-3);font-size:.9rem;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.subcategory-list-item .subcategory-edit-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}@media(max-width:480px){.subcategory-modal{max-width:100%;margin:var(--space-3);max-height:calc(100vh - var(--space-6))}.subcategory-modal-toolbar{flex-direction:column;gap:var(--space-2)}.btn-add-subcategory{width:100%;justify-content:center}}.category-detail-modal{max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.category-detail-modal-header{padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--border-color);flex-shrink:0}.category-detail-modal-header .subcategories-header{display:flex;justify-content:space-between;align-items:center;margin:0}.category-detail-modal-header .subcategories-header h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0;letter-spacing:.05em}.btn-add-subcategory-outline{display:flex;align-items:center;gap:var(--space-1);padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--text-primary);background-color:transparent;border:1px solid var(--border-color);border-radius:var(--radius-max);cursor:pointer;transition:all var(--transition-fast)}.btn-add-subcategory-outline:hover{background-color:var(--bg-hover);border-color:var(--text-secondary)}.category-detail-modal-body{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-5)}.category-detail-modal-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);flex-shrink:0;display:flex;justify-content:flex-start}.category-detail-modal-footer .btn{min-width:80px}.category-detail-header{display:flex;align-items:center;gap:var(--space-4)}.category-detail-header h2{margin:0;font-size:1.25rem}.category-type-badge{display:inline-block;padding:2px 10px;font-size:.75rem;font-weight:500;border-radius:var(--radius-max);margin-top:var(--space-1)}.category-type-badge.debit{background-color:var(--danger-light);color:var(--danger)}.category-type-badge.credit{background-color:var(--success-light);color:var(--success)}.category-detail-content{padding:var(--space-4) 0}.category-detail-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:var(--space-5);line-height:1.5}.category-detail-budget{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}.category-detail-budget h3{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.03em}.budget-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-4)}.budget-stat{text-align:center}.budget-stat-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-1);text-transform:uppercase}.budget-stat-value{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.budget-stat-value.spent{color:var(--danger)}.budget-stat-value.remaining{color:var(--success)}.budget-stat-value.over{color:var(--danger)}.budget-progress{display:flex;align-items:center;gap:var(--space-3)}.budget-progress-bar{flex:1;height:8px;background-color:var(--bg-secondary);border-radius:var(--radius-max);overflow:hidden}.budget-progress-fill{height:100%;background-color:var(--success);border-radius:var(--radius-max);transition:width .3s ease}.budget-progress-fill.warning{background-color:var(--warning)}.budget-progress-fill.over{background-color:var(--danger)}.budget-progress-text{font-size:.85rem;font-weight:600;color:var(--text-secondary);min-width:40px;text-align:right}.category-detail-no-budget{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5);text-align:center}.category-detail-no-budget p{color:var(--text-muted);font-size:.9rem;margin:0}.category-detail-subcategories{margin-top:var(--space-4)}.subcategories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.subcategories-header h3{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.03em}.subcategories-list-detail{display:flex;flex-direction:column;gap:0}.subcategory-item-detail{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast)}.subcategory-item-detail:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.subcategory-item-detail:last-child{border-radius:0 0 var(--radius-md) var(--radius-md);border-bottom:none}.subcategory-item-detail:only-child{border-radius:var(--radius-md)}.subcategory-item-detail:hover{background-color:var(--bg-hover)}.subcategory-item-left{display:flex;align-items:center;gap:var(--space-3)}.subcategory-bullet{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subcategory-name-detail{font-size:.9rem;color:var(--text-primary)}.subcategory-item-actions{display:flex;align-items:center;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast)}.subcategory-item-detail:hover .subcategory-item-actions{opacity:1}.subcategory-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.subcategory-action-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.subcategory-action-btn.delete:hover{background-color:var(--danger-light);color:var(--danger)}.subcategory-action-btn.edit:hover{background-color:var(--primary-light);color:var(--primary)}.subcategory-action-btn.save{color:var(--success)}.subcategory-action-btn.save:hover{background-color:var(--success-light);color:var(--success)}.subcategory-action-btn.cancel:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.subcategory-edit-row{display:flex;align-items:center;gap:var(--space-3);width:100%}.subcategory-edit-input{flex:1;padding:var(--space-2) var(--space-3);font-size:.9rem;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.subcategory-edit-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.subcategory-edit-actions{display:flex;align-items:center;gap:var(--space-1)}.no-subcategories{color:var(--text-muted);font-size:.9rem;text-align:center;padding:var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}@media(max-width:1024px){.categories-filters-row{flex-wrap:wrap}.categories-type-tabs{order:1}.categories-action-buttons{order:2}.categories-search-box{order:3;flex:1 1 100%;max-width:100%}}@media(max-width:768px){.categories-page-header{flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.categories-page-header-left p{display:none}.categories-page-header-left h1{margin-bottom:0}.categories-page-header-actions{flex-shrink:0}.categories-page-header-actions .add-transaction-btn-inline{padding:8px 12px;font-size:.85rem}.categories-filters-row{flex-direction:column;align-items:stretch}.categories-type-tabs{width:100%;justify-content:center;order:2}.categories-search-box{width:100%;max-width:100%;order:3}.categories-action-buttons{width:100%;order:1}.categories-grid{grid-template-columns:1fr}}@media(max-width:480px){.categories-type-tabs{flex-wrap:wrap}.category-type-tab{flex:1;text-align:center;padding:8px 12px;font-size:.85rem}.categories-action-buttons{display:flex;flex-direction:row;gap:var(--space-2)}.btn-new-category,.btn-new-subcategory{flex:1;justify-content:center;padding:10px 12px;font-size:.8rem}}.category-card-actions{position:absolute;top:12px;right:12px;display:flex;gap:6px;opacity:0;transition:opacity .2s ease}.category-card-new:hover .category-card-actions{opacity:1}.category-card-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;cursor:pointer;transition:all .15s ease}.category-card-action-btn.edit{background:var(--bg-tertiary);color:var(--text-secondary)}.category-card-action-btn.edit:hover{background:var(--primary);color:#fff}.category-card-action-btn.delete{background:var(--bg-tertiary);color:var(--text-secondary)}.category-card-action-btn.delete:hover{background:#ef4444;color:#fff}.modal.modal-small{max-width:480px;max-height:85vh}.edit-category-preview{display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-tertiary);border-radius:12px;margin-bottom:20px}.edit-category-icon-preview{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:12px}.edit-category-icon-preview svg{width:28px;height:28px}.edit-category-name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.subcategory-edit-expanded{flex-direction:column;gap:12px;padding:16px;background:var(--bg-tertiary);border-radius:12px}.subcategory-edit-expanded .subcategory-edit-input{width:100%}.subcategory-edit-pickers{display:grid;grid-template-columns:1fr 1fr;gap:12px}.subcategory-picker-row{display:flex;flex-direction:column;gap:6px;width:100%}.subcategory-picker-row label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.subcategory-picker-row .icon-picker,.subcategory-picker-row .color-picker{width:100%}.subcategory-picker-row .icon-picker-trigger,.subcategory-picker-row .color-picker-trigger{padding:10px 12px;font-size:13px}.subcategory-picker-row .icon-picker-preview,.subcategory-picker-row .color-picker-preview{width:24px;height:24px}.subcategory-picker-row .icon-picker-preview svg{width:14px;height:14px}.subcategory-picker-mini .icon-picker,.subcategory-picker-mini .color-picker{width:100%}.subcategory-picker-mini .icon-picker-trigger,.subcategory-picker-mini .color-picker-trigger{padding:10px 12px;font-size:13px}.subcategory-picker-mini .icon-picker-preview,.subcategory-picker-mini .color-picker-preview{width:24px;height:24px}.subcategory-picker-mini .icon-picker-preview svg{width:14px;height:14px}.subcategory-edit-expanded .subcategory-edit-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.subcategory-list-item:has(.subcategory-edit-expanded){padding:0}.reports-page{max-width:1400px;margin:0 auto}.reports-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.reports-page .page-header .header-left h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.reports-page .page-header .header-left .page-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:var(--space-1)}.reports-header-filters{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.period-toggle{display:flex;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:4px;gap:4px}.period-toggle-btn{padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.period-toggle-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.period-toggle-btn:hover:not(.active){color:var(--text-primary);background:var(--bg-hover)}.month-picker-wrapper{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.month-picker-wrapper:hover{border-color:var(--primary)}.month-picker-wrapper svg{color:var(--text-muted)}.month-picker-wrapper span{font-size:.9rem;font-weight:500;color:var(--text-primary)}.wallet-filter-wrapper{display:flex;align-items:center;gap:var(--space-2)}.wallet-filter-wrapper .dropdown{min-width:180px}.reports-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-6)}@media(max-width:1200px){.reports-stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.reports-stats-row{grid-template-columns:1fr}}.reports-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-normal);position:relative;overflow:hidden}.reports-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.reports-stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.reports-stat-card .stat-icon svg{width:24px;height:24px}.reports-stat-card.income .stat-icon{background:linear-gradient(135deg,#10b98126,#10b9810d);color:var(--success)}.reports-stat-card.expenses .stat-icon{background:linear-gradient(135deg,#ef444426,#ef44440d);color:var(--danger)}.reports-stat-card.balance .stat-icon{background:linear-gradient(135deg,#6366f126,#6366f10d);color:var(--primary)}.reports-stat-card.savings .stat-icon{background:linear-gradient(135deg,#f59e0b26,#f59e0b0d);color:var(--warning)}.reports-stat-card .stat-content{flex:1;min-width:0}.reports-stat-card .stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1)}.reports-stat-card .stat-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.reports-stat-card .stat-change{display:flex;align-items:center;gap:var(--space-1);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm)}.reports-stat-card .stat-change.positive{background:#10b9811a;color:var(--success)}.reports-stat-card .stat-change.negative{background:#ef44441a;color:var(--danger)}.reports-stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.reports-stat-card.income .stat-value{color:var(--success)}.reports-stat-card.expenses .stat-value{color:var(--danger)}.reports-stat-card.balance .stat-value{color:var(--primary)}.reports-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1100px){.reports-main-grid{grid-template-columns:1fr}}.reports-chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-normal)}.reports-chart-card:hover{box-shadow:var(--shadow-md)}.reports-chart-card .chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.reports-chart-card .chart-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.reports-chart-card .chart-header .view-details-link{font-size:.8rem;color:var(--primary);cursor:pointer;font-weight:500;display:flex;align-items:center;gap:var(--space-1);transition:color var(--transition-fast)}.reports-chart-card .chart-header .view-details-link:hover{color:var(--primary-hover)}.reports-chart-card .chart-legend-inline{display:flex;gap:var(--space-5);margin-bottom:var(--space-4)}.reports-chart-card .legend-item-inline{display:flex;align-items:center;gap:var(--space-2);font-size:.85rem;color:var(--text-secondary)}.reports-chart-card .legend-dot{width:10px;height:10px;border-radius:50%}.reports-chart-card .legend-dot.income{background:var(--primary)}.reports-chart-card .legend-dot.expenses{background:var(--text-muted)}.category-bars-container{display:flex;flex-direction:column;gap:var(--space-3)}.category-bar-item{display:flex;flex-direction:column;gap:var(--space-2)}.category-bar-header{display:flex;justify-content:space-between;align-items:center}.category-bar-name{font-size:.85rem;color:var(--text-secondary);font-weight:500}.category-bar-value{display:flex;align-items:baseline;gap:var(--space-2)}.category-bar-amount{font-size:.9rem;font-weight:600;color:var(--text-primary)}.category-bar-percent{font-size:.75rem;color:var(--text-muted)}.category-bar-track{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.category-bar-fill{height:100%;border-radius:var(--radius-sm);transition:width .5s ease-out}.reports-health-section{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1100px){.reports-health-section{grid-template-columns:1fr}}.financial-health-card-modern{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.financial-health-card-modern .health-header{display:flex;justify-content:space-between;align-items:center}.financial-health-card-modern .health-title-row{display:flex;align-items:center;gap:var(--space-2)}.financial-health-card-modern .health-icon{font-size:1.25rem}.financial-health-card-modern .health-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.health-score-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-max);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.health-score-badge.excellent{background:linear-gradient(135deg,#10b98133,#10b9811a);color:#10b981;border:1px solid rgba(16,185,129,.3)}.health-score-badge.good{background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:#22c55e;border:1px solid rgba(34,197,94,.3)}.health-score-badge.average{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.health-score-badge.poor{background:linear-gradient(135deg,#ef444433,#ef44441a);color:#ef4444;border:1px solid rgba(239,68,68,.3)}.health-score-visual{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-4) 0}.score-circle{position:relative;width:100px;height:100px;flex-shrink:0}.score-circle svg{width:100%;height:100%;transform:rotate(0)}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:baseline;gap:2px}.score-number{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.score-percent{font-size:.9rem;font-weight:600;color:var(--text-muted)}.score-details{flex:1}.score-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1) 0}.score-description{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.5}.health-insights-list{display:flex;flex-direction:column;gap:var(--space-3);border-top:1px solid var(--border-color);padding-top:var(--space-4)}.health-insight-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.health-insight-item:hover{background:var(--bg-hover);transform:translate(4px)}.insight-indicator{width:4px;height:100%;min-height:32px;border-radius:2px;flex-shrink:0}.health-insight-item.warning .insight-indicator{background:linear-gradient(180deg,#f59e0b,#fbbf24)}.health-insight-item.success .insight-indicator{background:linear-gradient(180deg,#10b981,#34d399)}.health-insight-item.info .insight-indicator{background:linear-gradient(180deg,#6366f1,#818cf8)}.insight-content{display:flex;flex-direction:column;gap:2px}.insight-label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.insight-detail{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.top-categories-card-modern{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.categories-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.categories-count{font-size:.8rem;color:var(--text-muted);padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-max)}.categories-list-modern{display:flex;flex-direction:column;gap:var(--space-4)}.category-item-modern{display:flex;align-items:flex-start;gap:var(--space-4)}.category-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,#818cf8 100%);color:#fff;font-size:.8rem;font-weight:700;border-radius:var(--radius-sm);flex-shrink:0}.category-details{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.category-name-row{display:flex;justify-content:space-between;align-items:center}.category-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.category-amount{font-size:.9rem;font-weight:700;color:var(--text-primary)}.category-bar-modern{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.category-bar-fill-modern{height:100%;border-radius:var(--radius-sm);transition:width .6s cubic-bezier(.4,0,.2,1)}.category-percent{font-size:.75rem;color:var(--text-muted)}.categories-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);color:var(--text-muted);text-align:center}.categories-empty .empty-icon{font-size:2.5rem;margin-bottom:var(--space-3);opacity:.5}.categories-empty p{margin:0;font-size:.9rem}.reports-insights-section{margin-bottom:var(--space-6)}.reports-insights-section .section-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);justify-content:start}.reports-insights-section .section-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.reports-insights-section .section-header .ai-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,#a78bfa 100%);border-radius:var(--radius-sm);color:#fff;font-size:.75rem}.reports-insights-categories-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1100px){.reports-insights-categories-grid{grid-template-columns:1fr}}.insights-cards-grid{display:flex;flex-direction:column;gap:var(--space-4)}@media(max-width:768px){.insights-cards-grid{grid-template-columns:1fr}}.insight-modern-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;gap:var(--space-4);transition:all var(--transition-normal)}.insight-modern-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-light)}.insight-modern-card .insight-icon-wrapper{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.insight-modern-card.alert .insight-icon-wrapper{background:linear-gradient(135deg,#f59e0b26,#f59e0b0d);color:var(--warning)}.insight-modern-card.opportunity .insight-icon-wrapper{background:linear-gradient(135deg,#10b98126,#10b9810d);color:var(--success)}.insight-modern-card.info .insight-icon-wrapper{background:linear-gradient(135deg,#6366f126,#6366f10d);color:var(--primary)}.insight-modern-card .insight-text{flex:1}.insight-modern-card .insight-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0}.insight-modern-card .insight-description{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0}.insight-modern-card .insight-highlight{font-weight:600;color:var(--primary)}.reports-top-categories{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.reports-insights-categories-grid .reports-insights-section,.reports-insights-categories-grid .reports-top-categories{margin-bottom:0}.reports-top-categories .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.reports-top-categories .section-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.top-categories-list{display:flex;flex-direction:column;gap:var(--space-4)}.top-category-item{display:flex;align-items:center;gap:var(--space-4)}.top-category-bar-wrapper{flex:1;display:flex;align-items:center;gap:var(--space-3)}.top-category-bar{flex:1;height:32px;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;position:relative}.top-category-bar-fill{height:100%;border-radius:var(--radius-md);display:flex;align-items:center;padding-left:var(--space-3);transition:width .5s ease-out}.top-category-bar-fill span{font-size:.85rem;font-weight:500;color:#fff;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.2)}.top-category-value{min-width:120px;text-align:right;font-size:.9rem;font-weight:600;color:var(--text-primary)}.reports-secondary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1024px){.reports-secondary-grid{grid-template-columns:1fr}}.reports-detailed-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.reports-detailed-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.reports-detailed-section .section-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.top-expenses-modern-list{display:flex;flex-direction:column;gap:var(--space-3)}.top-expense-modern-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.top-expense-modern-item:hover{background:var(--bg-hover);border-color:var(--primary);transform:translate(4px)}.top-expense-modern-item .expense-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);font-weight:700;font-size:.875rem;border-radius:var(--radius-md);flex-shrink:0}.top-expense-modern-item .expense-info{flex:1;min-width:0}.top-expense-modern-item .expense-category{font-size:.95rem;font-weight:600;color:var(--text-primary)}.top-expense-modern-item .expense-subcategory{font-size:.85rem;color:var(--text-secondary)}.top-expense-modern-item .expense-description{font-size:.8rem;color:var(--text-muted);margin-top:var(--space-1)}.top-expense-modern-item .expense-date{font-size:.75rem;color:var(--text-muted);margin-top:var(--space-1)}.top-expense-modern-item .expense-amount{font-size:1.1rem;font-weight:700;color:var(--danger);flex-shrink:0}.reports-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.95rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:2px dashed var(--border-color);text-align:center;padding:var(--space-6)}.reports-empty-state svg{width:48px;height:48px;margin-bottom:var(--space-3);opacity:.5}@media(max-width:768px){.reports-page .page-header{flex-direction:column;align-items:stretch}.reports-header-filters{justify-content:flex-start}.period-toggle{width:100%}.period-toggle-btn{flex:1;text-align:center}}.upgrade-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upgrade-modal{background:var(--card-bg, #fff);border-radius:16px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upgrade-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:#0000001a;border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #666);transition:background .2s}.upgrade-modal-close:hover{background:#0003}.upgrade-modal-header{text-align:center;padding:32px 24px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.upgrade-modal-icon{font-size:3rem;margin-bottom:12px}.upgrade-modal-title{margin:0 0 8px;font-size:1.75rem;font-weight:700}.upgrade-modal-subtitle{margin:0;font-size:1rem;opacity:.9}.upgrade-features{padding:24px;display:flex;flex-direction:column;gap:12px}.upgrade-feature{display:flex;align-items:center;gap:12px;font-size:1rem;color:var(--text-primary, #333)}.feature-check{width:24px;height:24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0}.free-trial-section{padding:0 24px 16px;text-align:center}.trial-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}.trial-icon{font-size:1.5rem}.trial-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary, #333);background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.trial-description{margin:0 0 16px;font-size:.875rem;color:var(--text-secondary, #666);line-height:1.5}.trial-start-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.trial-start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.trial-start-btn:disabled{opacity:.7;cursor:not-allowed}.trial-note{margin:10px 0 0;font-size:.75rem;color:var(--text-secondary, #666);display:flex;align-items:center;justify-content:center;gap:4px}.trial-note:before{content:"🔒";font-size:.875rem}.trial-divider{display:flex;align-items:center;margin:20px 0 4px;gap:16px}.trial-divider:before,.trial-divider:after{content:"";flex:1;height:1px;background:var(--border-color, #e0e0e0)}.trial-divider span{font-size:.75rem;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:1px}.pricing-options{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 24px}.pricing-card{border:2px solid var(--border-color, #e0e0e0);border-radius:12px;padding:20px 16px;text-align:center;cursor:pointer;transition:all .2s;position:relative;background:var(--card-bg, #fff)}.pricing-card:hover{border-color:#667eea}.pricing-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d);box-shadow:0 4px 12px #667eea33}.pricing-badge{position:absolute;top:-10px;right:-10px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;font-size:.75rem;font-weight:700;padding:4px 8px;border-radius:12px;white-space:nowrap}.pricing-card-header{margin-bottom:12px}.pricing-period{font-size:1rem;font-weight:600;color:var(--text-primary, #333)}.pricing-card-price{margin-bottom:8px}.price-amount{font-size:2rem;font-weight:700;color:var(--text-primary, #333)}.price-period{font-size:.875rem;color:var(--text-secondary, #666)}.pricing-equivalent{font-size:.75rem;color:var(--text-secondary, #666);margin-bottom:12px}.pricing-select-btn{width:100%;padding:8px 16px;font-size:.875rem;font-weight:600;border:2px solid #667eea;background:transparent;color:#667eea;border-radius:8px;cursor:pointer;transition:all .2s}.pricing-card.selected .pricing-select-btn{background:#667eea;color:#fff}.pricing-select-btn:hover:not(:disabled){background:#667eea;color:#fff}.upgrade-error{margin:16px 24px 0;padding:12px 16px;background:var(--error-bg, #ffebee);color:var(--error-text, #c62828);border-radius:8px;font-size:.875rem;text-align:center}.upgrade-subscribe-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 48px);margin:24px;padding:16px;font-size:1.125rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.upgrade-subscribe-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.upgrade-subscribe-btn:disabled{opacity:.7;cursor:not-allowed}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.upgrade-footer{text-align:center;padding:0 24px 24px;margin:0;font-size:.875rem;color:var(--text-secondary, #666)}.upgrade-success{text-align:center;padding:48px 32px}.upgrade-success .success-icon{font-size:4rem;margin-bottom:16px;animation:bounce .5s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.upgrade-success h2{margin:0 0 8px;font-size:1.5rem;color:var(--success-color, #4caf50)}.upgrade-success p{margin:0;color:var(--text-secondary, #666)}[data-theme=dark] .upgrade-modal{background:var(--card-bg-dark, #2d2d2d)}[data-theme=dark] .upgrade-modal-close{background:#ffffff1a;color:#ccc}[data-theme=dark] .upgrade-modal-close:hover{background:#fff3}[data-theme=dark] .upgrade-feature{color:var(--text-primary-dark, #e0e0e0)}[data-theme=dark] .pricing-card{background:var(--card-bg-dark, #2d2d2d);border-color:var(--border-color-dark, #444)}[data-theme=dark] .pricing-card:hover{border-color:#667eea}[data-theme=dark] .pricing-card.selected{background:#667eea1a}[data-theme=dark] .pricing-period,[data-theme=dark] .price-amount{color:var(--text-primary-dark, #e0e0e0)}[data-theme=dark] .price-period,[data-theme=dark] .pricing-equivalent,[data-theme=dark] .upgrade-footer{color:var(--text-secondary-dark, #aaa)}[data-theme=dark] .upgrade-success h2{color:#81c784}[data-theme=dark] .upgrade-success p{color:var(--text-secondary-dark, #aaa)}[data-theme=dark] .trial-header h3{color:var(--text-primary-dark, #e0e0e0)}[data-theme=dark] .trial-description,[data-theme=dark] .trial-note{color:var(--text-secondary-dark, #aaa)}[data-theme=dark] .trial-divider:before,[data-theme=dark] .trial-divider:after{background:var(--border-color-dark, #444)}[data-theme=dark] .trial-divider span{color:var(--text-secondary-dark, #aaa)}@media(max-width:480px){.pricing-options{grid-template-columns:1fr}.upgrade-modal-title{font-size:1.5rem}.price-amount{font-size:1.75rem}}.subscription-section{background:var(--card-bg, #fff);border-radius:12px;padding:24px;border:1px solid var(--border-color, #e0e0e0)}.subscription-section.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:12px;color:var(--text-secondary, #666)}.subscription-section.premium{border:2px solid transparent;background:linear-gradient(var(--card-bg, #fff),var(--card-bg, #fff)) padding-box,linear-gradient(135deg,#667eea,#764ba2) border-box}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.subscription-plan{display:flex;flex-direction:column;gap:4px}.plan-label{font-size:.875rem;color:var(--text-secondary, #666)}.plan-name{font-size:1.5rem;font-weight:700;color:var(--text-primary, #333);display:flex;align-items:center;gap:8px}.premium-badge{font-size:1.25rem}.subscription-section.premium .plan-name{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subscription-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:20px}.trial-badge-section{grid-column:1 / -1;margin-bottom:8px}.trial-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;font-size:.875rem;font-weight:700;border-radius:20px;letter-spacing:.5px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:.875rem;color:var(--text-secondary, #666)}.detail-value{font-size:1rem;font-weight:600;color:var(--text-primary, #333)}.all-features-unlimited{grid-column:1 / -1;display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:8px;color:#667eea;font-weight:600}.check-icon{font-size:1.25rem}.subscription-usage{margin-top:8px}.usage-title{margin:0 0 16px;font-size:1rem;font-weight:600;color:var(--text-primary, #333)}.usage-list{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.usage-item{padding:12px;background:var(--bg-secondary, #f8f9fa);border-radius:8px}.usage-item.at-limit{background:var(--error-bg, #ffebee)}.usage-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.usage-feature-name{font-weight:500;color:var(--text-primary, #333)}.usage-count{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary, #333)}.limit-badge{font-size:.75rem;padding:2px 6px;background:var(--error-color, #f44336);color:#fff;border-radius:4px;font-weight:600}.usage-bar{width:100%;height:8px;background:#0000001a;border-radius:4px;overflow:hidden}.usage-bar-fill{height:100%;background:var(--primary-color, #1976d2);border-radius:4px;transition:width .3s ease}.usage-item.at-limit .usage-bar-fill{background:var(--error-color, #f44336)}.usage-item:not(.at-limit) .usage-bar-fill{background:linear-gradient(90deg,var(--success-color, #4caf50) 0%,var(--warning-color, #ff9800) 70%,var(--error-color, #f44336) 100%)}.usage-reset-info{margin:0 0 20px;font-size:.875rem;color:var(--text-secondary, #666)}.trial-expired-warning{display:flex;align-items:flex-start;gap:12px;padding:16px;margin-bottom:20px;background:linear-gradient(135deg,#ff98001a,#ff57221a);border:1px solid rgba(255,152,0,.3);border-radius:10px}.trial-expired-warning .warning-icon{font-size:1.5rem;flex-shrink:0}.trial-expired-warning .warning-content{flex:1}.trial-expired-warning strong{display:block;font-size:1rem;color:var(--text-primary, #333);margin-bottom:4px}.trial-expired-warning p{margin:0;font-size:.875rem;color:var(--text-secondary, #666);line-height:1.5}.upgrade-button{width:100%;padding:14px 24px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;cursor:pointer;transition:transform .2s,box-shadow .2s}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #667eea66}.upgrade-button.trial-button{background:linear-gradient(135deg,#4caf50,#2e7d32)}.upgrade-button.trial-button:hover{box-shadow:0 4px 16px #4caf5066}.manage-subscription-button{width:100%;padding:12px 24px;font-size:1rem;font-weight:600;color:#667eea;background:transparent;border:2px solid #667eea;border-radius:10px;cursor:pointer;transition:background .2s,color .2s}.manage-subscription-button:hover{background:#667eea;color:#fff}[data-theme=dark] .subscription-section{background:var(--card-bg-dark, #2d2d2d);border-color:var(--border-color-dark, #444)}[data-theme=dark] .subscription-section.premium{background:linear-gradient(var(--card-bg-dark, #2d2d2d),var(--card-bg-dark, #2d2d2d)) padding-box,linear-gradient(135deg,#667eea,#764ba2) border-box}[data-theme=dark] .plan-label,[data-theme=dark] .detail-label,[data-theme=dark] .usage-reset-info{color:var(--text-secondary-dark, #aaa)}[data-theme=dark] .plan-name,[data-theme=dark] .detail-value,[data-theme=dark] .usage-title,[data-theme=dark] .usage-feature-name,[data-theme=dark] .usage-count{color:var(--text-primary-dark, #e0e0e0)}[data-theme=dark] .usage-item{background:#ffffff0d}[data-theme=dark] .usage-item.at-limit{background:#f4433626}[data-theme=dark] .all-features-unlimited{background:linear-gradient(135deg,#667eea33,#764ba233)}[data-theme=dark] .usage-bar{background:#ffffff1a}[data-theme=dark] .trial-expired-warning{background:linear-gradient(135deg,#ff980026,#ff572226);border-color:#ff980066}[data-theme=dark] .trial-expired-warning strong{color:var(--text-primary-dark, #e0e0e0)}[data-theme=dark] .trial-expired-warning p{color:var(--text-secondary-dark, #aaa)}.subscription-section .spinner{width:32px;height:32px;border:3px solid var(--border-color, #e0e0e0);border-top-color:var(--primary-color, #1976d2);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.subscription-section{padding:16px}.plan-name{font-size:1.25rem}.subscription-details{grid-template-columns:1fr 1fr}}.onboarding-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);padding:var(--space-6);transition:var(--theme-transition);position:relative}.onboarding-language-selector{position:absolute;top:var(--space-4);right:var(--space-4);z-index:100}.onboarding-language-selector .language-selector-btn{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.onboarding-language-selector .language-selector-btn:hover{background:var(--bg-elevated)}.onboarding-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:600px;width:100%;padding:var(--space-8);position:relative}.onboarding-progress{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-8)}.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-tertiary);transition:var(--transition-normal);cursor:pointer}.progress-dot.active{background:var(--primary);box-shadow:0 0 8px var(--primary-glow);transform:scale(1.2)}.progress-dot.completed{background:var(--success)}.progress-step-label{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:var(--space-1)}.onboarding-step{animation:onboardingFadeIn .3s ease}@keyframes onboardingFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.onboarding-step-header{text-align:center;margin-bottom:var(--space-6)}.onboarding-step-icon{font-size:3rem;margin-bottom:var(--space-3);display:block}.onboarding-step-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-2) 0}.onboarding-step-header p{color:var(--text-secondary);font-size:.9rem;margin:0;line-height:1.5}.onboarding-welcome-description{color:var(--text-secondary);line-height:1.6;text-align:center;margin-top:var(--space-4);font-size:.9rem}.onboarding-form-group{margin-bottom:var(--space-4)}.onboarding-form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.onboarding-form-group input{width:100%;padding:var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;transition:var(--transition-fast);box-sizing:border-box}.onboarding-form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.onboarding-form-group input[type=date]{background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:40px}.theme-preview-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-4)}.theme-card{border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;transition:var(--transition-normal);text-align:center;position:relative}.theme-card:hover{border-color:var(--primary);transform:translateY(-2px)}.theme-card.selected{border-color:var(--primary);box-shadow:var(--shadow-glow)}.theme-card-icon{font-size:2.5rem;margin-bottom:var(--space-2);display:block}.theme-card-label{font-weight:600;color:var(--text-primary);font-size:.9rem}.theme-card-badge{position:absolute;top:var(--space-2);right:var(--space-2);background:var(--primary);color:#fff;font-size:.7rem;padding:2px 8px;border-radius:var(--radius-sm);font-weight:600}.theme-card-preview{border-radius:var(--radius-sm);padding:var(--space-3);margin-bottom:var(--space-3);height:80px;display:flex;flex-direction:column;justify-content:space-between}.theme-card-preview.dark-preview{background:#0f172a;border:1px solid rgba(255,255,255,.08)}.theme-card-preview.light-preview{background:#f8fafc;border:1px solid #e2e8f0}.theme-preview-bar{height:6px;border-radius:3px;width:60%}.dark-preview .theme-preview-bar{background:#6366f1}.light-preview .theme-preview-bar{background:#4f46e5}.theme-preview-line{height:4px;border-radius:2px;width:80%}.dark-preview .theme-preview-line{background:#ffffff1a}.light-preview .theme-preview-line{background:#00000014}.theme-preview-line-short{height:4px;border-radius:2px;width:40%}.dark-preview .theme-preview-line-short{background:#ffffff0f}.light-preview .theme-preview-line-short{background:#0000000d}.onboarding-categories-section{margin-bottom:var(--space-5)}.onboarding-categories-section h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-3) 0}.category-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.category-chip{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-1) var(--space-3);font-size:.82rem;color:var(--text-secondary);border:1px solid var(--border-color);transition:var(--transition-fast)}.category-chip.expense{border-left:3px solid var(--danger)}.category-chip.income{border-left:3px solid var(--success)}.onboarding-add-category{display:flex;gap:var(--space-2);margin-top:var(--space-4)}.onboarding-add-category input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.onboarding-add-category input:focus{outline:none;border-color:var(--primary)}.onboarding-add-category select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.onboarding-add-category button{padding:var(--space-2) var(--space-4);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:600;transition:var(--transition-fast);white-space:nowrap}.onboarding-add-category button:hover{background:var(--primary-hover)}.onboarding-transaction-step .transaction-type-toggle{display:flex;background-color:var(--bg-tertiary);border-radius:999px;padding:4px;gap:0;margin-bottom:var(--space-4)}.onboarding-transaction-step .type-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .4s ease,color .3s ease,box-shadow .4s ease}.onboarding-transaction-step .type-toggle-btn:hover:not(.active){color:var(--text-secondary)}.onboarding-transaction-step .type-toggle-btn.active.expense{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff;box-shadow:0 4px 14px #ef444459}.onboarding-transaction-step .type-toggle-btn.active.income{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;box-shadow:0 4px 14px #10b98159}.onboarding-transaction-step .type-toggle-icon{font-size:1rem}.onboarding-transaction-step .amount-hero{text-align:center;margin-bottom:16px;padding:12px 0}.onboarding-transaction-step .amount-hero-label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.onboarding-transaction-step .amount-hero-input{display:flex;align-items:baseline;justify-content:center;gap:4px}.onboarding-transaction-step .amount-hero-currency{font-size:1.3rem;font-weight:300;color:var(--text-muted);-webkit-user-select:none;user-select:none}.onboarding-transaction-step .amount-hero-input input{background:transparent;border:none;outline:none;font-size:2.4rem;font-weight:200;color:var(--text-primary);text-align:center;width:10ch;min-width:4ch;max-width:20ch;field-sizing:content;padding:0;font-family:inherit;letter-spacing:-.02em}.onboarding-transaction-step .amount-hero-input input::placeholder{color:var(--text-soft)}.onboarding-transaction-step .amount-hero-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent);margin-top:16px}.onboarding-transaction-step .transaction-form-fields{display:flex;flex-direction:column;gap:var(--space-4)}.onboarding-transaction-step .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:540px){.onboarding-transaction-step .form-row{grid-template-columns:1fr}}.onboarding-transaction-step .form-group{display:flex;flex-direction:column;gap:6px}.onboarding-transaction-step .form-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.onboarding-transaction-step .input-with-button{display:flex;gap:8px}.onboarding-transaction-step .input-with-button .dropdown{flex:1;min-width:0}.onboarding-transaction-step .input-with-button .btn{flex-shrink:0;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:500}.onboarding-transaction-step .form-group input,.onboarding-transaction-step .form-group textarea{padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.onboarding-transaction-step .form-group input:focus,.onboarding-transaction-step .form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.onboarding-transaction-step .form-group textarea{resize:vertical;min-height:60px}.onboarding-no-wallet{text-align:center;padding:var(--space-8) var(--space-4)}.onboarding-no-wallet p{color:var(--text-secondary);margin-bottom:var(--space-4)}.onboarding-no-wallet button{padding:var(--space-3) var(--space-6);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:var(--transition-fast)}.onboarding-no-wallet button:hover{background:var(--primary-hover)}.onboarding-completion-check{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--success-light);margin:0 auto var(--space-4);animation:onboardingScaleIn .5s ease}@keyframes onboardingScaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.onboarding-completion-check svg{color:var(--success)}.onboarding-summary{margin-top:var(--space-5)}.onboarding-summary h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0 0 var(--space-3) 0}.onboarding-summary-list{list-style:none;padding:0;margin:0}.onboarding-summary-list li{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;color:var(--text-primary);font-size:.9rem}.onboarding-summary-list li .summary-icon{color:var(--success);flex-shrink:0}.onboarding-actions{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-8);gap:var(--space-3)}.onboarding-actions-left,.onboarding-actions-right{display:flex;gap:var(--space-2)}.onboarding-btn{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-fast);border:none;display:inline-flex;align-items:center;gap:var(--space-2)}.onboarding-btn-primary{background:var(--primary);color:#fff}.onboarding-btn-primary:hover{background:var(--primary-hover)}.onboarding-btn-primary:disabled{opacity:.6;cursor:not-allowed}.onboarding-btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.onboarding-btn-secondary:hover{background:var(--bg-hover)}.onboarding-btn-ghost{background:transparent;color:var(--text-muted);padding:var(--space-2) var(--space-3);font-size:.82rem}.onboarding-btn-ghost:hover{color:var(--text-secondary)}.onboarding-btn-success{background:var(--success);color:#fff}.onboarding-btn-success:hover{filter:brightness(1.1)}.onboarding-skip{text-align:center;margin-top:var(--space-4)}.onboarding-skip button{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;text-decoration:underline;transition:var(--transition-fast)}.onboarding-skip button:hover{color:var(--text-secondary)}@media(max-width:768px){.onboarding-page{padding:var(--space-4)}.onboarding-card{padding:var(--space-5);border-radius:var(--radius-lg)}.onboarding-step-header h2{font-size:1.25rem}.theme-preview-cards{grid-template-columns:1fr}.onboarding-add-category{flex-wrap:wrap}.onboarding-add-category input{min-width:0}.onboarding-actions{flex-direction:column-reverse;gap:var(--space-3)}.onboarding-actions-left,.onboarding-actions-right{width:100%;justify-content:center}.onboarding-btn{flex:1;justify-content:center}}@media(max-width:480px){.onboarding-card{padding:var(--space-4)}.onboarding-step-icon{font-size:2.5rem}}.landing-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}.landing-page .language-flag{display:none}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 2rem;transition:all .3s ease}.landing-nav.scrolled{background:#0f172ae6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 1px #ffffff0d}[data-theme=light] .landing-nav.scrolled{background:#ffffffe6;box-shadow:0 1px #0000000d}.landing-nav-container{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem}.landing-logo img{height:auto;width:155px}.landing-nav-links{display:flex;gap:.5rem}.landing-nav-links .nav-link{background:none;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:.5rem 1rem;cursor:pointer;transition:color .2s ease;border-radius:var(--radius-md)}.landing-nav-links .nav-link:hover,.landing-nav-links .nav-link.active{color:var(--text-primary)}.landing-nav-links .nav-link.active{text-decoration:underline;text-underline-offset:4px}.landing-nav-actions{display:flex;align-items:center;gap:.75rem}.nav-login-btn{background:none;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:.5rem 1rem;cursor:pointer;transition:color .2s ease}.nav-login-btn:hover{color:var(--text-primary)}.nav-cta-btn{background:var(--primary);border:none;color:#fff;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;border-radius:var(--radius-max);cursor:pointer;transition:all .2s ease}.nav-cta-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:.5rem;cursor:pointer;z-index:1001}.mobile-menu-toggle span{display:block;width:24px;height:2px;background:var(--text-primary);transition:all .3s ease;border-radius:2px}.mobile-menu-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.open span:nth-child(2){opacity:0}.mobile-menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.landing-mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:var(--bg-secondary);padding:1.5rem;flex-direction:column;gap:.75rem;border-bottom:1px solid var(--border-color);transform:translateY(-100%);opacity:0;transition:all .3s ease}.landing-mobile-menu.open{transform:translateY(0);opacity:1}.landing-mobile-menu button{background:none;border:none;color:var(--text-primary);font-size:1rem;padding:.75rem;text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:background .2s ease}.landing-mobile-menu button:hover{background:var(--bg-hover)}.mobile-menu-divider{height:1px;background:var(--border-color);margin:.5rem 0}.mobile-menu-actions{display:flex;gap:1rem;padding:.5rem 0}.mobile-login-btn{background:var(--bg-tertiary)!important;text-align:center!important}.mobile-cta-btn{background:var(--primary)!important;color:#fff!important;text-align:center!important;font-weight:600!important}@media(max-width:900px){.landing-nav-links,.landing-nav-actions{display:none}.mobile-menu-toggle,.landing-mobile-menu{display:flex}}.hero-section{position:relative;min-height:100vh;padding:8rem 2rem 4rem;display:flex;align-items:center}.hero-container{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}.hero-content{max-width:560px}.version-badge{display:inline-flex;align-items:center;gap:.5rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);color:var(--primary);font-size:.8rem;font-weight:500;padding:.4rem 1rem;border-radius:var(--radius-max);margin-bottom:1.5rem}.badge-dot{width:6px;height:6px;background:var(--success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.hero-title{font-size:clamp(2.5rem,5vw,3.75rem);font-weight:700;line-height:1.1;margin-bottom:1.5rem;letter-spacing:-.02em}.gradient-text{background:linear-gradient(135deg,var(--primary),#a855f7,var(--primary));background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero-description{font-size:1.125rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2rem}.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap}.btn-primary-lg{background:var(--primary);border:none;color:#fff;font-size:1rem;font-weight:600;padding:.875rem 2rem;border-radius:var(--radius-max);cursor:pointer;transition:all .2s ease}.btn-primary-lg:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 8px 24px #6366f14d}.btn-secondary-lg{background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary);font-size:1rem;font-weight:600;padding:.875rem 2rem;border-radius:var(--radius-max);cursor:pointer;transition:all .2s ease}.btn-secondary-lg:hover{background:var(--bg-tertiary);border-color:var(--border-color)}.hero-preview{position:relative}.preview-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-xl);position:relative;overflow:hidden}.preview-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--success))}.preview-header{display:flex;align-items:flex-start;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.preview-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;width:100%}.preview-balance{font-size:2rem;font-weight:700;flex:1}.preview-actions{display:flex;gap:.5rem}.preview-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.preview-action-btn:hover{background:var(--primary);color:#fff}.preview-transactions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.preview-transaction{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:transform .2s ease}.preview-transaction:hover{transform:translate(4px)}.transaction-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:1.25rem}.transaction-info{flex:1}.transaction-name{font-size:.9rem;font-weight:500}.transaction-date{font-size:.75rem;color:var(--text-muted)}.transaction-amount{font-weight:600;font-size:.9rem}.transaction-amount.negative{color:var(--danger)}.transaction-amount.positive{color:var(--success)}.preview-input{margin-bottom:1.5rem}.preview-input input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--text-secondary);font-size:.875rem}.preview-chart{background:linear-gradient(135deg,#6366f11a,#10b9811a);border-radius:var(--radius-md);padding:1rem}.chart-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.chart-value{font-size:1.25rem;font-weight:700;margin:.25rem 0 .5rem}.chart-value.positive{color:var(--success)}.mini-chart{height:40px}.chart-line{width:100%;height:100%}.hero-bg-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}.gradient-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4}.orb-1{width:600px;height:600px;background:var(--primary);top:-200px;right:-100px}.orb-2{width:400px;height:400px;background:#a855f7;bottom:-100px;left:-100px}.grid-pattern{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px}[data-theme=light] .grid-pattern{background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px)}@media(max-width:900px){.hero-section{padding-top:6rem}.hero-container{grid-template-columns:1fr;gap:3rem;text-align:center}.hero-content{max-width:100%}.hero-buttons{justify-content:center}.hero-preview{max-width:400px;margin:0 auto}}.features-section{padding:6rem 2rem;background:var(--bg-primary)}.section-container{max-width:1280px;margin:0 auto}.section-header{text-align:center;max-width:600px;margin:0 auto 4rem}.section-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem;letter-spacing:-.02em}.section-subtitle{font-size:1.1rem;color:var(--text-secondary);line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.feature-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;transition:all .3s ease}.feature-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:0 8px 32px #6366f126}.feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-lg);margin-bottom:1rem;color:var(--primary)}.feature-title{font-size:1rem;font-weight:600;margin-bottom:.5rem}.feature-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5}@media(max-width:1200px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.features-grid{grid-template-columns:1fr}}.how-it-works-section{padding:6rem 2rem;background:var(--bg-secondary)}.how-it-works-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.phone-mockup{display:flex;justify-content:center}.phone-frame{width:280px;height:560px;background:#1a1a2e;border-radius:40px;padding:12px;box-shadow:0 0 0 2px #2d2d44,0 20px 60px #0006;position:relative}.phone-frame:before{content:"";position:absolute;top:16px;left:50%;transform:translate(-50%);width:80px;height:24px;background:#0d0d1a;border-radius:16px}.phone-screen{width:100%;height:100%;background:var(--bg-primary);border-radius:32px;overflow:hidden;padding:3rem 1rem 1rem}.mockup-app{height:100%;display:flex;flex-direction:column}.mockup-header{text-align:center;margin-bottom:1.5rem}.mockup-balance{font-size:1.75rem;font-weight:700}.mockup-subtitle{font-size:.75rem;color:var(--text-muted)}.mockup-chart-area{height:120px;margin-bottom:1.5rem}.mockup-chart{width:100%;height:100%}.mockup-transactions{flex:1;display:flex;flex-direction:column;gap:.5rem}.mockup-tx{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);font-size:.875rem}.tx-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-secondary)}.tx-icon svg{width:18px;height:18px}.tx-name{flex:1}.tx-amount{font-weight:600;color:var(--danger)}.tx-amount.positive{color:var(--success)}.steps-content{max-width:480px}.steps-content .section-title{text-align:left;margin-bottom:2rem}.steps-list{display:flex;flex-direction:column;gap:1.5rem}.step-item{display:flex;gap:1rem}.step-number{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-weight:700;border-radius:50%;font-size:1rem}.step-info h3{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.step-info p{font-size:.9rem;color:var(--text-secondary);line-height:1.5}@media(max-width:900px){.how-it-works-content{grid-template-columns:1fr;gap:3rem}.phone-mockup{order:-1}.steps-content{max-width:100%}.steps-content .section-title{text-align:center}}.testimonials-section{padding:6rem 2rem;background:var(--bg-primary)}.testimonials-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.testimonial-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem}.stars{color:#fbbf24;font-size:1.25rem;letter-spacing:2px;margin-bottom:1rem}.testimonial-card blockquote{font-size:1.1rem;font-style:italic;line-height:1.6;margin-bottom:1.5rem;color:var(--text-primary)}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),#a855f7);border-radius:50%;font-weight:600;font-size:.875rem}.author-name{font-weight:600}.author-role{font-size:.8rem;color:var(--text-muted)}.security-features{display:flex;flex-direction:column;gap:1.5rem}.security-item{display:flex;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.security-icon{width:48px;height:48px;min-width:48px;display:flex;align-items:center;justify-content:center;background:var(--success-light);border-radius:var(--radius-lg);color:var(--success)}.security-icon.privacy{background:var(--primary-light);color:var(--primary)}.security-info h4{font-size:1rem;font-weight:600;margin-bottom:.25rem}.security-info p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}@media(max-width:900px){.testimonials-grid{grid-template-columns:1fr;gap:2rem}}.cta-section{position:relative;padding:6rem 2rem;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);overflow:hidden}.cta-content{position:relative;z-index:1;text-align:center;max-width:600px;margin:0 auto}.cta-content h2{font-size:clamp(2rem,4vw,2.75rem);font-weight:700;margin-bottom:1rem;letter-spacing:-.02em}.cta-content p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}.orb-3{width:500px;height:500px;background:var(--primary);top:-200px;left:50%;transform:translate(-50%)}.orb-4{width:300px;height:300px;background:#10b981;bottom:-150px;right:10%}.landing-page .app-footer{background:var(--bg-primary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-content,.hero-preview,.feature-card,.step-item,.testimonial-card,.security-item{animation:fadeInUp .6s ease forwards}.hero-preview{animation-delay:.2s}.feature-card:nth-child(1){animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.15s}.feature-card:nth-child(3){animation-delay:.2s}.feature-card:nth-child(4){animation-delay:.25s}.feature-card:nth-child(5){animation-delay:.3s}.feature-card:nth-child(6){animation-delay:.35s}.feature-card:nth-child(7){animation-delay:.4s}.feature-card:nth-child(8){animation-delay:.45s}.step-item:nth-child(1){animation-delay:.1s}.step-item:nth-child(2){animation-delay:.2s}.step-item:nth-child(3){animation-delay:.3s}
