:root{--primary-50: #f0fdfa;--primary-100: #ccfbf1;--primary-200: #99f6e4;--primary-300: #5eead4;--primary-400: #2dd4bf;--primary-500: #3fb599;--primary-600: #0d9488;--primary-700: #0f766e;--primary-800: #115e59;--primary-900: #134e4a;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--success: #16a34a;--success-light: #dcfce7;--danger: #dc2626;--danger-light: #fee2e2;--warning: #f59e0b;--warning-light: #fef3c7;--info: #0ea5e9;--info-light: #e0f2fe;--chart-1: #3fb599;--chart-2: #60a5fa;--chart-3: #f59e0b;--chart-4: #10b981;--chart-5: #ef4444;--chart-6: #8b5cf6;--chart-7: #ec4899;--chart-8: #14b8a6}body.dark-mode{--primary-50: #134e4a;--primary-100: #115e59;--primary-200: #0f766e;--primary-500: #2dd4bf;--primary-600: #5eead4;--gray-50: #0d1525;--gray-100: #1a2235;--gray-200: #253045;--gray-300: #374558;--gray-400: #526070;--gray-500: #7a8ea0;--gray-600: #a8baca;--gray-700: #c8d6e0;--gray-800: #e0eaf0;--gray-900: #f0f6fa;--success-light: #052e16;--danger-light: #450a0a;--warning-light: #431407;--info-light: #082f49}:root{--sidebar-width: 220px;--topbar-height: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-card: 0 0 0 1px rgba(0, 0, 0, .05), 0 1px 3px rgba(0, 0, 0, .06);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--fs-xs: .6875rem;--fs-sm: .75rem;--fs-base: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-2xl: 1.5rem;--fs-3xl: 1.875rem;--fs-4xl: 2.25rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}body.dark-mode{--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6), 0 4px 6px -4px rgba(0, 0, 0, .5);--shadow-card: 0 0 0 1px rgba(255, 255, 255, .04), 0 1px 3px rgba(0, 0, 0, .4)}.theme-icon-sun{display:none}body.dark-mode .theme-icon-sun{display:block}body.dark-mode .theme-icon-moon{display:none}*,*: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:var(--font-family);font-size:var(--fs-base);color:var(--gray-800);background-color:var(--gray-50);line-height:1.5;overflow:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}img{max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}#app{display:flex;height:100vh;width:100vw}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;z-index:100}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 20px 28px}.brand-icon{flex-shrink:0}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:var(--fs-md);font-weight:700;color:var(--gray-900);line-height:1.2}.brand-tagline{font-size:var(--fs-xs);font-weight:600;color:var(--gray-400);letter-spacing:.08em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 12px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:500;color:var(--gray-600);transition:all var(--transition-fast)}.nav-item:hover{background:var(--gray-100);color:var(--gray-800)}.nav-item.active{background:var(--primary-50);color:var(--primary-500);font-weight:600}.nav-icon{width:20px;height:20px;flex-shrink:0}.nav-group{display:flex;flex-direction:column}.nav-sub-items{display:none;flex-direction:column}.nav-group:has(.nav-item.active) .nav-sub-items{display:flex}.nav-sub{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 40px;border-radius:var(--radius-md);font-size:var(--fs-sm);color:var(--gray-500);transition:all var(--transition-fast)}.nav-sub:hover{background:var(--gray-100);color:var(--gray-800)}.nav-sub.active{color:var(--primary-500);font-weight:500}.nav-sub .nav-icon{width:16px;height:16px}.sidebar-footer{padding:16px}.topbar{height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:#fff;border-bottom:1px solid var(--gray-200);gap:20px}.search-bar{display:flex;align-items:center;gap:8px;background:var(--gray-100);border-radius:var(--radius-full);padding:8px 16px;flex:1;max-width:420px}.search-icon{width:18px;height:18px;color:var(--gray-400);flex-shrink:0}.search-bar input{border:none;background:none;outline:none;font-size:var(--fs-base);color:var(--gray-800);width:100%}.search-bar input::placeholder{color:var(--gray-400)}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-full);color:var(--gray-500);transition:all var(--transition-fast)}.icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.icon-btn svg{width:20px;height:20px}.avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--primary-500);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer}.avatar svg{width:18px;height:18px}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.page-content{flex:1;overflow-y:auto;padding:28px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-header-text{min-width:0;flex:1 1 auto}.page-header-text h1{font-size:clamp(1.125rem,4vw,1.5rem);font-weight:700;color:var(--gray-900);line-height:1.2}.page-header-text p{font-size:var(--fs-base);color:var(--gray-500);margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:600;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--primary-500);color:#fff}.btn-primary:hover{background:var(--primary-600)}.btn-outline{background:#fff;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-block{width:100%}.btn-sm{padding:6px 12px;font-size:var(--fs-sm)}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:var(--fs-base);font-weight:600;color:var(--gray-700)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:8px;transition:box-shadow var(--transition-base);position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card-header{display:flex;align-items:center;justify-content:space-between}.stat-label{font-size:var(--fs-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.stat-icon{width:20px;height:20px;color:var(--gray-400)}.stat-value{font-size:var(--fs-2xl);font-weight:700;color:var(--gray-900);line-height:1.1}.stat-change{font-size:var(--fs-sm);font-weight:500;display:inline-flex;align-items:center;gap:4px}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.stat-sub{font-size:var(--fs-xs);color:var(--gray-400)}.stat-bar{height:4px;border-radius:2px;background:var(--gray-100);margin-top:4px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:2px;transition:width var(--transition-slow)}.health-card{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.health-info h3{font-size:var(--fs-md);font-weight:600;color:var(--gray-800)}.health-info p{font-size:var(--fs-sm);color:var(--gray-500)}.health-score{display:flex;align-items:center;gap:12px}.health-score-value{text-align:right}.health-score-number{font-size:var(--fs-2xl);font-weight:700;color:var(--primary-500);line-height:1}.health-score-label{font-size:var(--fs-xs);font-weight:700;color:var(--success);text-transform:uppercase;letter-spacing:.05em}.health-ring{width:48px;height:48px}.health-ring circle{fill:none;stroke-width:4;stroke-linecap:round}.health-ring .ring-bg{stroke:var(--gray-200)}.health-ring .ring-fill{stroke:var(--primary-500);transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset var(--transition-slow)}.two-col{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}.toggle-group{display:inline-flex;background:var(--gray-100);border-radius:var(--radius-full);padding:3px}.toggle-btn{padding:5px 14px;border:none;background:none;border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:500;color:var(--gray-500);transition:all var(--transition-fast)}.toggle-btn.active{background:var(--primary-500);color:#fff}.category-list{display:flex;flex-direction:column;gap:14px}.category-item{display:flex;align-items:center;gap:10px}.category-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.category-name{flex:1;font-size:var(--fs-base);color:var(--gray-700)}.category-amount{font-size:var(--fs-base);font-weight:600;color:var(--gray-800)}.chart-container{position:relative;width:100%}.chart-container canvas{width:100%!important}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 14px;font-size:var(--fs-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--gray-200);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th:hover{color:var(--gray-700)}.data-table th .sort-arrow{margin-left:4px;opacity:.4}.data-table th.sorted .sort-arrow{opacity:1;color:var(--primary-500)}.data-table td{padding:12px 14px;font-size:var(--fs-base);color:var(--gray-700);border-bottom:1px solid var(--gray-100);max-width:300px}.data-table tr:hover td{background:var(--gray-50)}.amount-positive{color:var(--success);font-weight:600}.amount-negative{color:var(--danger);font-weight:600}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:500;background:var(--gray-100);color:var(--gray-600)}.chip-primary{background:var(--primary-50);color:var(--primary-500)}.chip-label{cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.chip-label:hover{background:var(--primary-100);color:var(--primary-700)}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;align-items:center}.filter-bar select,.filter-bar input[type=date],.filter-bar input[type=number],.filter-bar input[type=text]{padding:7px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--fs-sm);color:var(--gray-700);background:#fff;outline:none;transition:border-color var(--transition-fast)}.filter-bar select:focus,.filter-bar input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #1a56db1a}.filter-bar select{min-width:140px}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:20px}.pagination-count{font-size:var(--fs-sm);color:var(--gray-500);margin-right:8px;white-space:nowrap}.pagination button{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-200);background:#fff;border-radius:var(--radius-md);font-size:var(--fs-sm);color:var(--gray-600);transition:all var(--transition-fast)}.pagination button:hover{background:var(--gray-50);border-color:var(--gray-300)}.pagination button.active{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-bottom:24px}.accounts-empty-hint{grid-column:1 / -1;color:var(--gray-500);font-size:var(--fs-sm);padding:8px 0}.accounts-archived-section{margin-bottom:24px}.accounts-archived-header{margin-bottom:12px}.accounts-archived-title{font-size:15px;font-weight:600;margin:0 0 4px;color:var(--gray-700)}.accounts-archived-desc{font-size:13px;color:var(--gray-500);margin:0}.accounts-grid-archived{margin-bottom:0}.account-card-archived{opacity:.75;background:var(--gray-50);border-style:dashed;cursor:default}.account-card-archived:hover{box-shadow:none}.account-card-archived:before{background:var(--gray-300)!important}.account-restore-btn{margin-top:12px;width:100%}.account-settings-archived-header{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin:20px 0 12px;padding-top:16px;border-top:1px solid var(--gray-200)}.account-settings-row-archived{opacity:.85}.acct-archived-badge{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);background:var(--gray-100);padding:2px 6px;border-radius:4px;margin-left:6px;vertical-align:middle}.field-archive{min-width:100px}.account-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base);position:relative;overflow:hidden}.account-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary-500)}.account-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.account-card-name{font-size:var(--fs-sm);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}.account-card-balance{font-size:var(--fs-xl);font-weight:700;color:var(--gray-900)}.account-card-txns{font-size:var(--fs-xs);color:var(--gray-400);margin-top:6px}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;border:2px dashed var(--gray-300);border-radius:var(--radius-xl);background:var(--gray-50);text-align:center;gap:16px;padding:40px;transition:all var(--transition-base);cursor:pointer}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary-500);background:var(--primary-50)}.upload-zone-icon{width:64px;height:64px;color:var(--gray-400)}.upload-zone h2{font-size:var(--fs-xl);font-weight:700;color:var(--gray-700)}.upload-zone p{font-size:var(--fs-base);color:var(--gray-500)}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .4s ease-out forwards}.animate-in:nth-child(1){animation-delay:0ms}.animate-in:nth-child(2){animation-delay:60ms}.animate-in:nth-child(3){animation-delay:.12s}.animate-in:nth-child(4){animation-delay:.18s}.animate-in:nth-child(5){animation-delay:.24s}.animate-in:nth-child(6){animation-delay:.3s}.time-range{display:inline-flex;gap:4px;background:var(--gray-100);border-radius:var(--radius-full);padding:3px}.time-range-btn{padding:5px 12px;border:none;background:none;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:600;color:var(--gray-500);cursor:pointer;transition:all var(--transition-fast)}.time-range-btn.active{background:#fff;color:var(--gray-800);box-shadow:var(--shadow-xs)}.no-data{text-align:center;padding:40px;color:var(--gray-400);font-size:var(--fs-base)}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}}.hamburger-btn{display:none;flex-shrink:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:999;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.sidebar-overlay.visible{display:block}@media(max-width:768px){.hamburger-btn{display:flex}.sidebar{position:fixed;left:calc(-1 * var(--sidebar-width));height:100vh;transition:left var(--transition-base);z-index:1000;box-shadow:none}.sidebar.open{left:0;box-shadow:var(--shadow-lg)}.stats-grid{grid-template-columns:1fr}.inv-stats-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:16px;overflow-x:hidden}.topbar{padding:0 16px;gap:10px}.search-bar{min-width:0}#notif-btn{display:none!important}.accounts-grid{grid-template-columns:1fr}.page-header{flex-direction:column;gap:12px}.page-header-actions{flex-wrap:wrap;width:100%}.page-header-text h1{font-size:var(--fs-xl)}.page-header-text .data-range-badge,#dash-upload-btn{display:none}.metrics-bar{flex-direction:column!important;gap:10px!important;padding:12px 16px!important}.metrics-item{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left}.metrics-item-label{margin-bottom:0}.metrics-item-value{font-size:var(--fs-md);text-align:right}.metrics-divider{display:none}}.summary-strip{display:flex;gap:20px;padding:14px 20px;background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:16px;border:1px solid var(--gray-200);flex-wrap:wrap}.summary-item{display:flex;flex-direction:column}.summary-item-label{font-size:var(--fs-xs);color:var(--gray-500);font-weight:500}.summary-item-value{font-size:var(--fs-md);font-weight:700;color:var(--gray-800)}.sidebar-data-indicator{padding:12px 16px;margin:0 12px;border-top:1px solid var(--gray-200);display:flex;flex-direction:column;gap:2px}.sidebar-data-count{font-size:var(--fs-xs);font-weight:600;color:var(--gray-600)}.sidebar-data-range{font-size:var(--fs-xs);color:var(--gray-400);line-height:1.3}.data-range-badge{font-size:var(--fs-sm);color:var(--gray-400);font-weight:400}.app-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);background:var(--gray-800);color:#fff;padding:10px 24px;border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:500;box-shadow:var(--shadow-lg);opacity:0;transition:all .3s ease;z-index:10000;pointer-events:none}.app-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.undo-toast{display:flex;align-items:center;gap:16px;padding:10px 16px 10px 20px;border-radius:var(--radius-full);pointer-events:all;white-space:nowrap}.undo-toast-msg{flex:1}.undo-toast-btn{background:none;border:1.5px solid rgba(255,255,255,.5);color:#fff;font-size:var(--fs-sm);font-weight:600;padding:4px 12px;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);font-family:var(--font-family)}.undo-toast-btn:hover{background:#ffffff26}.category-item[style*=cursor]{padding:4px 6px;margin:-4px -6px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.category-item[style*=cursor]:hover{background:var(--gray-50)}.transfers-info-banner{display:flex;align-items:center;gap:12px;padding:12px 20px;background:linear-gradient(135deg,#eff6ff,#f0f9ff);border:1px solid #bfdbfe;border-radius:var(--radius-lg);margin-bottom:16px}.transfers-info-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#dbeafe;border-radius:var(--radius-md);color:var(--primary-600);flex-shrink:0}.transfers-info-text{flex:1;font-size:var(--fs-sm);color:var(--gray-600);line-height:1.4}.transfers-info-text strong{color:var(--gray-800)}.btn-ghost{background:none;border:none;color:var(--primary-600);font-weight:500;cursor:pointer;padding:4px 10px;border-radius:var(--radius-sm);transition:background var(--transition-fast);white-space:nowrap}.btn-ghost:hover{background:#dbeafe}.transfers-toggle-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:12px}.transfer-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.transfer-toggle input{display:none}.transfer-toggle-slider{position:relative;width:36px;height:20px;background:var(--gray-300);border-radius:var(--radius-full);transition:background .2s ease;flex-shrink:0}.transfer-toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #00000026}.transfer-toggle input:checked+.transfer-toggle-slider{background:var(--primary-500)}.transfer-toggle input:checked+.transfer-toggle-slider:before{transform:translate(16px)}.transfer-toggle-label{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--gray-500);font-weight:500}.transfer-row{background:var(--gray-50)!important}.transfer-row td{color:var(--gray-400)!important;font-style:italic}.transfer-row .chip{opacity:.7}.transfer-row .amount-positive,.transfer-row .amount-negative{opacity:.6}.transfer-badge{display:inline-flex;align-items:center;gap:2px;padding:1px 8px;background:#dbeafe;color:var(--primary-600);font-size:10px;font-weight:600;font-style:normal;border-radius:var(--radius-full);white-space:nowrap;vertical-align:middle;margin-left:4px}.manual-badge{display:inline-flex;align-items:center;padding:1px 6px;background:var(--warning-light);color:#92400e;font-size:10px;font-weight:600;border-radius:var(--radius-full);vertical-align:middle;margin-left:4px;cursor:default}.txn-actions-cell{width:64px;text-align:right;padding-right:8px!important}.txn-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:2px;opacity:0;transition:opacity var(--transition-fast)}tr:hover .txn-row-actions{opacity:1}.txn-row-btn{background:none;border:none;cursor:pointer;padding:5px;border-radius:var(--radius-sm);color:var(--gray-400);transition:color var(--transition-fast),background var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;line-height:1}.txn-edit-btn:hover{color:var(--primary-500);background:var(--primary-50)}.txn-delete-btn:hover{color:var(--danger);background:var(--danger-light)}.add-txn-type-row{display:flex;gap:8px;margin-bottom:16px}.add-txn-type-btn{flex:1;padding:8px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;color:var(--gray-500);font-family:var(--font-family);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.add-txn-type-btn:hover{border-color:var(--gray-300);color:var(--gray-700)}.add-txn-type-btn.active.expense{background:var(--danger-light);border-color:var(--danger);color:var(--danger);font-weight:600}.add-txn-type-btn.active.income{background:var(--success-light);border-color:var(--success);color:var(--success);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-panel{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .2s ease}.modal-panel-lg{max-width:700px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--gray-100)}.modal-header h2{font-size:var(--fs-lg);font-weight:700;color:var(--gray-900);margin:0}.modal-close{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{color:var(--gray-700);background:var(--gray-100)}.modal-body{padding:16px 24px;overflow-y:auto;flex:1}.modal-subtitle{font-size:var(--fs-sm);color:var(--gray-500);margin-bottom:16px;line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--gray-100)}.account-settings-list{display:flex;flex-direction:column;gap:12px}.account-settings-row{display:flex;align-items:flex-start;gap:16px;padding:14px 16px;background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-100)}.account-settings-info{min-width:140px;flex-shrink:0}.account-settings-name{font-weight:600;font-size:var(--fs-sm);color:var(--gray-800)}.account-settings-balance{font-size:var(--fs-xs);color:var(--gray-400);margin-top:2px}.account-settings-fields{display:flex;gap:10px;flex-wrap:wrap;flex:1}.field-group{display:flex;flex-direction:column;gap:4px;min-width:100px}.field-group label{font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px}.field-group input,.field-group select{padding:6px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-family:Inter,sans-serif;background:#fff;color:var(--gray-700);transition:border-color var(--transition-fast)}.field-group input:focus,.field-group select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #1a56db1a}.field-group.hidden{display:none}.input-with-suffix{display:flex;align-items:center;gap:0}.input-with-suffix input{border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);width:70px}.input-suffix{padding:6px 8px;background:var(--gray-100);border:1px solid var(--gray-200);border-left:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--fs-xs);color:var(--gray-500);white-space:nowrap}.account-group-header{grid-column:1 / -1;font-size:var(--fs-sm);font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;padding:8px 0 0;margin-top:8px}.account-group-header:first-child{margin-top:0}.account-type-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:14px;border-radius:var(--radius-sm);opacity:.8;flex-shrink:0}.account-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.account-card-subtitle{font-size:11px;color:var(--gray-400);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-card-interest{font-size:var(--fs-xs);color:var(--success);font-weight:600;margin-top:6px}.account-card-projected{font-size:11px;color:var(--gray-400);margin-top:2px}.account-card-breakdown{display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:8px}.account-card-breakdown-item{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--gray-500);font-weight:500}@media(max-width:768px){.modal-panel,.modal-panel-lg{width:95%;max-height:90vh}.account-settings-row{flex-direction:column;gap:10px}.account-settings-info{min-width:auto}.account-settings-fields{width:100%}}.metrics-item{text-align:center}.metrics-item-label{font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.metrics-item-value{font-size:18px;font-weight:700;color:var(--gray-900)}.metrics-item-pct{font-size:14px;font-weight:500}.balance-breakdown{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:8px}.breakdown-item{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--gray-500);font-weight:500}.breakdown-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.inv-pl-strip{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--gray-100);flex-wrap:wrap;font-size:11px}.inv-pl-label{color:var(--gray-500);font-weight:500}.inv-pl-arrow{color:var(--gray-300);font-size:12px}.inv-pl-value{font-weight:600;font-size:11px}.inv-pl-hint{color:var(--gray-400);font-style:italic;font-size:11px}.inv-stats-grid{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.inv-stats-grid{grid-template-columns:repeat(2,1fr)}}.inv-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;margin-bottom:20px}@media(max-width:1024px){.inv-grid{grid-template-columns:1fr}}.stat-icon-emoji{font-size:20px;line-height:1}.ticker-cell{display:flex;flex-direction:column;gap:1px}.ticker-symbol{font-weight:700;font-size:var(--fs-sm);color:var(--gray-900)}.ticker-name{font-size:11px;color:var(--gray-400);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.price-cell{display:flex;align-items:center}.price-input{width:85px;padding:4px 6px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-family:Inter,sans-serif;color:var(--gray-700);background:var(--gray-50);text-align:right;transition:border-color var(--transition-fast)}.price-input:focus{outline:none;border-color:var(--primary-500);background:#fff;box-shadow:0 0 0 3px #1a56db1a}.price-input::placeholder{color:var(--gray-300)}.pl-pct{font-size:11px;font-weight:500;opacity:.8}.txn-type-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.txn-type-buy{background:#d1fae5;color:#065f46}.txn-type-sell{background:#fee2e2;color:#991b1b}.txn-type-dividend{background:#dbeafe;color:#1e40af}.btn-icon-sm{background:none;border:none;cursor:pointer;color:var(--gray-400);padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-icon-sm:hover{color:var(--danger);background:#fee2e2}.empty-state{text-align:center;padding:80px 20px;background:#fff;border-radius:var(--radius-lg);border:2px dashed var(--gray-200)}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:var(--fs-lg);color:var(--gray-800);margin-bottom:8px}.empty-state p{font-size:var(--fs-sm);color:var(--gray-500);max-width:360px;margin:0 auto;line-height:1.5}.holding-row{cursor:default}.holding-row:hover{background:var(--gray-50)}.computed-value{padding:6px 10px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:600;color:var(--gray-700)}.form-row{display:flex;gap:12px;margin-bottom:12px}@media(max-width:480px){.form-row{flex-direction:column}.filter-bar select,.filter-bar input[type=text]{width:100%;min-width:0}.period-label{min-width:100px;font-size:var(--fs-sm)}}.field-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px #ef44441a!important}.field-readonly{background:var(--gray-50)!important;color:var(--gray-500)!important;cursor:not-allowed;opacity:.8}.txn-imported-notice{font-size:var(--fs-sm);color:var(--gray-500);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:12px}body.dark-mode .field-readonly{background:var(--gray-800)!important;color:var(--gray-400)!important}body.dark-mode .txn-imported-notice{background:var(--gray-800);border-color:var(--gray-700);color:var(--gray-400)}.btn-outline{background:#fff;border:1px solid var(--gray-200);color:var(--gray-700);padding:8px 16px;border-radius:var(--radius-md);font-size:var(--fs-sm);font-weight:500;font-family:Inter,sans-serif;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all var(--transition-fast)}.btn-outline:hover{background:var(--gray-50);border-color:var(--gray-300)}select.btn{-webkit-appearance:none;-moz-appearance:none;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.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}select.btn:focus{outline:none;background-color:#fff;border-color:var(--gray-300)}.page-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}.price-status-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-md);margin-bottom:16px;font-size:var(--fs-sm);color:var(--gray-600);flex-wrap:wrap}.price-status-text{flex:1;min-width:200px}.price-status-detail{font-size:var(--fs-xs);color:var(--gray-400);font-family:Inter,monospace}.price-progress-bar{width:100%;height:4px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;margin-top:4px;order:99}.price-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);transition:width .3s ease}.btn-loading{opacity:.7;cursor:wait!important}.btn-loading svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.price-source-icon{font-size:12px;margin-left:4px;cursor:help;flex-shrink:0}.price-cell{display:flex;align-items:center;gap:4px}.ticker-search-group{position:relative}.ticker-search-wrap{position:relative;display:flex;align-items:center}.ticker-search-icon{position:absolute;left:10px;color:var(--gray-400);pointer-events:none;z-index:1}.ticker-search-wrap input{width:100%;padding:8px 36px 8px 34px;border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:var(--fs-sm);font-family:Inter,sans-serif;color:var(--gray-800);background:#fff;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.ticker-search-wrap input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #1a56db1a}.ticker-search-spinner{position:absolute;right:10px;display:flex;align-items:center;color:var(--primary-500)}.ticker-search-spinner svg{animation:spin .8s linear infinite}.ticker-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;max-height:320px;overflow-y:auto;z-index:100;margin-top:4px}.ticker-suggestion-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--gray-50);transition:background var(--transition-fast)}.ticker-suggestion-item:last-child{border-bottom:none}.ticker-suggestion-item:hover{background:var(--primary-50)}.suggestion-main{display:flex;align-items:center;gap:8px;margin-bottom:2px}.suggestion-symbol{font-weight:700;font-size:var(--fs-sm);color:var(--gray-900);font-family:Inter,monospace}.suggestion-type-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--radius-full);background:var(--gray-100);color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.suggestion-name{font-size:12px;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-meta{font-size:11px;color:var(--gray-400);margin-top:1px}.ticker-suggestion-empty{padding:16px;text-align:center;font-size:var(--fs-sm);color:var(--gray-400)}.selected-ticker-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-md);margin-bottom:12px}.selected-ticker-info{flex:1;display:flex;align-items:baseline;gap:8px;min-width:0}.selected-ticker-symbol{font-weight:700;font-size:var(--fs-base);color:var(--primary-700);font-family:Inter,monospace}.selected-ticker-name{font-size:var(--fs-sm);color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-ticker-meta{font-size:11px;color:var(--gray-400);white-space:nowrap}.btn-clear-ticker{background:none;border:none;cursor:pointer;font-size:18px;color:var(--gray-400);padding:2px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1}.btn-clear-ticker:hover{color:var(--danger);background:#fee2e2}.account-card-negative{border:1px solid var(--danger);background:#fef2f2}.account-card-negative:before{background:var(--danger)!important}.account-card-negative .account-card-balance{color:var(--danger)}.account-card-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;opacity:.85}.account-card-icon svg{display:block}.appearance-panel{width:100%;padding:14px 16px;margin-top:10px;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-md);animation:fadeSlideIn .2s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.appearance-section{margin-bottom:12px}.appearance-section:last-child{margin-bottom:0}.appearance-section-header{display:flex;align-items:center;margin-bottom:8px}.appearance-section-label{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.icon-picker-grid{display:flex;flex-wrap:wrap;gap:6px}.icon-picker-item{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;color:var(--gray-500);cursor:pointer;transition:all var(--transition-fast)}.icon-picker-item:hover{border-color:var(--primary-400);color:var(--primary-500);background:var(--primary-50);transform:scale(1.08)}.icon-picker-item.selected{border-color:var(--primary-500);color:var(--primary-600);background:var(--primary-50);box-shadow:0 0 0 2px #1a56db26}.color-picker-grid{display:flex;flex-wrap:wrap;gap:8px}.color-picker-item{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:0 1px 3px #00000026}.color-picker-item:hover{transform:scale(1.15);box-shadow:0 2px 8px #0003}.color-picker-item.selected{border-color:#fff;box-shadow:0 0 0 2px var(--gray-800),0 2px 8px #0003;transform:scale(1.1)}.acct-appearance-btn{display:inline-flex!important;align-items:center;gap:4px;padding:5px 10px!important}.acct-icon-preview{display:block}.acct-icon-preview-emoji{font-size:14px;line-height:1}.acct-color-swatch{display:inline-block;width:14px;height:14px;border-radius:var(--radius-full);border:1.5px solid rgba(255,255,255,.5);box-shadow:0 0 0 1px #0000001a}.txn-detail-header{text-align:center;padding-bottom:20px;border-bottom:1px solid var(--gray-100);margin-bottom:20px}.txn-detail-amount{font-size:32px;font-weight:800;font-family:Inter,sans-serif;letter-spacing:-.5px}.txn-detail-meta{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px}.txn-detail-date{font-size:var(--fs-sm);color:var(--gray-400)}.txn-detail-badge{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);font-weight:600;padding:3px 10px;border-radius:var(--radius-full)}.txn-detail-grid{display:flex;flex-direction:column;gap:0}.txn-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gray-50)}.txn-detail-row:last-child{border-bottom:none}.txn-detail-label{font-size:var(--fs-xs);font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.3px}.txn-detail-value{font-size:var(--fs-sm);font-weight:500;color:var(--gray-800);text-align:right;max-width:60%}.txn-detail-note-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-100)}.txn-detail-note{margin-top:8px;font-size:var(--fs-sm);color:var(--gray-700);line-height:1.6;background:var(--gray-50);padding:12px 14px;border-radius:var(--radius-md);word-break:break-word}.data-table tbody tr[data-txn-index]:hover,.data-table tbody tr.holding-txn-row:hover,.holdings-table tbody tr.holding-row:hover{background:var(--primary-50);transition:background var(--transition-fast)}.holding-row{cursor:pointer}.import-preview-panel{width:95vw}.import-preview-table .import-edit{width:100%;padding:4px 6px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-family);background:#fff;transition:border-color var(--transition-fast)}.import-preview-table .import-edit:focus{border-color:var(--primary-500);outline:none;box-shadow:0 0 0 2px #1a56db26}.import-preview-table .import-edit-num{text-align:right}.import-preview-table .import-edit-type{padding:4px 2px;cursor:pointer}.import-row-excluded{opacity:.4;text-decoration:line-through}.import-row-excluded .import-edit{pointer-events:none}.btn-range{background:transparent;border:none;font-family:var(--font-family);font-size:12px;font-weight:500;color:var(--gray-500);padding:4px 10px;border-radius:4px;cursor:pointer;transition:all var(--transition-fast)}.btn-range:hover{color:var(--gray-900);background:var(--gray-200)}.btn-range.active{background:#fff;color:var(--primary-600);box-shadow:0 1px 2px #0000000d}.avatar-initials{font-size:13px;font-weight:700;letter-spacing:.02em;color:#fff}.user-menu{position:fixed;z-index:1200;min-width:260px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:8px;animation:userMenuIn .15s ease}@keyframes userMenuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{display:flex;align-items:center;gap:12px;padding:10px 10px 12px}.user-menu-avatar{width:40px;height:40px;flex-shrink:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}.user-menu-avatar svg{width:20px;height:20px}.user-menu-identity{display:flex;flex-direction:column;min-width:0}.user-menu-name{font-size:var(--fs-base);font-weight:600;color:var(--gray-900);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-subtitle{font-size:var(--fs-xs);color:var(--gray-500);margin-top:2px}.user-menu-divider{height:1px;background:var(--gray-100);margin:4px 0}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;background:none;border-radius:var(--radius-sm);color:var(--gray-700);font-size:var(--fs-base);font-weight:500;text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.user-menu-item:hover{background:var(--gray-100);color:var(--gray-900)}.user-menu-item svg{width:18px;height:18px;flex-shrink:0;color:var(--gray-500)}.user-menu-item:hover svg{color:var(--gray-700)}.user-menu-item-danger{color:var(--danger)}.user-menu-item-danger:hover{background:var(--danger-light);color:var(--danger)}.user-menu-item-danger svg,.user-menu-item-danger:hover svg{color:var(--danger)}.prefs-modal-body{padding:8px 24px 24px}.prefs-section{padding:16px 0;border-bottom:1px solid var(--gray-100)}.prefs-section:last-child{border-bottom:none}.prefs-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);margin-bottom:12px}.prefs-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.prefs-field:last-child{margin-bottom:0}.prefs-field label{font-size:var(--fs-sm);font-weight:600;color:var(--gray-700)}.prefs-field input[type=text],.prefs-field select{padding:9px 12px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-base);color:var(--gray-800);background:#fff;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.prefs-field input[type=text]:focus,.prefs-field select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.prefs-hint{font-size:var(--fs-xs);color:var(--gray-500);line-height:1.4}.prefs-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}.prefs-field-wide{grid-column:1 / -1}.prefs-section-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}.prefs-section-header .prefs-section-title{margin-bottom:0}.prefs-acct-list{display:flex;flex-direction:column;gap:6px;margin-top:10px;max-height:220px;overflow-y:auto;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:8px;background:var(--gray-50)}.prefs-acct-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 10px;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-sm)}.prefs-acct-name{font-size:var(--fs-sm);font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.prefs-acct-currency{width:78px;padding:5px 8px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:600;color:var(--gray-800);background:#fff;cursor:pointer}.prefs-acct-currency:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.prefs-swatches{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.prefs-swatch{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid transparent;padding:0;cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast);box-shadow:0 0 0 1px var(--gray-200)}.prefs-swatch:hover{transform:scale(1.08)}.prefs-swatch.is-selected{border-color:#fff;box-shadow:0 0 0 2px var(--gray-900)}.prefs-toggle{display:flex;align-items:flex-start;gap:12px;padding:12px;margin-top:10px;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none}.prefs-toggle input{display:none}.prefs-toggle-slider{position:relative;flex-shrink:0;width:36px;height:20px;background:var(--gray-300);border-radius:var(--radius-full);transition:background var(--transition-fast);margin-top:2px}.prefs-toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #00000026;transition:transform var(--transition-fast)}.prefs-toggle input:checked+.prefs-toggle-slider{background:var(--primary-500)}.prefs-toggle input:checked+.prefs-toggle-slider:before{transform:translate(16px)}.prefs-toggle-text{display:flex;flex-direction:column;gap:2px;flex:1}.prefs-toggle-text strong{font-size:var(--fs-base);font-weight:600;color:var(--gray-800)}.prefs-toggle-text span{font-size:var(--fs-xs);color:var(--gray-500);line-height:1.4}.period-picker{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding:8px 12px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg)}.period-nav-group{display:flex;align-items:center;gap:4px}.period-nav-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius-sm);background:none;color:var(--gray-500);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.period-nav-btn:hover{background:var(--gray-100);color:var(--gray-800)}.period-label{font-size:var(--fs-base);font-weight:600;color:var(--gray-900);min-width:140px;text-align:center}.period-label-static{padding:0 8px}.period-mode{padding:5px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:500;color:var(--gray-700);background:#fff;cursor:pointer;outline:none;transition:border-color var(--transition-fast)}.period-mode:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.period-custom{display:flex;align-items:center;gap:6px}.period-custom input[type=date]{padding:5px 8px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);color:var(--gray-700);background:#fff}.period-custom input[type=date]:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50)}.period-custom-sep{color:var(--gray-400);font-size:var(--fs-sm)}#period-today{margin-left:auto}.expenses-kpis{grid-template-columns:repeat(4,1fr)}.insights-panel{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}.insights-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:14px 18px;background:none;border:none;text-align:left;cursor:pointer;color:var(--gray-700);font-weight:600;font-size:var(--fs-base);transition:background var(--transition-fast)}.insights-toggle:hover{background:var(--gray-50)}.insights-toggle-icon{display:flex;color:var(--primary-500)}.insights-toggle-text{color:var(--gray-900)}.insights-toggle-meta{flex:1;color:var(--gray-400);font-weight:400;font-size:var(--fs-sm)}.insights-chevron{display:flex;color:var(--gray-400);transition:transform var(--transition-base)}.insights-panel.is-open .insights-chevron{transform:rotate(180deg)}.insights-body{display:none;padding:0 18px 18px}.insights-panel.is-open .insights-body{display:block}.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.insights-card{padding:16px;display:flex;flex-direction:column;min-height:290px;min-width:0}.insights-card-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px;gap:10px}.insights-card-header h3{font-size:var(--fs-base);font-weight:600;color:var(--gray-800);margin:0}.insights-card-sub{font-size:var(--fs-xs);color:var(--gray-400)}.insights-rollup-toggle{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-xs);font-weight:500;color:var(--gray-500);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.insights-rollup-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary-500);cursor:pointer;margin:0}.insights-rollup-toggle span{line-height:1}.insights-chart-wrap{position:relative;flex:1;min-height:220px}.insights-chart-wrap-doughnut{max-height:200px}.insights-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--gray-400);font-size:var(--fs-sm);padding:24px}.insights-empty.hidden,canvas.hidden{display:none}.insights-legend{display:flex;flex-direction:column;gap:4px;margin-top:10px;max-height:130px;overflow-y:auto}.insights-legend-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.insights-legend-row:hover{background:var(--gray-50)}.insights-legend-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}.insights-legend-label{flex:1;font-size:var(--fs-sm);color:var(--gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.insights-legend-value{font-size:var(--fs-sm);font-weight:600;color:var(--gray-800);white-space:nowrap}.insights-legend-pct{font-weight:500;color:var(--gray-400);margin-left:4px}.calendar-heatmap{--cell-size: 12px;--cell-gap: 3px;font-family:var(--font-family);display:flex;flex-direction:column;flex:1;min-height:0}.cal-stage{display:block;width:fit-content;margin:0 auto}.cal-month-row{display:grid;grid-auto-flow:column;grid-auto-columns:calc(var(--cell-size) + var(--cell-gap));gap:0;margin-bottom:4px;margin-left:28px;font-size:10px;color:var(--gray-400);line-height:1;min-height:12px}.cal-corner{display:none}.cal-month-label{white-space:nowrap}.cal-body{display:flex;gap:4px;align-items:flex-start}.cal-day-labels{display:grid;grid-template-rows:repeat(7,var(--cell-size));row-gap:var(--cell-gap);font-size:9px;color:var(--gray-400);width:24px}.cal-day-label{line-height:var(--cell-size);white-space:nowrap}.cal-weeks{display:flex;gap:var(--cell-gap)}.cal-week{display:grid;grid-template-rows:repeat(7,var(--cell-size));row-gap:var(--cell-gap)}.cal-cell{width:var(--cell-size);height:var(--cell-size);border-radius:2px;background:var(--gray-100);transition:outline var(--transition-fast)}.cal-cell[data-level="0"]{background:var(--gray-100)}.cal-cell[data-level="1"]{background:#dbeafe}.cal-cell[data-level="2"]{background:#93c5fd}.cal-cell[data-level="3"]{background:#3b82f6}.cal-cell[data-level="4"]{background:#1e40af}.cal-cell-out{width:var(--cell-size);height:var(--cell-size);background:transparent}.cal-cell[data-level]:hover{outline:2px solid var(--gray-700);outline-offset:1px}.cal-legend{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:auto;padding-top:12px;font-size:11px;color:var(--gray-500)}.cal-legend .cal-cell{width:10px;height:10px;cursor:default}.cal-legend-text{margin:0 4px}@media(max-width:1240px){.insights-grid{grid-template-columns:1fr 1fr}}.label-breakdown-list{display:flex;flex-direction:column;gap:8px}.label-breakdown-row{display:grid;grid-template-columns:1fr 2fr auto auto;align-items:center;gap:10px;padding:4px 0;cursor:pointer}.label-breakdown-name{font-size:var(--fs-sm);font-weight:500;color:var(--gray-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.label-breakdown-bar-bg{height:6px;border-radius:3px;background:var(--gray-100);overflow:hidden}.label-breakdown-bar-fill{height:100%;border-radius:3px;background:var(--primary-400)}.label-breakdown-amount{font-size:var(--fs-sm);font-weight:600;color:var(--gray-700);white-space:nowrap;text-align:right}.label-breakdown-count{font-size:11px;color:var(--gray-400);white-space:nowrap;min-width:44px;text-align:right}body.dark-mode .label-breakdown-bar-bg{background:var(--gray-700)}body.dark-mode .label-breakdown-name{color:var(--gray-200)}body.dark-mode .label-breakdown-amount{color:var(--gray-300)}.label-mgr-list{display:flex;flex-direction:column;gap:2px}.label-mgr-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:8px 4px;border-radius:var(--radius-sm)}.label-mgr-row:hover{background:var(--gray-50)}.label-mgr-name{font-size:var(--fs-sm);font-weight:500;color:var(--gray-800)}.label-mgr-meta{font-size:11px;color:var(--gray-400);white-space:nowrap}.label-mgr-actions{display:flex;gap:4px}.label-mgr-input{width:100%;padding:6px 10px;border:1px solid var(--primary-300);border-radius:var(--radius-sm);font-size:var(--fs-sm);background:var(--surface);color:var(--text-primary)}body.dark-mode .label-mgr-row:hover{background:var(--gray-800)}body.dark-mode .label-mgr-name{color:var(--gray-200)}@media(max-width:760px){.insights-grid{grid-template-columns:1fr}.expenses-kpis{grid-template-columns:repeat(2,1fr)}}body.compact-mode .page-content{padding:18px}body.compact-mode .stat-card,body.compact-mode .card{padding:14px 16px}body.compact-mode .page-header{margin-bottom:16px}body.compact-mode .topbar{height:52px;padding:0 18px}body.compact-mode :root{--topbar-height: 52px}.inv-scope-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:var(--card-bg, #fff);border:1px solid var(--gray-200);border-radius:10px;padding:8px 10px;margin-bottom:16px}.inv-scope-label{font-size:var(--fs-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;margin-right:4px}.inv-scope-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-700);border-radius:999px;padding:5px 12px;font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.inv-scope-pill:hover{background:#fff;border-color:var(--gray-300);color:var(--gray-800)}.inv-scope-pill.active{background:var(--primary-600, #1a56db);border-color:var(--primary-600, #1a56db);color:#fff}.inv-scope-pill.active .inv-scope-dot{box-shadow:0 0 0 2px #fff6 inset}.inv-scope-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-400);flex-shrink:0}.inv-scope-dot-all{background:linear-gradient(135deg,#1a56db,#10b981)}.inv-compare-section{margin-bottom:24px}.inv-compare-section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.inv-compare-section-header h3{margin:0;font-size:var(--fs-base);font-weight:600;color:var(--gray-800)}.inv-compare-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.inv-compare-card{position:relative;display:flex;align-items:stretch;gap:0;background:var(--card-bg, #fff);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:0;text-align:left;cursor:pointer;overflow:hidden;transition:box-shadow var(--transition-fast),transform var(--transition-fast),border-color var(--transition-fast)}.inv-compare-card:hover{border-color:var(--gray-300);transform:translateY(-1px);box-shadow:0 4px 12px #0f172a0f}.inv-compare-accent{width:4px;background:var(--primary-600, #1a56db);flex-shrink:0}.inv-compare-body{flex:1;padding:12px 14px;display:flex;flex-direction:column;gap:4px;min-width:0}.inv-compare-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.inv-compare-name{font-size:var(--fs-sm);font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-compare-count{font-size:var(--fs-xs);color:var(--gray-400);flex-shrink:0}.inv-compare-value{font-size:var(--fs-lg);font-weight:700;color:var(--gray-900);line-height:1.2}.inv-compare-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:var(--fs-xs);color:var(--gray-500)}.inv-compare-invested{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-compare-spark{margin-top:4px;display:block}.alloc-tab-bar{display:flex;gap:2px;background:var(--gray-100);border-radius:6px;padding:3px}.alloc-tab{border:none;background:transparent;color:var(--gray-500);font-size:var(--fs-xs);font-weight:600;padding:4px 10px;border-radius:4px;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.alloc-tab:hover{color:var(--gray-700)}.alloc-tab.active{background:#fff;color:var(--gray-800);box-shadow:0 1px 3px #0f172a14}.toggle-pill-row{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:var(--fs-xs);color:var(--gray-500);-webkit-user-select:none;user-select:none}.toggle-pill-row input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary, #1a56db);cursor:pointer}.toggle-pill-label{font-weight:500}.alloc-custom-legend{display:flex;flex-direction:column;gap:6px;padding:8px 16px 4px}.alloc-legend-item{display:flex;align-items:center;gap:8px;font-size:var(--fs-xs)}.alloc-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.alloc-legend-label{color:var(--gray-700);font-weight:500}.alloc-legend-pct{margin-left:auto;color:var(--gray-500);font-variant-numeric:tabular-nums}.alloc-legend-hidden .alloc-legend-dot{opacity:.3}.alloc-legend-hidden .alloc-legend-label{text-decoration:line-through;opacity:.4}.alloc-legend-hidden .alloc-legend-pct{opacity:.4}.import-dest-section{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:16px}.import-dest-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;flex-wrap:wrap}.import-dest-label{font-size:var(--fs-sm);font-weight:600;color:var(--gray-800)}.import-dest-help{font-size:var(--fs-xs);color:var(--gray-500)}.import-dest-controls{display:flex;flex-direction:column;gap:8px}.import-dest-select{width:100%;max-width:360px;padding:8px 10px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;font-size:var(--fs-sm)}.import-dest-create{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.import-dest-new-input{flex:1;min-width:200px;padding:8px 10px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:var(--fs-sm)}.savings-page{display:flex;flex-direction:column;gap:20px}.savings-page>.stats-grid,.savings-page>.insights-panel,.savings-page>.card,.savings-page>.savings-pots-card{margin-bottom:0}.savings-page .insights-panel .insights-body{padding-top:18px}.savings-stat-positive{color:#10b981}.savings-stat-negative{color:#ef4444}.savings-insights-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px}.savings-chart-main{display:flex;flex-direction:column;min-height:340px}.savings-chart-main .insights-chart-wrap{min-height:260px}.savings-charts-side{display:flex;flex-direction:column;gap:16px}.savings-charts-side .insights-card{flex:1;min-height:0}.savings-charts-side .insights-chart-wrap{min-height:110px}.savings-pots-inner{display:flex;gap:32px;align-items:flex-start}.savings-pots-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px}.savings-pots-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.savings-pots-hero{display:flex;flex-direction:column;gap:2px}.savings-pots-hero-label{font-size:var(--fs-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.savings-pots-hero-value{font-size:clamp(26px,5vw,36px);font-weight:700;line-height:1.1;letter-spacing:-.02em}.savings-pots-hero-sub{font-size:var(--fs-sm);color:var(--gray-400);margin-top:2px}.savings-pot-compact-list{display:flex;flex-direction:column;gap:0}.savings-pot-compact-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--gray-100)}.savings-pot-compact-row:last-child{border-bottom:none}.savings-pot-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.savings-pot-name{flex:1;font-size:var(--fs-sm);color:var(--gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.savings-pot-amt{font-size:var(--fs-sm);font-weight:600;white-space:nowrap}.savings-pots-donut-side{flex-shrink:0;width:180px;display:flex;flex-direction:column;align-items:center;padding-top:8px}.savings-pots-donut-wrap{width:160px;height:160px;position:relative}.savings-pots-empty{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.savings-pots-empty-text{flex:1;min-width:200px}.savings-breakdown{overflow-x:auto}.savings-table{width:100%}.savings-table th.num,.savings-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.savings-rate-cell{display:flex;align-items:center;justify-content:flex-end;gap:8px}.savings-rate-bar-track{width:44px;height:5px;background:var(--gray-100);border-radius:99px;overflow:hidden;flex-shrink:0}.savings-rate-bar-fill{height:100%;border-radius:99px;transition:width .3s ease}@media(max-width:720px){.savings-insights-layout{grid-template-columns:1fr}.savings-pots-donut-side{display:none}}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--gray-100)}.login-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px}.login-brand{text-align:center;margin-bottom:24px}.login-logo{width:48px;height:48px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--primary-600);color:#fff}.login-logo svg{width:26px;height:26px}.login-title{font-size:22px;font-weight:700;color:var(--gray-900);margin:0 0 4px}.login-subtitle{font-size:14px;color:var(--gray-500);margin:0}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:12px 14px;font-size:15px;border:1px solid var(--gray-300);border-radius:var(--radius-md);background:#fff;color:var(--gray-900);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.login-error{font-size:13px;color:var(--danger);background:var(--danger-light);border-radius:var(--radius-sm);padding:8px 12px}.login-submit{width:100%;justify-content:center;padding:12px;font-size:15px}.offline-banner{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:1500;display:flex;align-items:center;gap:12px;max-width:calc(100% - 24px);margin-top:8px;padding:8px 12px 8px 16px;font-size:13px;font-weight:500;color:#92400e;background:var(--warning-light, #fef3c7);border:1px solid var(--warning, #f59e0b);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.offline-banner-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:18px;line-height:1;color:inherit;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;opacity:.7}.offline-banner-close:hover{opacity:1;background:#0000000f}body.dark-mode .sidebar,body.dark-mode .topbar,body.dark-mode .card,body.dark-mode .stat-card,body.dark-mode .modal-panel,body.dark-mode .login-card,body.dark-mode .inv-compare-card{background:var(--gray-100)}body.dark-mode .transfers-info-banner{background:var(--gray-100);border-color:var(--gray-300)}body.dark-mode .transfers-info-icon{background:var(--gray-200);color:var(--primary-500)}body.dark-mode .btn-outline{background:transparent;color:var(--gray-700);border-color:var(--gray-300)}body.dark-mode .btn-outline:hover{background:var(--gray-200)}body.dark-mode select.btn{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='%237a8ea0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}body.dark-mode select.btn:focus{background-color:transparent;border-color:var(--gray-300)}body.dark-mode .btn-ghost{color:var(--gray-600)}body.dark-mode .btn-ghost:hover{background:var(--gray-200)}body.dark-mode .filter-bar select,body.dark-mode .filter-bar input[type=date],body.dark-mode .filter-bar input[type=number],body.dark-mode .filter-bar input[type=text],body.dark-mode .field-group input,body.dark-mode .field-group select,body.dark-mode .login-input,body.dark-mode .import-dest-select,body.dark-mode .import-dest-new-input,body.dark-mode .holding-form input,body.dark-mode .holding-form select{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .search-bar input{color:var(--gray-800)}body.dark-mode #txn-amount,body.dark-mode #txn-note,body.dark-mode #txn-date,body.dark-mode #txn-payee,body.dark-mode #txn-labels,body.dark-mode #txn-category{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .data-table th{color:var(--gray-500);border-bottom-color:var(--gray-200)}body.dark-mode .data-table td{color:var(--gray-700);border-bottom-color:var(--gray-200)}body.dark-mode .data-table tr:hover td{background:var(--gray-200)}body.dark-mode .pagination button{background:var(--gray-100);border-color:var(--gray-200);color:var(--gray-600)}body.dark-mode .pagination button:hover{background:var(--gray-200)}body.dark-mode .pagination button.active{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}body.dark-mode .period-picker{background:var(--gray-100);border-color:var(--gray-200)}body.dark-mode .period-mode,body.dark-mode select.period-mode,body.dark-mode .period-custom input[type=date]{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .period-custom input[type=date]:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #6366f126}body.dark-mode .chip{background:var(--gray-200);color:var(--gray-700)}body.dark-mode .chip-primary{background:var(--primary-100);color:var(--primary-600)}body.dark-mode .chip-label:hover{background:var(--primary-900);color:var(--primary-200)}body.dark-mode .alloc-tab.active{background:var(--gray-200);color:var(--gray-800);box-shadow:0 1px 3px #0000004d}body.dark-mode .insights-panel{background:var(--gray-100);border-color:var(--gray-200)}body.dark-mode .insights-toggle{color:var(--gray-700)}body.dark-mode .insights-toggle:hover{background:var(--gray-200)}body.dark-mode .insights-card{background:var(--gray-100)}body.dark-mode .ticker-suggestions{background:var(--gray-100);border-color:var(--gray-200)}body.dark-mode .ticker-suggestion-item{color:var(--gray-700)}body.dark-mode .ticker-suggestion-item:hover{background:var(--gray-200)}body.dark-mode .selected-ticker-card{background:var(--gray-200);border-color:var(--gray-300)}body.dark-mode .account-card{background:var(--gray-100)}body.dark-mode .import-dest-section{background:var(--gray-200);border-color:var(--gray-300)}body.dark-mode ::-webkit-scrollbar-thumb{background:var(--gray-300)}body.dark-mode .add-txn-type-btn{background:var(--gray-200);border-color:var(--gray-300);color:var(--gray-600)}body.dark-mode .add-txn-type-btn:hover{background:var(--gray-300)}body.dark-mode .transfer-badge{background:var(--primary-100);color:var(--primary-600)}body.dark-mode .btn-primary:hover{background:#3b78e7}body.dark-mode .login-logo{background:var(--primary-500)}body.dark-mode .inv-scope-pill.active{background:var(--primary-500);border-color:var(--primary-500)}body.dark-mode .inv-compare-accent{background:var(--primary-500)}body.dark-mode .inv-scope-bar{background:var(--gray-100);border-color:var(--gray-200)}body.dark-mode .inv-scope-pill{background:var(--gray-200);border-color:var(--gray-300);color:var(--gray-700)}body.dark-mode .inv-scope-pill:hover{background:var(--gray-300);border-color:var(--gray-400);color:var(--gray-800)}body.dark-mode .chart-range-selector{background:var(--gray-200)}body.dark-mode .btn-range.active{background:var(--gray-100);color:var(--primary-500);box-shadow:0 1px 3px #0000004d}body.dark-mode .time-range{background:var(--gray-200)}body.dark-mode .time-range-btn{color:var(--gray-400)}body.dark-mode .time-range-btn:hover{color:var(--gray-200);background:var(--gray-300)}body.dark-mode .time-range-btn.active{background:var(--gray-100);color:var(--primary-500);box-shadow:0 1px 3px #0000004d}body.dark-mode .alloc-tab-bar{background:var(--gray-200)}body.dark-mode .notif-item{border-color:var(--gray-200)}body.dark-mode .notif-item:hover{background:var(--gray-200)}body.dark-mode .offline-banner{color:#fbbf24;background:#431407;border-color:#92400e}body{transition:background-color .2s ease,color .2s ease}.sidebar,.topbar,.card,.stat-card,.modal-panel{transition:background-color .2s ease,border-color .2s ease}body.dark-mode .category-manager-table-wrap{border-color:var(--gray-300)}body.dark-mode .category-manager-table th{background:var(--gray-200);color:var(--gray-600);border-color:var(--gray-300)}body.dark-mode .category-manager-table td{border-color:var(--gray-200)}body.dark-mode .cat-display-input,body.dark-mode .cat-merge-select{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .cat-display-input:focus,body.dark-mode .cat-merge-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #6366f126}body.dark-mode .cat-raw-name code{background:var(--gray-200);color:var(--gray-600)}body.dark-mode .cat-text-input{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .cat-text-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #6366f126}body.dark-mode .cat-move-select{background:var(--gray-200);color:var(--gray-800);border-color:var(--gray-300)}body.dark-mode .cat-group-card{background:var(--gray-100)}.category-manager-table-wrap{overflow-x:auto;border:1px solid var(--gray-100);border-radius:var(--radius-md)}.category-manager-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.category-manager-table th{padding:8px 12px;text-align:left;font-weight:600;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-100);white-space:nowrap}.category-manager-table td{padding:8px 12px;border-bottom:1px solid var(--gray-50);vertical-align:middle}.category-manager-table tr:last-child td{border-bottom:none}.cat-raw-name code{font-size:.78rem;color:var(--gray-500);background:var(--gray-100);padding:2px 6px;border-radius:var(--radius-sm)}.cat-display-input,.cat-merge-select{width:100%;min-width:130px;padding:5px 8px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);background:var(--bg-primary);color:var(--text-primary)}.cat-display-input:disabled{opacity:.45;cursor:not-allowed}.cat-color-swatches{display:flex;gap:5px;flex-wrap:wrap}.cat-color-swatch{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .1s,border-color .1s}.cat-color-swatch:hover{transform:scale(1.2)}.cat-color-swatch.selected{border-color:var(--text-primary);transform:scale(1.15)}.cat-color-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle;flex-shrink:0}.cat-text-input{padding:8px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);background:var(--bg-primary, #fff);color:var(--text-primary, inherit)}.cat-new-card{margin-bottom:16px}.cat-new-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.cat-new-row #new-cat-name{flex:1;min-width:200px}.cat-groups{display:flex;flex-direction:column;gap:14px}.cat-group-card{padding:14px 16px}.cat-group-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.cat-group-dot{width:14px;height:14px}.cat-group-name{font-weight:600;min-width:160px}.cat-group-name-static{margin:0;font-size:var(--fs-base);color:var(--gray-500)}.cat-group-count{font-size:.72rem;font-weight:600;color:var(--gray-500);background:var(--gray-100);border-radius:999px;padding:2px 8px}.cat-group-swatches{margin-left:auto}.cat-group-delete{color:var(--danger, #ef4444)}.cat-group-body{display:flex;flex-direction:column;gap:8px}.cat-sub-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.cat-move-select{padding:4px 8px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);background:var(--bg-primary, #fff);color:var(--text-primary, inherit);max-width:200px}.cat-empty-hint{color:var(--gray-500);font-size:var(--fs-sm);margin:4px 0}.cat-result-banner{background:var(--primary-50, #eef2ff);border:1px solid var(--primary-200, #c7d2fe);color:var(--text-primary, inherit);border-radius:var(--radius-md);padding:10px 14px;margin-bottom:14px;font-size:var(--fs-sm)}.cat-result-muted{color:var(--gray-500);margin-left:6px}.budget-month-nav{display:flex;align-items:center;justify-content:center;gap:12px;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--gray-100)}.budget-month-label{font-size:var(--fs-base);font-weight:600;color:var(--gray-900);min-width:160px;text-align:center}.budget-rows{display:flex;flex-direction:column;gap:12px}.budget-row{display:grid;grid-template-columns:1fr 2fr auto auto;align-items:center;gap:14px}.budget-row-name{display:flex;align-items:center;gap:8px;font-size:var(--fs-sm);font-weight:500;color:var(--gray-800);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-cat-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.budget-progress-bg{height:8px;border-radius:4px;background:var(--gray-100);overflow:hidden}.budget-progress-fill{height:100%;border-radius:4px;transition:width .4s ease}.budget-row-bar{min-width:0}.budget-row-amounts{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);white-space:nowrap}.budget-sep{color:var(--gray-300)}.budget-pct{font-weight:600;font-size:11px;min-width:32px;text-align:right}.budget-row-actions{display:flex;gap:4px}.budget-empty{font-size:var(--fs-sm);color:var(--gray-400);text-align:center;padding:20px 0}.budget-summary-line{margin-top:14px;padding-top:12px;border-top:1px solid var(--gray-100);font-size:var(--fs-sm);color:var(--gray-500)}.budget-summary-over{color:var(--danger);font-weight:500}.budget-add-card{margin-bottom:20px}.budget-add-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.budget-cat-select{flex:1 1 180px;padding:8px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);color:var(--gray-700);background:var(--gray-50);cursor:pointer}.budget-limit-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}.budget-limit-input{width:120px;padding:8px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:var(--fs-sm);color:var(--gray-700);background:var(--gray-50)}.budget-currency-label{font-size:var(--fs-sm);font-weight:500;color:var(--gray-500)}.budget-inline-input{width:90px;padding:4px 8px;border:1px solid var(--primary-300);border-radius:var(--radius-sm);font-size:var(--fs-sm)}.budget-suggestions-card{margin-bottom:20px}.budget-suggestion-row{display:flex;align-items:center;gap:14px;padding:8px 0;border-top:1px solid var(--gray-100)}.budget-suggestion-avg{flex:1;font-size:var(--fs-sm);color:var(--gray-600)}.budget-dash-rows{display:flex;flex-direction:column;gap:10px}.budget-dash-row{display:grid;grid-template-columns:140px 1fr auto;align-items:center;gap:12px;cursor:pointer;border-radius:var(--radius-sm);padding:4px 6px;margin:0 -6px;transition:background var(--transition-fast)}.budget-dash-row:hover{background:var(--gray-50)}.budget-dash-name{font-size:var(--fs-sm);font-weight:500;color:var(--gray-700);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-dash-bar{min-width:0}.budget-dash-right{display:flex;align-items:center;gap:10px;white-space:nowrap}.budget-dash-amounts{font-size:var(--fs-sm);font-weight:500}.budget-dash-pct{font-size:11px;font-weight:600;min-width:36px;text-align:right}body.dark-mode .budget-progress-bg{background:var(--gray-700)}body.dark-mode .budget-dash-row:hover{background:var(--gray-200)}body.dark-mode .budget-cat-select,body.dark-mode .budget-limit-input{background:var(--gray-800);border-color:var(--gray-600);color:var(--gray-100)}@media(max-width:768px){.budget-row{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.budget-row-bar{grid-column:1 / -1}.budget-dash-row{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.budget-dash-bar{grid-column:1 / -1}}
