@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#111827cc;--bg-card-hover:#111827f2;--bg-input:#0f172a99;--bg-nav:#0a0e1aeb;--accent-primary:#06b6d4;--accent-primary-soft:#06b6d426;--accent-secondary:#8b5cf6;--accent-secondary-soft:#8b5cf626;--accent-gradient:linear-gradient(135deg, #06b6d4, #8b5cf6);--accent-gradient-warm:linear-gradient(135deg, #f59e0b, #ef4444);--success:#10b981;--success-soft:#10b98126;--danger:#ef4444;--danger-soft:#ef444426;--warning:#f59e0b;--warning-soft:#f59e0b26;--info:#3b82f6;--info-soft:#3b82f626;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#06b6d4;--border-color:#94a3b81a;--border-color-hover:#94a3b840;--border-accent:#06b6d44d;--glass-bg:#0f172a99;--glass-border:#94a3b814;--glass-blur:16px;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow-cyan:0 0 20px #06b6d426;--shadow-glow-purple:0 0 20px #8b5cf626;--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--nav-height-mobile:64px;--nav-width-desktop:240px;--content-max-width:1200px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-size:16px}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-weight:400;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 25% 25%,#06b6d408 0%,#0000 50%),radial-gradient(circle at 75% 75%,#8b5cf608 0%,#0000 50%);position:fixed;inset:0}#root{z-index:1;min-height:100dvh;position:relative}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:2rem;font-weight:700}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{color:var(--text-secondary)}a{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-secondary)}small{color:var(--text-muted);font-size:.8rem}.mono{font-family:var(--font-mono)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.glass-card:hover{border-color:var(--border-color-hover)}.glass-card.glow-cyan{box-shadow:var(--shadow-glow-cyan);border-color:var(--border-accent)}.glass-card.glow-purple{box-shadow:var(--shadow-glow-purple);border-color:#8b5cf64d}.stat-card{gap:var(--space-xs);flex-direction:column;display:flex}.stat-card .stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.75rem;font-weight:500}.stat-card .stat-value{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.stat-card .stat-value.positive{background:linear-gradient(135deg,#10b981,#06b6d4);-webkit-background-clip:text;background-clip:text}.stat-card .stat-value.negative{background:linear-gradient(135deg,#ef4444,#f59e0b);-webkit-background-clip:text;background-clip:text}.stat-card .stat-sub{color:var(--text-secondary);font-size:.8rem}input,select,textarea{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);width:100%;padding:.5rem .75rem;font-size:.9rem}input:focus,select:focus,textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft);outline:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}input[type=number]{font-family:var(--font-mono)}label{color:var(--text-secondary);margin-block-end:var(--space-xs);font-size:.8rem;font-weight:500;display:block}.field-group{gap:var(--space-xs);flex-direction:column;display:flex}.inline-editable{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);border:1px solid #0000;min-width:60px;padding:2px 6px}.inline-editable:hover{background:var(--bg-input);border-color:var(--border-color)}.inline-editable:focus{background:var(--bg-input);border-color:var(--accent-primary);outline:none}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font-body);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;min-height:40px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-gradient);color:#fff;border:none}.btn-primary:hover{box-shadow:var(--shadow-glow-cyan);filter:brightness(1.1)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background:0 0}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:.375rem .75rem}.btn-ghost:hover{color:var(--text-primary);background:var(--accent-primary-soft)}.btn-danger{background:var(--danger-soft);color:var(--danger);border:1px solid #ef444433}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{min-height:32px;padding:.3rem .75rem;font-size:.78rem}.btn-icon{min-height:unset;border-radius:var(--radius-sm);padding:.5rem}.table-wrap{-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);scrollbar-gutter:stable;overflow-x:auto}table{border-collapse:separate;border-spacing:0;width:100%;font-size:.85rem}thead th{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);z-index:1;white-space:nowrap;padding:.75rem 1rem;font-size:.7rem;font-weight:600;position:sticky;top:0}tbody td{border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle;padding:.625rem 1rem}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:#06b6d40a}tbody tr:last-child td{border-bottom:none}.td-number{font-family:var(--font-mono);text-align:right;font-size:.82rem}thead th.td-number{text-align:right}tfoot td{border-top:2px solid var(--border-color);color:var(--text-primary);padding:.75rem 1rem;font-weight:600}.progress-bar{border-radius:var(--radius-full);background:#94a3b81a;width:100%;height:8px;overflow:hidden}.progress-bar .progress-fill{border-radius:var(--radius-full);background:var(--accent-gradient);height:100%;transition:width var(--transition-slow)}.progress-bar .progress-fill.success{background:var(--success)}.progress-bar .progress-fill.warning{background:var(--warning)}.progress-bar .progress-fill.danger{background:var(--danger)}.badge{border-radius:var(--radius-full);letter-spacing:.03em;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-soft);color:var(--success)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-warning{background:var(--warning-soft);color:var(--warning)}.badge-info{background:var(--info-soft);color:var(--info)}.badge-accent{background:var(--accent-primary-soft);color:var(--accent-primary)}.tabs{border-bottom:1px solid var(--border-color);scrollbar-width:none;gap:2px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{font-family:var(--font-heading);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.625rem 1.25rem;font-size:.82rem;font-weight:500}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.quick-notes{border-top:1px solid var(--border-color);margin-block-start:var(--space-xl)}.quick-notes-toggle{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) 0;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:.8rem;font-weight:500;display:flex}.quick-notes-toggle:hover{color:var(--text-secondary)}.quick-notes-toggle .chevron{transition:transform var(--transition-fast);font-size:.7rem}.quick-notes-toggle .chevron.open{transform:rotate(90deg)}.quick-notes-content{padding-block-end:var(--space-lg)}.quick-notes-content textarea{resize:vertical;min-height:80px;font-size:.85rem;line-height:1.5}.app-layout{min-height:100dvh;display:flex}.sidebar{width:var(--nav-width-desktop);background:var(--bg-nav);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);height:100dvh;padding:var(--space-lg) 0;z-index:100;overscroll-behavior:contain;flex-direction:column;display:none;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{padding:0 var(--space-lg);margin-block-end:var(--space-2xl)}.sidebar-logo h2{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.sidebar-logo small{margin-block-start:2px;display:block}.sidebar-nav{padding:0 var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{align-items:center;gap:var(--space-md);padding:.625rem var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-size:.85rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-primary);background:#94a3b80f}.nav-item.active{color:var(--accent-primary);background:var(--accent-primary-soft)}.nav-item .nav-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.15rem}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-color);margin-top:auto}.sidebar-user{align-items:center;gap:var(--space-sm);display:flex}.sidebar-user img{border-radius:var(--radius-full);border:2px solid var(--border-color);width:32px;height:32px}.sidebar-user .user-name{color:var(--text-primary);font-size:.82rem;font-weight:500}.sidebar-user .user-email{color:var(--text-muted);font-size:.7rem}.bottom-nav{height:var(--nav-height-mobile);background:var(--bg-nav);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);z-index:100;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:48px;min-height:48px;padding:6px 12px;font-size:.65rem;font-weight:500;text-decoration:none;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--accent-primary)}.bottom-nav-item .nav-icon{font-size:1.25rem}.main-content{padding:var(--space-lg);max-width:var(--content-max-width);flex:1;width:100%;margin-inline:auto;padding-block-end:calc(var(--nav-height-mobile) + var(--space-xl))}.page-header{margin-block-end:var(--space-xl)}.page-header h1{margin-block-end:var(--space-xs);font-size:1.5rem}.page-header p{color:var(--text-muted);font-size:.85rem}.grid-2,.grid-3{gap:var(--space-md);grid-template-columns:1fr;display:grid}.grid-4{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.section{margin-block-end:var(--space-xl)}.section-title{justify-content:space-between;align-items:center;gap:var(--space-sm);margin-block-end:var(--space-md);font-size:.95rem;font-weight:600;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-lg);animation:fadeIn var(--transition-fast);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:480px;max-height:80dvh;animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-block-end:var(--space-lg);display:flex}.modal-header h3{font-size:1.1rem}.modal-actions{gap:var(--space-sm);justify-content:flex-end;margin-block-start:var(--space-lg);display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #06b6d433}50%{box-shadow:0 0 20px #06b6d466}}.animate-in{animation:slideUp var(--transition-base)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#94a3b826}::-webkit-scrollbar-thumb:hover{background:#94a3b84d}*{scrollbar-width:thin;scrollbar-color:#94a3b826 transparent}.auth-screen{min-height:100dvh;padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.auth-card{text-align:center;width:100%;max-width:380px}.auth-logo{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-block-end:var(--space-sm);font-size:2.5rem;font-weight:800}.auth-subtitle{color:var(--text-muted);margin-block-end:var(--space-2xl);font-size:.9rem}.auth-btn-google{justify-content:center;align-items:center;gap:var(--space-md);width:100%;padding:.875rem var(--space-xl);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;min-height:48px;font-size:.95rem;font-weight:500;display:inline-flex}.auth-btn-google:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow-cyan);background:#ffffff1a}.auth-btn-google svg{width:20px;height:20px}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-muted)}.empty-state .empty-icon{opacity:.4;margin-block-end:var(--space-md);font-size:2.5rem}.empty-state p{margin-block-end:var(--space-lg);font-size:.9rem}@media (width>=768px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.sidebar{display:flex}.bottom-nav{display:none}.main-content{padding:var(--space-xl) var(--space-2xl);margin-inline-start:var(--nav-width-desktop);padding-block-end:var(--space-2xl)}.page-header h1{font-size:2rem}.modal{max-width:560px}}@media (width>=1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-auto{margin-block-start:auto}.ml-auto{margin-inline-start:auto}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.dashboard-stats{gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-block-end:var(--space-xl);display:grid}.dashboard-stats .stat-card .stat-value{font-size:1.5rem}.donut-section{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.donut-container{width:220px;height:220px;position:relative}.donut-container svg{transform:rotate(-90deg)}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-center .donut-total-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.donut-center .donut-total-value{font-family:var(--font-heading);color:var(--text-primary);font-size:1.2rem;font-weight:700}.donut-legend{gap:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.legend-item{align-items:center;gap:var(--space-xs);color:var(--text-secondary);font-size:.8rem;display:flex}.legend-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.milestone-item{gap:var(--space-xs);padding:var(--space-md) 0;border-bottom:1px solid var(--border-color);flex-direction:column;display:flex}.milestone-item:last-child{border-bottom:none}.milestone-header{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.milestone-label{font-family:var(--font-heading);font-size:.95rem;font-weight:600}.milestone-meta{gap:var(--space-md);color:var(--text-muted);font-size:.75rem;display:flex}.milestone-numbers{color:var(--text-secondary);justify-content:space-between;font-size:.8rem;display:flex}.fx-bar{gap:var(--space-lg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);background:#06b6d40a;flex-wrap:wrap;align-items:center;margin-block-end:var(--space-xl);font-size:.78rem;display:flex}.fx-bar .fx-pair{font-family:var(--font-mono);color:var(--text-primary);font-weight:500}.fx-bar .fx-updated{color:var(--text-muted);margin-inline-start:auto;font-size:.7rem}.yoy-table input{width:100%;font-family:var(--font-mono);color:var(--text-primary);border-radius:var(--radius-sm);text-align:right;background:0 0;border:1px solid #0000;padding:4px 6px;font-size:.82rem}.yoy-table input:hover{border-color:var(--border-color)}.yoy-table input:focus{border-color:var(--accent-primary);background:var(--bg-input);outline:none}@media (width>=768px){.dashboard-stats{grid-template-columns:repeat(4,1fr)}.donut-section{flex-direction:row;justify-content:center}}.inv-stats{gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-block-end:var(--space-xl);display:grid}.inv-stats .stat-value{font-size:1.4rem}.sync-bar{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);background:#8b5cf60a;margin-block-end:var(--space-xl);font-size:.78rem;display:flex}.add-entry-row{gap:var(--space-sm);padding:var(--space-md);border-bottom:2px solid var(--border-color);background:#06b6d405;flex-wrap:wrap;display:flex}.add-entry-row input,.add-entry-row select{flex:1;min-width:80px}.source-badge{padding:1px 6px;font-size:.65rem}@media (width>=768px){.inv-stats{grid-template-columns:repeat(4,1fr)}}.budget-income{gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-block-end:var(--space-xl);display:grid}.budget-income .stat-value{font-size:1.3rem}.collapsible-header{width:100%;padding:var(--space-md);color:var(--text-primary);font-family:var(--font-heading);cursor:pointer;border:none;border-bottom:1px solid var(--border-color);background:0 0;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600;display:flex}.collapsible-header .chevron{transition:transform var(--transition-fast);color:var(--text-muted);font-size:.7rem}.collapsible-header .chevron.open{transform:rotate(90deg)}.ef-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.ef-grid .ef-item{flex-direction:column;gap:2px;display:flex}.ef-grid .ef-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.ef-grid .ef-value{font-family:var(--font-heading);color:var(--text-primary);font-size:1.1rem;font-weight:600}.bonus-alloc{gap:var(--space-sm);flex-direction:column;display:flex}.bonus-row{padding:var(--space-xs) 0;justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.bonus-row.remaining{border-top:1px solid var(--border-color);padding-top:var(--space-sm);color:var(--accent-primary);font-weight:600}@media (width>=768px){.budget-income{grid-template-columns:repeat(4,1fr)}.ef-grid{grid-template-columns:repeat(3,1fr)}}.tax-summary-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-block-end:var(--space-xl);display:grid}.tax-summary-grid .stat-value{font-size:1.3rem}.tax-month-input{text-align:right;width:90px;color:var(--text-primary);font-family:var(--font-mono);border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;padding:4px 6px;font-size:.82rem}.tax-month-input:hover{border-color:var(--border-color)}.tax-month-input:focus{border-color:var(--accent-primary);background:var(--bg-input);outline:none}.bracket-current{background:var(--accent-primary-soft)!important}@media (width>=768px){.tax-summary-grid{grid-template-columns:repeat(3,1fr)}}.cc-month-nav{justify-content:center;align-items:center;gap:var(--space-lg);margin-block-end:var(--space-xl);display:flex}.cc-month-nav h2{text-align:center;min-width:180px}.cc-month-nav button{background:var(--glass-bg);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-full);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1rem;display:flex}.cc-month-nav button:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.cc-stats{gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-block-end:var(--space-xl);display:grid}.cc-stats .stat-value{font-size:1.3rem}.txn-add-form{gap:var(--space-sm);padding:var(--space-md);border-bottom:2px solid var(--border-color);background:#06b6d405;flex-wrap:wrap;align-items:flex-end;display:flex}.txn-add-form .field-group{flex:1;min-width:80px}.txn-add-form .field-group label{margin-block-end:2px}.txn-add-form input,.txn-add-form select{padding:.375rem .5rem;font-size:.82rem}.day-group-header{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);background:#94a3b80a;justify-content:space-between;padding:.5rem 1rem;font-size:.75rem;font-weight:600;display:flex}.day-group-header .day-total{font-family:var(--font-mono);color:var(--text-secondary)}.day-weekend{color:var(--accent-secondary)}.day-friday{color:var(--warning)}.template-section{margin-block-end:var(--space-xl)}.template-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.template-item{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#94a3b80a;font-size:.82rem;display:flex}.template-item .template-cat{color:var(--text-muted);font-size:.65rem}.template-item input{text-align:right;background:0 0;border:1px solid #0000;width:60px;padding:2px 6px;font-size:.82rem}.template-item input:focus{border-color:var(--accent-primary);background:var(--bg-input)}.txn-inline{color:var(--text-primary);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition-fast);background:0 0;border:1px solid #0000;padding:2px 4px;font-size:.82rem}.txn-inline:hover{border-color:var(--border-color)}.txn-inline:focus{border-color:var(--accent-primary);background:var(--bg-input);outline:none}.txn-inline.mono{font-family:var(--font-mono);text-align:right}.txn-delete{opacity:0;transition:opacity var(--transition-fast);color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:2px;font-size:.7rem}tbody tr:hover .txn-delete{opacity:1}.txn-delete:hover{color:var(--danger)}@media (width>=768px){.cc-stats{grid-template-columns:repeat(4,1fr)}}.trip-grid{gap:var(--space-md);grid-template-columns:1fr;display:grid}.trip-card{cursor:pointer;transition:border-color var(--transition-base), transform var(--transition-fast)}.trip-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.trip-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);margin-block-end:var(--space-sm);display:flex}.trip-card-header h3{font-size:1.1rem}.trip-card-meta{gap:var(--space-md);color:var(--text-secondary);flex-wrap:wrap;font-size:.8rem;display:flex}.trip-detail-header{align-items:center;gap:var(--space-md);flex-wrap:wrap;margin-block-end:var(--space-xl);display:flex}.trip-detail-header h1{flex:1}.back-btn{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:.375rem .75rem;font-size:.82rem}.back-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.day-card{padding:var(--space-md);border-bottom:1px solid var(--border-color)}.day-card:last-child{border-bottom:none}.day-card-header{align-items:center;gap:var(--space-sm);margin-block-end:var(--space-sm);font-size:.85rem;display:flex}.day-card-date{color:var(--accent-primary);min-width:90px;font-weight:600}.day-card-label{color:var(--text-muted)}.day-card textarea{resize:vertical;min-height:60px;font-size:.85rem}.flight-card{gap:var(--space-sm);flex-direction:column;display:flex}.flight-row{gap:var(--space-md);flex-wrap:wrap;font-size:.85rem;display:flex}.flight-row strong{color:var(--text-primary)}.expense-summary-bar{border-radius:var(--radius-sm);height:24px;gap:2px;margin-block-end:var(--space-md);display:flex;overflow:hidden}.expense-summary-bar .bar-seg{transition:width var(--transition-base);min-width:2px}.cat-legend{gap:var(--space-sm);flex-wrap:wrap;margin-block-end:var(--space-lg);font-size:.72rem;display:flex}@media (width>=768px){.trip-grid{grid-template-columns:repeat(2,1fr)}}.scratch-layout{gap:var(--space-lg);min-height:400px;display:flex}.scratch-sidebar{flex-shrink:0;width:200px;display:none}.scratch-list{flex-direction:column;gap:2px;display:flex}.scratch-list-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;width:100%;padding:.5rem .75rem;font-size:.82rem;display:flex}.scratch-list-item:hover{color:var(--text-primary);background:#94a3b80f}.scratch-list-item.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.scratch-list-item.archived{opacity:.5}.scratch-editor{flex:1;min-width:0}.scratch-name-input{font-family:var(--font-heading);color:var(--text-primary);width:100%;background:0 0;border:none;margin-block-end:var(--space-lg);padding:0;font-size:1.25rem;font-weight:600}.scratch-name-input:focus{border-bottom:2px solid var(--accent-primary);outline:none}.block{padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast);margin-block-end:var(--space-md);position:relative}.block:hover{border-color:var(--border-color-hover)}.block-toolbar{opacity:0;transition:opacity var(--transition-fast);gap:4px;display:flex;position:absolute;top:6px;right:6px}.block:hover .block-toolbar{opacity:1}.block-toolbar button{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);padding:2px 6px;font-size:.7rem}.block-toolbar button:hover{color:var(--danger);border-color:var(--danger)}.block-type-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-block-end:var(--space-xs);font-size:.65rem}.block textarea{resize:vertical;min-height:50px;font-size:.85rem}.block-table input{color:var(--text-primary);border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;width:100%;padding:4px 6px;font-size:.82rem}.block-table input:focus{border-color:var(--accent-primary);background:var(--bg-input);outline:none}.block-table th input{color:var(--accent-primary);font-weight:600}.calc-block{align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.calc-label{font-size:.9rem;font-weight:500}.calc-formula{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-input);border-radius:var(--radius-sm);flex:1;padding:4px 8px;font-size:.82rem}.calc-result{font-family:var(--font-heading);color:var(--accent-primary);font-size:1.2rem;font-weight:700}.check-item{align-items:center;gap:var(--space-sm);padding:4px 0;display:flex}.check-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}.check-item.checked span{color:var(--text-muted);text-decoration:line-through}.check-item span{flex:1;font-size:.85rem}.add-block-menu{gap:var(--space-sm);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-wrap:wrap;display:flex}.add-block-menu button{background:var(--glass-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.375rem .75rem;font-size:.78rem}.add-block-menu button:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.scratch-mobile-select{margin-block-end:var(--space-lg)}@media (width>=768px){.scratch-sidebar{display:block}.scratch-mobile-select{display:none}}
