@import"https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,300;0,400;0,600;0,700;1,400&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";:root{--stone-50: #faf8f6;--stone-100: #f3f0ec;--stone-200: #e6e1db;--stone-300: #d1c9bf;--stone-400: #a89e91;--stone-500: #7a7067;--stone-600: #5c544b;--stone-700: #3e3832;--stone-800: #2a2521;--stone-900: #1a1714;--terracotta-400: #d4845a;--terracotta-500: #c47245;--terracotta-600: #b05e33;--terracotta-700: #8a4828;--sage-400: #7da87b;--sage-500: #5c8a5a;--sage-600: #4a7248;--amber-400: #e8b84b;--amber-500: #d4a230;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--bg: var(--stone-50);--bg-elevated:#ffffff;--text: var(--stone-800);--text-muted: var(--stone-500);--text-faint: var(--stone-400);--border: var(--stone-200);--border-strong: var(--stone-300);--accent: var(--terracotta-500);--accent-hover: var(--terracotta-600);--accent-soft: rgba(196, 114, 69, .08);--success: var(--sage-500);--danger: #c0392b;--danger-soft: rgba(192, 57, 43, .08);--font-serif: "Spectral", Georgia, "Times New Roman", serif;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(26, 23, 20, .04), 0 1px 3px rgba(26, 23, 20, .06);--shadow-md: 0 4px 6px rgba(26, 23, 20, .04), 0 2px 4px rgba(26, 23, 20, .06);--shadow-lg: 0 10px 25px rgba(26, 23, 20, .06), 0 4px 10px rgba(26, 23, 20, .04);--shadow-xl: 0 20px 40px rgba(26, 23, 20, .08), 0 8px 16px rgba(26, 23, 20, .04);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E")}.app-shell{display:flex;flex-direction:column;min-height:100vh}.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:#faf8f6d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-brand{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none;color:var(--text)}.nav-brand-icon{width:32px;height:32px;background:var(--terracotta-500);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-serif);font-weight:700;font-size:1.1rem}.nav-brand-name{font-family:var(--font-serif);font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.nav-links{display:flex;align-items:center;gap:var(--space-xs);list-style:none}.nav-link{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;color:var(--text-muted);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out);text-decoration:none}.nav-link:hover{color:var(--text);background:var(--accent-soft)}.nav-link.active{color:var(--accent);background:var(--accent-soft)}.nav-link.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--accent);border-radius:2px}.page{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--space-2xl) var(--space-xl)}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:2.25rem;font-weight:700}h2{font-size:1.5rem;margin-bottom:var(--space-lg)}h3{font-size:1.125rem;font-weight:600}.eyebrow{font-family:var(--font-sans);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-xs)}.lede{font-size:1.125rem;color:var(--text-muted);max-width:560px;line-height:1.7}.support-copy{font-size:.875rem;color:var(--text-muted);line-height:1.6}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:box-shadow .3s var(--ease-out),transform .3s var(--ease-out)}.card:hover{box-shadow:var(--shadow-md)}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-2xl)}.summary-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-xl);box-shadow:var(--shadow-sm);transition:box-shadow .3s var(--ease-out),transform .2s var(--ease-out)}.summary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-card-label{font-size:.8rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.summary-card-value{font-family:var(--font-serif);font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.summary-card-value.negative{color:var(--danger)}.summary-card-value.positive{color:var(--success)}.summary-card-sub{font-size:.8rem;color:var(--text-faint);margin-top:var(--space-xs)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.category-list-compact{list-style:none}.category-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--stone-100)}.category-item:last-child{border-bottom:none}.category-item:hover{opacity:.85}.category-item-active{background:var(--stone-50);border-radius:var(--radius);padding:var(--space-sm) var(--space-md);box-shadow:inset 0 0 0 1px var(--stone-200)}.category-item-active .category-name{font-weight:700}.category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-info{flex:1;min-width:0}.category-name{font-size:.875rem;font-weight:500}.category-bar-track{height:4px;background:var(--stone-100);border-radius:4px;margin-top:var(--space-xs);overflow:hidden}.category-bar-fill{height:100%;border-radius:4px;transition:width .6s var(--ease-out)}.category-amount{font-family:var(--font-serif);font-size:.875rem;font-weight:600;white-space:nowrap}.table-wrap{overflow-x:auto;border-radius:var(--radius-md)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{text-align:left;font-family:var(--font-sans);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);padding:var(--space-sm) var(--space-md);border-bottom:2px solid var(--border);background:var(--stone-50);white-space:nowrap}.data-table td{padding:var(--space-md);border-bottom:1px solid var(--stone-100);vertical-align:middle}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover{background:var(--stone-50)}.data-table .amount{font-family:var(--font-serif);font-weight:600;text-align:right;font-variant-numeric:tabular-nums}.data-table .amount.expense{color:var(--danger)}.data-table .amount.income{color:var(--success)}.category-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;white-space:nowrap}.category-badge .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.import-hero{text-align:center;max-width:600px;margin:0 auto var(--space-2xl)}.drop-zone{border:2px dashed var(--stone-300);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);text-align:center;background:var(--bg-elevated);transition:all .3s var(--ease-out);cursor:pointer;position:relative}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--accent-soft)}.drop-zone.drag-over{transform:scale(1.01)}.drop-zone-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.6}.drop-zone-text{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;margin-bottom:var(--space-xs)}.drop-zone-sub{font-size:.875rem;color:var(--text-muted)}.drop-zone-sub span{color:var(--accent);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-sans);font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--terracotta-500);color:#fff;box-shadow:0 1px 3px #c472454d}.btn-primary:hover:not(:disabled){background:var(--terracotta-600);box-shadow:0 4px 12px #c472454d;transform:translateY(-1px)}.btn-secondary{background:var(--stone-100);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--stone-200)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--stone-100);color:var(--text)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.75rem}.flow-steps{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.flow-step{display:flex;align-items:center;gap:var(--space-sm)}.flow-step-num{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;background:var(--stone-100);color:var(--text-faint);transition:all .3s var(--ease-out)}.flow-step.active .flow-step-num,.flow-step.complete .flow-step-num{background:var(--terracotta-500);color:#fff}.flow-step.active .step-label,.flow-step.complete .step-label{color:var(--text);font-weight:600}.flow-step-label{font-size:.8rem;color:var(--text-faint)}.flow-connector{flex:1;height:2px;background:var(--stone-200);min-width:20px}.flow-connector.complete{background:var(--terracotta-500)}.mapping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.mapping-field{display:flex;flex-direction:column;gap:var(--space-xs)}.mapping-field label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.mapping-field select{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;color:var(--text);background:var(--bg-elevated);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.mapping-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.status{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;margin-bottom:var(--space-md)}.status.success{background:#5c8a5a1a;color:var(--sage-600)}.status.error{background:var(--danger-soft);color:var(--danger)}.filter-bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:var(--space-sm) var(--space-lg);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;background:var(--bg-elevated);color:var(--text);transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-input::placeholder{color:var(--text-faint)}.filter-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;color:var(--text);background:var(--bg-elevated);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.category-edit{display:flex;align-items:center;gap:var(--space-xs)}.category-edit select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.75rem;background:var(--bg-elevated);cursor:pointer}.category-edit select:focus{outline:none;border-color:var(--accent)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);color:var(--text-faint)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.4}.empty-state-text{font-family:var(--font-serif);font-size:1.125rem;margin-bottom:var(--space-sm);color:var(--text-muted)}.empty-state-sub{font-size:.875rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.section-header h2{margin-bottom:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-in:nth-child(1){animation-delay:.02s}.animate-in:nth-child(2){animation-delay:.06s}.animate-in:nth-child(3){animation-delay:.1s}.animate-in:nth-child(4){animation-delay:.14s}.animate-in:nth-child(5){animation-delay:.18s}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr 1fr}.two-col{grid-template-columns:1fr}.nav{padding:var(--space-sm) var(--space-md)}.nav-brand-name{font-size:1.1rem}.nav-link{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.page{padding:var(--space-xl) var(--space-md)}h1{font-size:1.75rem}}@media(max-width:600px){.dashboard-grid,.mapping-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}.search-input{min-width:auto}.flow-steps{flex-wrap:wrap}.flow-connector{display:none}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--stone-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--stone-400)}input[type=file]{display:none}.chip{display:inline-flex;align-items:center;padding:2px var(--space-sm);border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.chip.confidence-high{background:#5c8a5a1f;color:var(--sage-600)}.chip.confidence-medium{background:#e8b84b1f;color:var(--amber-500)}.chip.confidence-low{background:var(--danger-soft);color:var(--danger)}.chip.confidence-ambiguous{background:var(--accent-soft);color:var(--accent)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background:#1a171480;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal-content{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:600px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-header h3{font-size:1.25rem}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--stone-100);border-radius:var(--radius-full);cursor:pointer;font-size:1.2rem;color:var(--text-muted);transition:all .2s ease}.modal-close:hover{background:var(--stone-200);color:var(--text)}.cat-manager-list{list-style:none}.cat-manager-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--stone-100)}.cat-manager-item:last-child{border-bottom:none}.cat-manager-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.cat-manager-name{flex:1;font-weight:500;font-size:.875rem}.category-row-info{flex:1;display:flex;align-items:center;gap:var(--space-xs)}.category-row-name{font-weight:500;font-size:.875rem}.category-seed-badge{font-size:.65rem;color:var(--text-faint);background:var(--stone-100);padding:1px 6px;border-radius:var(--radius-full)}.category-row-count{font-size:.75rem;color:var(--text-muted);margin-right:var(--space-sm)}.category-row-actions,.cat-manager-actions{display:flex;gap:4px}.cat-manager-actions .btn-xs{padding:2px 6px;font-size:.7rem}.cat-manager-new{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) 0;border-top:1px solid var(--stone-200);margin-top:var(--space-sm)}.cat-manager-name-input,.cat-manager-color-input{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.8rem}.cat-manager-name-input{flex:1;min-width:120px}.cat-manager-color-input{width:36px;height:32px;padding:2px;cursor:pointer}.category-picker{padding:2px 4px;font-size:.75rem;border:1px solid var(--stone-200);border-radius:var(--radius);background:#fff;cursor:pointer;min-width:100px}.import-stats{display:flex;gap:var(--space-lg);flex-wrap:wrap}.import-stat{flex:1;min-width:80px;text-align:center;padding:var(--space-md);background:var(--stone-50);border-radius:var(--radius-md)}.import-stat-value.negative{color:var(--danger)}.import-stat-value.positive{color:var(--success)}.status-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:300;animation:fadeIn .3s var(--ease-out)}.status-toast-content{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-lg)}.status-toast-text{font-size:.875rem;font-weight:500}.status-toast-close{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--text-muted);padding:0 4px;line-height:1}.status-toast-close:hover{color:var(--text)}.status-banner{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:300;background:var(--danger-soft);color:var(--danger);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;max-width:500px;text-align:center}.success-banner{background:#5c8a5a1a;color:var(--sage-600)}.error-banner{background:var(--danger-soft);color:var(--danger)}.category-changed{background:#c472450d}.category-changed td:first-child:before{content:"●";color:var(--accent);margin-right:8px;font-size:.6rem}.error-banner{max-width:500px}.btn-xs{padding:2px 6px;font-size:.7rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;background:transparent;color:var(--text-muted);transition:all .15s ease}.btn-xs:hover{background:var(--stone-100);color:var(--text)}.form-input{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.8rem;color:var(--text);background:var(--bg-elevated)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.section-header .btn-sm{padding:4px 8px;font-size:.7rem}.modal-content{width:95%;padding:var(--space-lg)}.modal-backdrop{position:fixed;inset:0;background:#1a171480;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal-backdrop .modal{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:540px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-backdrop .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-backdrop .modal-header h2{font-size:1.25rem;margin:0}.modal-backdrop .modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--stone-100);border-radius:var(--radius-full);cursor:pointer;font-size:1.2rem;color:var(--text-muted);transition:all .2s ease}.modal-backdrop .modal-close:hover{background:var(--stone-200);color:var(--text)}.category-form{margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--stone-100)}.category-form h3{font-size:.95rem;margin:0 0 var(--space-sm) 0;font-weight:600}.form-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-sm)}.form-row .form-input{flex:1}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-sm)}.color-picker{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:var(--space-sm)}.color-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s ease}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--bg-elevated),0 0 0 4px var(--text-muted)}.category-list{list-style:none;padding:0;margin:0}.category-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;border-bottom:1px solid var(--stone-50)}.category-row:last-child{border-bottom:none}.category-swatch{width:16px;height:16px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 0 0 1px #00000014}.delete-confirm{margin-top:var(--space-md);padding:var(--space-md);background:var(--danger-soft);border-radius:var(--radius);font-size:.85rem;color:var(--danger)}.delete-confirm p{margin:0 0 var(--space-sm) 0}.categorization-cta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);background:linear-gradient(135deg,var(--amber-400),var(--terracotta-400));color:#fff;border:none;padding:var(--space-lg) var(--space-xl)}.categorization-cta:hover{box-shadow:var(--shadow-lg)}.categorization-cta-content{display:flex;align-items:center;gap:var(--space-md);flex:1;min-width:0}.categorization-cta-icon{font-size:2rem;flex-shrink:0}.categorization-cta-title{font-family:var(--font-serif);font-size:1.125rem;font-weight:700;margin-bottom:2px}.categorization-cta-sub{font-size:.875rem;opacity:.85}.categorization-cta .btn{background:#fff;color:var(--terracotta-600);border:none;font-weight:600;flex-shrink:0}.categorization-cta .btn:hover{background:var(--stone-50)}.cluster-section .section-header{margin-bottom:var(--space-md)}.cluster-card{border:1px solid var(--stone-200);border-radius:var(--radius-md);padding:var(--space-md);background:var(--stone-50);margin-bottom:var(--space-sm)}.cluster-card:last-child{margin-bottom:0}.cluster-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);gap:var(--space-sm);flex-wrap:wrap}.cluster-card-info{display:flex;align-items:center;gap:var(--space-xs)}.cluster-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cluster-card-name{font-weight:600;font-size:.9rem}.cluster-card-count{font-size:.8rem;color:var(--text-muted)}.cluster-category-select{padding:4px 8px;border:1px solid var(--stone-300);border-radius:var(--radius-sm);font-size:.8rem;background:#fff;cursor:pointer}.cluster-card-txns{list-style:none;padding:0;margin:0}.cluster-txn-item{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:.85rem;border-bottom:1px solid var(--stone-100)}.cluster-txn-item:last-child{border-bottom:none}.cluster-txn-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.cluster-txn-amount{font-family:var(--font-serif);font-weight:600;font-size:.85rem;white-space:nowrap;margin-left:var(--space-md)}.cluster-txn-amount.expense{color:var(--danger)}.cluster-txn-amount.income{color:var(--success)}.uncat-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--stone-100);font-size:.875rem}.uncat-row:last-child{border-bottom:none}.uncat-desc{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uncat-amount.expense{color:var(--danger)}.uncat-amount.income{color:var(--success)}.uncat-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.uncat-select{padding:4px 8px;border:1px solid var(--stone-300);border-radius:var(--radius-sm);font-size:.8rem;background:#fff;cursor:pointer}.filter-bar,.inline-cat-form{padding:var(--space-md) var(--space-lg)}.inline-cat-form h4{font-size:.9rem;font-weight:600;margin:0 0 var(--space-sm);color:var(--text)}.inline-cat-form .form-input{padding:6px 10px;font-size:.85rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;transition:border-color .15s ease}.inline-cat-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}.category-badge-clickable{transition:background-color .15s ease,box-shadow .15s ease}.category-badge-clickable:hover{background-color:var(--stone-100);box-shadow:0 0 0 1px var(--stone-300)}.inline-category-popover-container{position:relative;z-index:1000;padding:var(--space-sm)}.category-popover{background:#fff;border:1px solid var(--stone-200);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-height:350px;display:flex;flex-direction:column;overflow:hidden;z-index:1000}.inline-category-popover-container .category-popover{position:relative;width:100%;max-width:400px}.category-popover-search{padding:var(--space-sm) var(--space-md);border:none;border-bottom:1px solid var(--stone-100);font-size:.85rem;outline:none;background:#fff}.category-popover-list{overflow-y:auto;max-height:300px;padding:var(--space-xs) 0}.category-popover-empty{padding:var(--space-md);text-align:center;color:var(--text-muted);font-size:.85rem}.category-popover-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);cursor:pointer;font-size:.85rem;transition:background-color .1s ease}.category-popover-item:hover{background-color:var(--stone-50)}.category-popover-item.active{background-color:var(--primary-soft)}.category-popover-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-popover-name{flex:1;color:var(--text)}.category-popover-parent{font-size:.75rem;color:var(--text-muted)}.category-popover-check{color:var(--primary);font-weight:700;font-size:.85rem}@media(max-width:480px){.category-popover{width:260px}}.donut-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-md)}.donut-card h3{margin:0 0 var(--space-md);font-size:1rem;font-weight:600;color:var(--text)}.donut-layout{display:flex;gap:var(--space-lg);align-items:center}.donut-visual{flex:1;position:relative;min-height:220px}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.donut-center-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.donut-center-value{font-size:1.25rem;font-weight:700;font-family:var(--font-serif);color:var(--text)}.donut-legend{flex:0 0 200px}.donut-legend-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:.85rem}.donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.doughnut-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.doughnut-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.doughnut-header h3{margin:0}.doughnut-time-toggle{display:flex;gap:var(--space-xs)}.time-btn{padding:4px 10px;font-size:.75rem;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-full);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s var(--ease-out)}.time-btn:hover{border-color:var(--accent);color:var(--accent)}.time-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.doughnut-layout{display:flex;gap:var(--space-xl);align-items:center}.doughnut-visual{flex:1;position:relative;min-height:260px;display:flex;align-items:center;justify-content:center}.doughnut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.doughnut-center-label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.doughnut-center-value{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;color:var(--text)}.doughnut-legend{flex:0 0 180px}.doughnut-legend-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;cursor:pointer;transition:opacity .15s ease}.doughnut-legend-item:hover{opacity:.8}.doughnut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.doughnut-legend-name{font-size:.8rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doughnut-legend-pct{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.8rem}.doughnut-legend-more{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--stone-200);font-size:.8rem;color:var(--text-muted)}.doughnut-tooltip{background:var(--bg-elevated);border:1px solid var(--stone-200);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-lg);pointer-events:none}.doughnut-tooltip-name{font-weight:600;color:var(--text);margin-bottom:2px}.doughnut-tooltip-value{color:var(--text);font-family:var(--font-serif);font-weight:500}.doughnut-tooltip-pct{color:var(--text-muted);font-size:.85rem}.doughnut-slice{transition:opacity .2s ease}.doughnut-slice:hover{opacity:.8}.quick-add-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:500;border:1px dashed var(--stone-300);border-radius:var(--radius-md);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s var(--ease-out)}.quick-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.quick-add-form{display:flex;gap:var(--space-xs);align-items:center;flex-wrap:wrap;padding:var(--space-md);margin-bottom:var(--space-lg);background:var(--stone-50);border-radius:var(--radius-md);border:1px solid var(--stone-200)}.quick-add-input{padding:4px 8px;font-size:.8rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;color:var(--text);outline:none;transition:border-color .15s ease}.quick-add-input:focus{border-color:var(--accent)}.quick-add-select{padding:4px 8px;font-size:.8rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;color:var(--text);outline:none;cursor:pointer}.quick-add-color{width:28px;height:28px;border:1px solid var(--stone-300);border-radius:var(--radius-sm);cursor:pointer;padding:0;background:none}.quick-add-color::-webkit-color-swatch-wrapper{padding:0}.quick-add-color::-webkit-color-swatch{border:none;border-radius:2px}.inline-category-popover-container{padding:var(--space-md);background:var(--stone-50);border-top:1px solid var(--stone-200)}.category-changed{background:#c472450a}.cluster-section{margin-bottom:var(--space-lg)}.cluster-card{margin-bottom:var(--space-md)}.cluster-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.cluster-card-info{display:flex;align-items:center;gap:var(--space-sm)}.cluster-card-dot{width:8px;height:8px;border-radius:50%}.cluster-card-name{font-size:.85rem;font-weight:600}.cluster-card-count{font-size:.75rem;color:var(--text-muted)}.cluster-card-actions{display:flex;align-items:center;gap:var(--space-xs)}.cluster-category-select{padding:3px 6px;font-size:.75rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;cursor:pointer}.cluster-card-txns{list-style:none;padding-left:var(--space-lg)}.cluster-txn-item{display:flex;justify-content:space-between;align-items:center;padding:2px 0;font-size:.8rem}.cluster-txn-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cluster-txn-amount{font-family:var(--font-serif);font-weight:600;white-space:nowrap;margin-left:var(--space-md)}.uncat-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--stone-100)}.uncat-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem}.uncat-amount{font-family:var(--font-serif);font-weight:600;white-space:nowrap}.uncat-actions{display:flex;align-items:center;gap:var(--space-xs)}.uncat-select{padding:3px 6px;font-size:.75rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;cursor:pointer}@media(max-width:768px){.doughnut-layout{flex-direction:column}.doughnut-legend{flex:none;width:100%}.doughnut-header,.cluster-card-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.uncat-row{flex-wrap:wrap}}.footer{text-align:center;padding:var(--space-lg);border-top:1px solid var(--border)}.category-badge-clickable:hover{background:var(--accent-soft)}.flow-steps{display:flex;align-items:center;gap:0;margin-bottom:var(--space-xl);flex-wrap:wrap}.flow-step{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;background:var(--stone-100);color:var(--text-muted)}.flow-step.complete{background:#5c8a5a1a;color:var(--success)}.flow-step.complete .flow-step-num{background:var(--success);color:#fff}.flow-step.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.flow-step.active .flow-step-num{background:var(--accent);color:#fff}.flow-step-num{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;background:var(--stone-300);color:#fff}.flow-connector{width:24px;height:2px;background:var(--stone-300);margin:0 var(--space-xs)}.flow-connector.complete{background:var(--success)}.import-stats{display:flex;gap:var(--space-xl);flex-wrap:wrap;margin-top:var(--space-lg)}.import-stat{text-align:center}.import-stat-value{font-family:var(--font-serif);font-size:1.5rem;font-weight:700}.import-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.mapping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md);margin-top:var(--space-md)}.mapping-field-label{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-bottom:4px}.mapping-field-select{width:100%;padding:6px 8px;font-size:.8rem;border:1px solid var(--stone-300);border-radius:var(--radius-sm);background:#fff;cursor:pointer}.status-toast{position:fixed;top:60px;right:var(--space-xl);z-index:200;animation:slideIn .3s var(--ease-out)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.status-toast-content{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.status-toast-text{font-size:.85rem;font-weight:500}.status-toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem;padding:0;line-height:1}.status-banner{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:200;padding:var(--space-sm) var(--space-xl);background:var(--danger);color:#fff;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;box-shadow:var(--shadow-lg)}.success-banner{padding:var(--space-sm) var(--space-xl);background:var(--success);color:#fff;border-radius:var(--radius-md);font-size:.85rem;text-align:center}.error-banner{padding:var(--space-sm) var(--space-xl);background:var(--danger-soft);color:var(--danger);border-radius:var(--radius-md);font-size:.85rem;text-align:center}.categorization-cta{background:linear-gradient(135deg,var(--accent-soft),transparent);border-color:var(--accent)}.categorization-cta-content{display:flex;align-items:center;gap:var(--space-md)}.categorization-cta-icon{font-size:1.5rem}.categorization-cta-title{font-weight:600;font-size:.95rem}.categorization-cta-sub{font-size:.8rem;color:var(--text-muted);margin-top:2px}.search-input{padding:6px 10px;font-size:.85rem;border:1px solid var(--stone-300);border-radius:var(--radius-md);background:#fff;color:var(--text);outline:none;transition:border-color .15s ease}.search-input:focus{border-color:var(--accent)}.filter-select{padding:6px 8px;font-size:.8rem;border:1px solid var(--stone-300);border-radius:var(--radius-md);background:#fff;color:var(--text);cursor:pointer;outline:none}.filter-select:focus{border-color:var(--accent)}.animate-in{animation:fadeInUp .4s var(--ease-out) both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.dashboard-grid,.two-col{grid-template-columns:1fr}.page{padding:var(--space-xl) var(--space-md)}.nav{padding:var(--space-sm) var(--space-md)}.nav-brand-name{display:none}.flow-steps{flex-direction:column;align-items:flex-start}.flow-connector{display:none}.import-stats{justify-content:space-between}.mapping-grid{grid-template-columns:1fr}.status-toast{right:var(--space-md);left:var(--space-md)}.status-toast-content{justify-content:space-between}}
