:root{--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #e2e8f0;--color-bg-glass: rgba(248, 250, 252, .9);--color-bg-overlay: rgba(15, 23, 42, .55);--color-accent-primary: #2563eb;--color-accent-hover: #3b82f6;--color-accent-light: #93c5fd;--color-accent-subtle: rgba(37, 99, 235, .06);--color-accent-gradient: #1e40af;--color-accent-gradient-hover: #2563eb;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #f8fafc;--color-success: #16a34a;--color-success-bg: rgba(22, 163, 74, .1);--color-warning: #d97706;--color-warning-bg: rgba(217, 119, 6, .1);--color-danger: #dc2626;--color-danger-bg: rgba(220, 38, 38, .1);--color-info: #2563eb;--color-purple: #7c3aed;--color-purple-bg: rgba(124, 58, 237, .1);--color-border: rgba(15, 23, 42, .08);--color-border-hover: rgba(15, 23, 42, .16);--color-border-focus: #2563eb;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .08);--shadow-md: 0 4px 12px rgba(15, 23, 42, .12);--shadow-lg: 0 8px 28px rgba(15, 23, 42, .14);--shadow-xl: 0 16px 48px rgba(15, 23, 42, .18);--shadow-glow: 0 0 20px rgba(37, 99, 235, .25);--spacing-xs: .25rem;--spacing-sm: .625rem;--spacing-md: 1.125rem;--spacing-lg: 1.75rem;--spacing-xl: 2.5rem;--spacing-2xl: 3.75rem;--radius-sm: .75rem;--radius-md: 1rem;--radius-lg: 1.5rem;--radius-xl: 2rem;--radius-full: 9999px;--font-sans: "Space Grotesk", system-ui, -apple-system, sans-serif;--font-mono: "Space Grotesk", system-ui, -apple-system, sans-serif;--font-code: "Space Mono", "Fira Code", monospace;--transition-fast: .15s cubic-bezier(.34, 1.56, .64, 1);--transition-default: .25s cubic-bezier(.34, 1.56, .64, 1);--transition-slow: .4s cubic-bezier(.34, 1.56, .64, 1)}*{margin:0;padding:0;box-sizing:border-box}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}html,body{height:100%;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;letter-spacing:-.02em;margin-bottom:var(--spacing-md)}h1{font-size:2.25rem;font-weight:700}h2{font-size:1.625rem}h3{font-size:1.25rem}h4{font-size:1.0625rem}p{margin-bottom:var(--spacing-md)}.glass{background:var(--color-bg-secondary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.glass-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:var(--radius-lg)}button{font-family:inherit;font-size:.875rem;letter-spacing:.025em;cursor:pointer;border:none;transition:var(--transition-default)}.btn{padding:.5rem 1.25rem;border-radius:var(--radius-full);font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:var(--transition-default);font-size:.875rem;letter-spacing:-.01em}.btn-primary{background:var(--color-accent-primary);color:#fff}.btn-primary:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}input,select,textarea{font-family:inherit;font-size:.95rem;padding:.75rem 1rem;background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid transparent;border-radius:var(--radius-md);transition:var(--transition-default);outline:none;width:100%}input:hover,select:hover,textarea:hover{border-color:var(--color-border-hover)}input:focus,select:focus,textarea:focus{background:var(--color-bg-secondary);border-color:var(--color-border-focus);box-shadow:0 0 0 2px var(--color-accent-subtle)}input::placeholder{color:var(--color-text-muted)}input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--color-accent-primary);border-radius:4px}.card{background:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--color-border);transition:var(--transition-default)}.card:hover{border-color:var(--color-border-hover)}.container{max-width:1400px;margin:0 auto;padding:var(--spacing-xl)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeInOpacity{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn var(--transition-slow) ease-out forwards}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:var(--radius-full);border:2px solid var(--color-bg-primary)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-purple{color:var(--color-purple)}.text-info{color:var(--color-info)}.text-sm{font-size:.875rem}.font-mono{font-family:var(--font-code)}.flex-center{display:flex;align-items:center;justify-content:center}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only:focus{position:static;width:auto;height:auto;padding:var(--spacing-sm) var(--spacing-md);margin:0;overflow:visible;clip:auto;white-space:normal;background:var(--color-accent-primary);color:#fff;z-index:9999}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);padding:2rem}.error-boundary-content{background:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:3rem;max-width:600px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);text-align:center}.error-icon{font-size:4rem;margin-bottom:1rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-boundary-content h1{color:var(--color-text-primary);font-size:2rem;margin-bottom:1rem;font-weight:700}.error-message{color:var(--color-text-secondary);font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.error-details{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin:2rem 0;text-align:left}.error-details summary{cursor:pointer;font-weight:600;color:var(--color-accent-primary);-webkit-user-select:none;user-select:none}.error-details summary:hover{color:var(--color-accent-hover)}.error-stack{margin-top:1rem;padding:1rem;background:var(--color-bg-secondary);border-radius:4px;overflow-x:auto;font-size:.85rem;color:var(--color-danger);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-actions .btn{padding:.75rem 2rem;font-size:1rem;border-radius:var(--radius-md);border:none;cursor:pointer;font-weight:600;transition:all .3s ease}.error-actions .btn-primary{background:var(--color-accent-primary);color:#fff}.error-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.error-actions .btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.error-actions .btn-secondary:hover{background:var(--color-border-hover)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:var(--color-bg-primary)}.login-split-layout{display:flex;min-height:100vh}.login-brand-panel{flex:0 0 420px;background:linear-gradient(160deg,#1e3a8a,#2563eb);display:flex;flex-direction:column;justify-content:center;padding:60px 48px;gap:40px}.login-brand-content{display:flex;flex-direction:column;gap:16px}.login-brand-logo{width:52px;height:52px;border-radius:9999px;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:#fff;font-family:var(--font-sans, "Space Grotesk", sans-serif)}.login-brand-headline{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.2;color:#fff;margin:0}.login-brand-sub{font-size:15px;color:#ffffffbf;margin:0}.login-brand-bars{display:flex;flex-direction:column;gap:6px}.login-bar{height:10px;border-radius:3px}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:40px 24px;min-width:0}.login-form-panel .login-container{min-height:auto;padding:0;background:transparent;width:100%}@media(max-width:900px){.login-brand-panel{display:none}.login-split-layout{display:block;min-height:100vh;background:#f8fafc}.login-form-panel{min-height:100vh}}.login-card{width:100%;max-width:420px;padding:var(--spacing-2xl);text-align:center;animation:fadeIn .5s ease-out}.login-header h1{font-size:2rem;margin-bottom:var(--spacing-sm);color:var(--color-text-primary);letter-spacing:-.03em;font-weight:600}.login-header p{color:var(--color-text-secondary);font-size:1rem;margin-bottom:var(--spacing-2xl)}.login-content{margin-bottom:var(--spacing-2xl)}.google-sign-in-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-xl);background:#fff;color:#333;border:none;border-radius:var(--radius-full);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition-default);box-shadow:var(--shadow-md)}.google-sign-in-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.google-sign-in-btn:active{transform:translateY(0)}.google-icon{width:24px;height:24px}.error-message{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);font-size:.875rem}.success-message{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-success-bg, rgba(48, 200, 120, .12));border:1px solid var(--color-success, #30c878);border-radius:var(--radius-md);color:var(--color-success, #30c878);font-size:.875rem}.login-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);background:var(--color-bg-secondary, rgba(255, 255, 255, .04));padding:4px;border-radius:var(--radius-full)}.login-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition-fast)}.login-tab.active{background:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.email-auth-form{display:flex;flex-direction:column;gap:var(--spacing-md);text-align:left}.login-field{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:.85rem;color:var(--color-text-secondary)}.login-field input{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.95rem;transition:var(--transition-fast)}.login-field input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #6366f126}.login-checkbox{display:flex;gap:var(--spacing-sm);align-items:flex-start;font-size:.8rem;color:var(--color-text-secondary);line-height:1.4}.login-checkbox input{margin-top:3px}.login-checkbox a{color:var(--color-accent-primary);text-decoration:underline}.email-submit-btn{margin-top:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-accent-primary);color:#fff;border:none;border-radius:var(--radius-full);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition-default)}.email-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.email-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-mode-links{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.link-button{background:none;border:none;color:var(--color-accent-primary);font-size:.85rem;cursor:pointer;padding:4px 8px}.link-button:hover{text-decoration:underline}.legal-acceptance{margin-top:var(--spacing-md);font-size:.75rem;color:var(--color-text-muted);line-height:1.5}.legal-acceptance a{color:var(--color-text-muted);text-decoration:underline;text-underline-offset:2px;transition:var(--transition-fast)}.legal-acceptance a:hover{color:var(--color-accent-primary)}.login-footer{color:var(--color-text-muted);font-size:.875rem}.login-footer p{margin-bottom:var(--spacing-xs)}.privacy-note{font-size:.75rem;opacity:.7}.legal-links{margin-top:var(--spacing-md);font-size:.75rem}.legal-links a{color:var(--color-text-muted);text-decoration:none;transition:var(--transition-fast)}.legal-links a:hover{color:var(--color-accent-primary)}.link-sep{margin:0 var(--spacing-xs);opacity:.4}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--spacing-md)}.sidebar{width:260px;height:100vh;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:var(--spacing-lg) var(--spacing-md);position:fixed;top:0;left:0;z-index:50;transition:transform var(--transition-default)}.sidebar-header{margin-bottom:var(--spacing-xl);padding:0 var(--spacing-sm)}.app-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.app-logo h1{font-size:1.25rem;margin:0;letter-spacing:-.03em;color:var(--color-text-primary);font-weight:600}.logo-icon{font-size:1.5rem}.text-accent{color:var(--color-text-primary)}.avatar{width:36px;height:36px;border-radius:var(--radius-full);border:none;padding:0;object-fit:cover}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar-nav-separator{height:1px;background:var(--color-border);margin:14px 12px}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:.55rem var(--spacing-md);border-radius:var(--radius-full);color:var(--color-text-secondary);background:transparent;transition:var(--transition-default);position:relative;font-size:.875rem}.nav-item:hover{color:var(--color-text-primary);background:var(--color-accent-subtle)}.nav-item.active{color:#fff;background:var(--color-accent-primary);font-weight:500}.nav-icon{font-size:1.1rem;min-width:22px;text-align:center}.nav-label{font-weight:inherit;letter-spacing:-.01em}.active-indicator{display:none}.sidebar-footer{display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid var(--color-border);margin-top:8px}.sidebar-footer .avatar{width:32px;height:32px}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.sidebar-user-name{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.6875rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-signout{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);padding:6px;border-radius:var(--radius-full);display:flex;align-items:center;transition:var(--transition-default)}.sidebar-signout:hover{color:var(--color-danger)}@media(max-width:900px){.sidebar{transform:translate(-100%)}.sidebar-wrapper.open .sidebar{transform:translate(0)}}.trial-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-xl);background:var(--color-accent-subtle);border-bottom:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-primary);min-height:44px}.trial-banner-icon{display:flex;align-items:center;flex-shrink:0;color:var(--color-accent-primary)}.trial-banner-text{flex:1;line-height:1.4}.trial-banner-cta{flex-shrink:0;padding:.375rem var(--spacing-md);background:var(--color-accent-primary);color:var(--color-text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.trial-banner-cta:hover{background:var(--color-accent-hover)}.trial-banner-cta:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.trial-banner-dismiss{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.trial-banner-dismiss:hover{color:var(--color-text-primary);background:var(--color-border)}.trial-banner-dismiss:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.trial-banner--warning{background:var(--color-warning-bg);border-bottom-color:var(--color-warning)}.trial-banner--warning .trial-banner-icon{color:var(--color-warning)}.trial-banner--warning .trial-banner-cta{background:var(--color-warning);padding:.5rem var(--spacing-lg);font-size:.875rem}.trial-banner--warning .trial-banner-cta:hover{background:#b45309}.trial-banner--warning .trial-banner-cta:focus-visible{outline-color:var(--color-warning)}@media(max-width:1024px){.trial-banner{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap}.trial-banner-text{flex-basis:calc(100% - 80px)}.trial-banner-cta{margin-left:auto}}@media(max-width:480px){.trial-banner{flex-direction:column;align-items:stretch;gap:var(--spacing-xs);text-align:center}.trial-banner-icon{display:none}.trial-banner-dismiss{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs)}.trial-banner{position:relative;padding-top:var(--spacing-md)}.trial-banner-cta{align-self:center}}.layout{display:flex;min-height:100vh;background:var(--color-bg-primary)}.main-content{flex:1;margin-left:260px;min-height:100vh;display:flex;flex-direction:column}.top-bar{height:56px;padding:0 var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-md, 14px);position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--color-bg-primary) 90%,transparent);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-bottom:1px solid var(--color-border)}.top-bar-titleblock{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.15}.top-bar-title{font-size:.875rem;font-weight:600;color:var(--color-text-primary);letter-spacing:-.01em}.top-bar-subtitle{font-size:.6875rem;color:var(--color-text-muted);margin-top:1px}.top-bar-actions{display:flex;align-items:center;gap:var(--spacing-sm, 8px);flex-shrink:0}.top-bar-plan-cta{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:var(--radius-full, 9999px);background:var(--color-accent-primary);color:#fff;border:none;font-family:inherit;font-size:.8125rem;font-weight:600;cursor:pointer;transition:var(--transition-default, .25s cubic-bezier(.34, 1.56, .64, 1))}.top-bar-plan-cta:hover{background:var(--color-accent-hover, #3b82f6);transform:translateY(-1px);box-shadow:var(--shadow-glow, 0 0 20px rgba(37, 99, 235, .25))}.top-bar-plan-cta:active{transform:translateY(0)}.top-bar-plan-cta:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-full, 9999px);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);padding:0;cursor:pointer;flex-shrink:0}.mobile-menu-btn:hover{background:var(--color-accent-subtle);color:var(--color-accent-primary)}.content-container{padding:var(--spacing-xl);max-width:1600px;width:100%;margin:0 auto;animation:fadeIn .5s ease-out}.mobile-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:45;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-footer{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border);margin-top:auto}.app-footer-copy{font-size:.75rem;color:var(--color-text-muted)}.app-footer-links{display:flex;justify-content:center;gap:var(--spacing-lg)}.app-footer a{font-size:.75rem;color:var(--color-text-muted);text-decoration:none;transition:var(--transition-fast)}.app-footer a:hover{color:var(--color-accent-primary)}@media(max-width:900px){.main-content{margin-left:0}.top-bar{padding:0 var(--spacing-md)}.mobile-menu-btn{display:inline-flex}.top-bar-plan-cta span{display:none}.top-bar-plan-cta{padding:0 10px;height:30px}.content-container{padding:var(--spacing-md)}}.sync-status{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:12px;font-size:.9rem;font-weight:500;margin-bottom:1.5rem;transition:all .3s ease;box-shadow:var(--shadow-sm)}.sync-icon{font-size:1.2rem;display:flex;align-items:center;justify-content:center}.sync-status.loading{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.sync-status.syncing{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid rgba(194,132,26,.2)}.sync-status.saved{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgba(45,138,78,.2)}.sync-status.error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(197,48,48,.2)}.sync-icon.spinning{animation:spin 1s linear infinite}.retry-btn{margin-left:auto;padding:.4rem 1rem;background:var(--color-danger);border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{opacity:.9;transform:translateY(-1px)}.retry-btn:active{transform:translateY(0)}@media(max-width:768px){.sync-status{font-size:.85rem;padding:.6rem 1rem}.sync-icon{font-size:1rem}}.monthly-table-summary{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);background:var(--color-bg-secondary, #fff);border:1px solid var(--color-border, rgba(15, 23, 42, .08));border-radius:var(--radius-md, 1rem);box-shadow:0 4px 16px -12px #0f172a2e}.monthly-summary-stat{display:flex;flex-direction:column;gap:.2rem;min-width:0}.monthly-summary-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary, #475569)}.monthly-summary-value{font-size:1.4rem;font-weight:700;color:var(--color-text-primary, #0f172a);line-height:1.15;word-break:break-word}.monthly-summary-value--editable{background:transparent;border:1px dashed transparent;padding:.1rem .25rem;margin:-.1rem -.25rem;border-radius:var(--radius-sm, .5rem);text-align:left;cursor:text;color:inherit;font:inherit;transition:border-color .12s ease,background .12s ease}.monthly-summary-value--editable:hover,.monthly-summary-value--editable:focus-visible{border-color:var(--color-border-hover, rgba(15, 23, 42, .16));background:var(--color-bg-primary, #f8fafc);outline:none}.monthly-summary-edit{display:inline-flex;align-items:center}.monthly-summary-input{width:100%;max-width:14ch;padding:.25rem .4rem;font:inherit;font-size:1.35rem;font-weight:700;color:var(--color-text-primary, #0f172a);background:var(--color-bg-primary, #f8fafc);border:1px solid var(--color-border-focus, #2563eb);border-radius:var(--radius-sm, .5rem);outline:none}.monthly-summary-input--invalid{border-color:var(--color-danger, #dc2626);animation:monthlySummaryShake .18s ease}@keyframes monthlySummaryShake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.monthly-summary-override-row{display:inline-flex;align-items:center;gap:.4rem;margin-top:.2rem}.monthly-summary-override-badge{display:inline-flex;align-items:center;padding:.1rem .45rem;border-radius:999px;background:var(--color-warning-bg, rgba(217, 119, 6, .1));color:var(--color-warning, #d97706);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.monthly-summary-reset{display:inline-flex;align-items:center;gap:.2rem;padding:.1rem .4rem;border:1px solid transparent;border-radius:var(--radius-sm, .5rem);background:transparent;color:var(--color-text-secondary, #475569);font-size:.75rem;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.monthly-summary-reset:hover,.monthly-summary-reset:focus-visible{background:var(--color-bg-primary, #f8fafc);border-color:var(--color-border, rgba(15, 23, 42, .08));color:var(--color-text-primary, #0f172a);outline:none}.monthly-summary-stat--unallocated .monthly-summary-value{transition:color .18s ease}.monthly-summary-stat--balanced .monthly-summary-value{color:var(--color-success, #16a34a)}.monthly-summary-stat--surplus .monthly-summary-value{color:var(--color-warning, #d97706)}.monthly-summary-stat--deficit .monthly-summary-value{color:var(--color-danger, #dc2626)}.monthly-summary-sign-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted, #94a3b8)}.monthly-summary-stat--balanced .monthly-summary-sign-label{color:var(--color-success, #16a34a)}.monthly-summary-stat--surplus .monthly-summary-sign-label{color:var(--color-warning, #d97706)}.monthly-summary-stat--deficit .monthly-summary-sign-label{color:var(--color-danger, #dc2626)}.monthly-summary-tighten{grid-column:1 / -1;display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem;padding-top:.65rem;margin-top:.25rem;border-top:1px dashed var(--color-border, rgba(15, 23, 42, .12));font-size:.88rem;color:var(--color-text-secondary, #475569)}.monthly-summary-tighten-label{font-weight:600;color:var(--color-warning, #d97706);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.monthly-summary-tighten-value{font-weight:700;font-size:1rem;color:var(--color-text-primary, #0f172a);font-variant-numeric:tabular-nums}.monthly-summary-tighten-savings{color:var(--color-success, #16a34a);font-weight:500}@media(max-width:640px){.monthly-table-summary{grid-template-columns:1fr;padding:var(--spacing-md, .875rem)}.monthly-summary-value{font-size:1.25rem}.monthly-summary-input{font-size:1.2rem}.monthly-summary-tighten{flex-direction:column;align-items:flex-start;gap:.25rem}}.month-selector{position:relative;display:inline-flex;align-items:center;gap:var(--spacing-xs, .25rem);background:var(--color-bg-secondary, #fff);border:1px solid var(--color-border, rgba(15, 23, 42, .08));border-radius:var(--radius-md, 1rem);padding:.25rem}.month-selector-arrow{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:none;background:transparent;border-radius:var(--radius-sm, .75rem);color:var(--color-text-secondary, #475569);cursor:pointer;transition:background .12s ease,color .12s ease}.month-selector-arrow:hover:not(:disabled){background:var(--color-accent-subtle, rgba(37, 99, 235, .06));color:var(--color-accent-primary, #2563eb)}.month-selector-arrow:focus-visible{outline:2px solid var(--color-border-focus, #2563eb);outline-offset:2px}.month-selector-arrow:disabled{opacity:.4;cursor:not-allowed}.month-selector-label{display:inline-flex;align-items:center;gap:.4rem;height:2rem;padding:0 .75rem;border:none;background:transparent;border-radius:var(--radius-sm, .75rem);font-weight:600;font-size:.95rem;color:var(--color-text-primary, #0f172a);cursor:pointer;min-width:10rem;justify-content:space-between;transition:background .12s ease}.month-selector-label:hover{background:var(--color-accent-subtle, rgba(37, 99, 235, .06))}.month-selector-label:focus-visible{outline:2px solid var(--color-border-focus, #2563eb);outline-offset:2px}.month-selector-label-text{white-space:nowrap}.month-selector-dropdown{position:absolute;top:calc(100% + .25rem);left:0;right:0;z-index:50;margin:0;padding:.25rem;list-style:none;background:var(--color-bg-secondary, #fff);border:1px solid var(--color-border, rgba(15, 23, 42, .08));border-radius:var(--radius-md, 1rem);box-shadow:0 8px 24px #0f172a1f;max-height:16rem;overflow-y:auto}.month-selector-option{margin:0}.month-selector-option-btn{display:block;width:100%;padding:.4rem .75rem;border:none;background:transparent;text-align:left;font:inherit;color:var(--color-text-primary, #0f172a);border-radius:var(--radius-sm, .75rem);cursor:pointer}.month-selector-option-btn:hover,.month-selector-option-btn:focus-visible{background:var(--color-accent-subtle, rgba(37, 99, 235, .06));outline:none}.month-selector-option.is-selected .month-selector-option-btn{background:var(--color-accent-primary, #2563eb);color:var(--color-text-inverse, #f8fafc)}.month-selector-option.is-selected .month-selector-option-btn:hover,.month-selector-option.is-selected .month-selector-option-btn:focus-visible{background:var(--color-accent-hover, #3b82f6)}@media(max-width:640px){.month-selector-label{min-width:8rem;font-size:.9rem}.month-selector-arrow{width:1.75rem;height:1.75rem}}.ef-banner{display:flex;align-items:stretch;gap:var(--spacing-md, 12px);padding:0;border-radius:var(--radius-lg, 12px);border:1px solid var(--color-border, rgba(255, 255, 255, .08));overflow:hidden;background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent-primary, #6366f1) 10%,transparent) 0%,transparent 60%)}.ef-banner-clickable{display:flex;flex:1;align-items:center;gap:var(--spacing-md, 16px);background:transparent;border:none;padding:var(--spacing-lg, 20px) var(--spacing-lg, 24px);color:inherit;text-align:left;cursor:pointer;width:100%;transition:background-color .12s ease}.ef-banner-clickable:hover,.ef-banner-clickable:focus-visible{background-color:var(--color-bg-tertiary, rgba(255, 255, 255, .04));outline:none}.ef-banner-clickable:focus-visible{box-shadow:inset 0 0 0 2px var(--color-accent-primary, #6366f1)}.ef-banner-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;min-width:56px;border-radius:50%;background:color-mix(in srgb,var(--color-accent-primary, #6366f1) 20%,transparent);color:var(--color-accent-primary, #6366f1);flex-shrink:0}.ef-banner--missing .ef-banner-icon,.ef-banner--paused .ef-banner-icon{background:color-mix(in srgb,var(--color-warning, #eab308) 20%,transparent);color:var(--color-warning, #eab308)}.ef-banner--complete .ef-banner-icon{background:color-mix(in srgb,var(--color-success, #10b981) 20%,transparent);color:var(--color-success, #10b981)}.ef-banner-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-xs, 6px)}.ef-banner-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm, 8px);flex-wrap:wrap}.ef-banner-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary, #fff)}.ef-banner-subtitle{margin:0;font-size:.875rem;color:var(--color-text-secondary, rgba(255, 255, 255, .6))}.ef-banner-status{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;border-radius:999px}.ef-banner-status--active{background:color-mix(in srgb,var(--color-accent-primary, #6366f1) 20%,transparent);color:var(--color-accent-primary, #6366f1)}.ef-banner-status--paused{background:color-mix(in srgb,var(--color-warning, #eab308) 20%,transparent);color:var(--color-warning, #eab308)}.ef-banner-status--complete{background:color-mix(in srgb,var(--color-success, #10b981) 20%,transparent);color:var(--color-success, #10b981)}.ef-banner-progress{width:100%;height:8px;background:color-mix(in srgb,var(--color-border, rgba(255, 255, 255, .1)) 100%,transparent);border-radius:999px;overflow:hidden;margin-top:4px}.ef-banner-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-primary, #6366f1),color-mix(in srgb,var(--color-accent-primary, #6366f1) 70%,#fff));border-radius:inherit;transition:width .24s ease}.ef-banner--complete .ef-banner-progress-fill{background:var(--color-success, #10b981)}.ef-banner--paused .ef-banner-progress-fill{background:var(--color-warning, #eab308);opacity:.7}.ef-banner-meta{display:flex;gap:var(--spacing-md, 16px);align-items:baseline;flex-wrap:wrap;margin-top:4px}.ef-banner-amount{font-size:.9375rem}.ef-banner-amount strong{font-size:1rem;color:var(--color-text-primary, #fff)}.ef-banner-amount-divider,.ef-banner-amount-target{color:var(--color-text-secondary, rgba(255, 255, 255, .6))}.ef-banner-coverage{font-size:.8125rem;color:var(--color-text-secondary, rgba(255, 255, 255, .7))}.ef-banner-coverage--muted{font-style:italic;opacity:.7}.ef-banner-coverage--success{color:var(--color-success, #10b981);font-weight:600}.ef-banner-actions{display:flex;align-items:center;padding:var(--spacing-md, 16px) var(--spacing-lg, 20px);border-left:1px solid var(--color-border, rgba(255, 255, 255, .08))}.ef-banner-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-accent-primary, #6366f1);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .12s ease,transform .12s ease}.ef-banner-cta:hover,.ef-banner-cta:focus-visible{background:color-mix(in srgb,var(--color-accent-primary, #6366f1) 85%,#fff);outline:none;transform:translateY(-1px)}.ef-banner-cta--resume{background:var(--color-warning, #eab308);color:#1a1a1a}.ef-banner-cta--resume:hover,.ef-banner-cta--resume:focus-visible{background:color-mix(in srgb,var(--color-warning, #eab308) 85%,#fff)}.ef-banner--strip{padding:0;background:#16a34a0f;border-color:#16a34a33}.ef-strip-inner{display:flex;align-items:center;gap:14px;padding:10px 18px;width:100%;background:transparent;border:none;cursor:pointer;text-align:left;font-family:var(--font-sans, "Space Grotesk", sans-serif)}.ef-strip-inner:hover,.ef-strip-inner:focus-visible{background-color:#16a34a14;outline:none}.ef-strip-icon{color:#16a34a;flex-shrink:0}.ef-strip-text{flex:1;font-size:13px;color:#0f172a;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ef-strip-text strong{font-weight:600}.ef-strip-meta{color:#475569}.ef-strip-chip{padding:2px 10px;border-radius:9999px;background:#16a34a1f;color:#16a34a;font-size:11px;font-weight:600;white-space:nowrap}@media(max-width:640px){.ef-banner{flex-direction:column}.ef-banner-clickable{padding:var(--spacing-md, 16px)}.ef-banner-actions{border-left:none;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08));padding:var(--spacing-sm, 12px) var(--spacing-md, 16px);justify-content:flex-end}.ef-banner-icon{width:44px;height:44px;min-width:44px}.ef-banner-header{flex-direction:column;align-items:flex-start}}.month-preview-card{display:flex;flex-direction:column;gap:var(--spacing-sm, 10px);padding:var(--spacing-md, 16px);background:var(--color-bg-secondary, rgba(255, 255, 255, .04));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:var(--radius-md, 10px);color:inherit;text-align:left;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background-color .12s ease;min-width:0}.month-preview-card:hover,.month-preview-card:focus-visible{transform:translateY(-2px);border-color:var(--color-accent-primary, #6366f1);background-color:var(--color-bg-tertiary, rgba(255, 255, 255, .06));outline:none}.month-preview-card--current{border-color:var(--color-accent-primary, #6366f1);background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent-primary, #6366f1) 10%,transparent) 0%,transparent 100%)}.month-preview-card--deficit{border-left:3px solid var(--color-danger, #ef4444)}.month-preview-card--surplus{border-left:3px solid var(--color-warning, #eab308)}.month-preview-card--balanced{border-left:3px solid var(--color-success, #10b981)}.month-preview-header{display:flex;align-items:center;gap:8px}.month-preview-label{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary, #fff);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.month-preview-chip{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:999px;background:color-mix(in srgb,var(--color-accent-primary, #6366f1) 25%,transparent);color:var(--color-accent-primary, #6366f1)}.month-preview-arrow{color:var(--color-text-secondary, rgba(255, 255, 255, .5));flex-shrink:0;transition:transform .12s ease}.month-preview-card:hover .month-preview-arrow,.month-preview-card:focus-visible .month-preview-arrow{transform:translate(2px);color:var(--color-accent-primary, #6366f1)}.month-preview-stats{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs, 6px) var(--spacing-sm, 12px)}.month-preview-stat{display:flex;flex-direction:column;gap:2px}.month-preview-stat dt{font-size:.6875rem;font-weight:500;color:var(--color-text-secondary, rgba(255, 255, 255, .55));text-transform:uppercase;letter-spacing:.04em}.month-preview-stat dd{margin:0;font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #fff)}.month-preview-stat--unallocated{grid-column:1 / -1;padding-top:4px;border-top:1px dashed var(--color-border, rgba(255, 255, 255, .08));margin-top:2px}.month-preview-stat--unallocated dd{font-size:1rem}.month-preview-stat--deficit dd{color:var(--color-danger, #ef4444)}.month-preview-stat--surplus dd{color:var(--color-warning, #eab308)}.month-preview-stat--balanced dd{color:var(--color-success, #10b981)}.month-preview-waterfall{display:flex;flex-direction:column;gap:4px;margin-top:2px}.waterfall-row{display:grid;grid-template-columns:50px 1fr 54px;align-items:center;gap:8px}.waterfall-row--total{padding-top:5px;border-top:1px dashed rgba(15,23,42,.08);margin-top:3px}.waterfall-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waterfall-track{position:relative;height:8px;border-radius:3px;background:transparent;width:100%}.waterfall-track--income{background:#2563eb1a;border-radius:3px;height:14px}.waterfall-bar{position:absolute;top:0;bottom:0;height:100%;border-radius:3px;transition:width .24s ease,left .24s ease}.waterfall-bar--income{height:14px}.waterfall-amount{font-size:11px;text-align:right;font-variant-numeric:tabular-nums;color:var(--color-text-primary, #0f172a);white-space:nowrap}.this-month-panel{display:flex;flex-direction:column;gap:var(--spacing-sm, 10px)}.this-month-panel .tmp-section-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.this-month-panel .tmp-section-header h3{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;color:var(--color-text-primary);margin:0}.this-month-panel .tmp-plan-cta{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--color-accent-primary);font-family:inherit;font-size:.8125rem;font-weight:600;padding:6px 8px;border-radius:var(--radius-full, 9999px);cursor:pointer;transition:var(--transition-default, .25s cubic-bezier(.34, 1.56, .64, 1))}.this-month-panel .tmp-plan-cta:hover{background:var(--color-accent-subtle, rgba(37, 99, 235, .06))}.this-month-panel .tmp-plan-cta:hover svg{transform:translate(2px)}.this-month-panel .tmp-plan-cta svg{transition:transform var(--transition-fast, .15s cubic-bezier(.34, 1.56, .64, 1))}.this-month-panel .tmp-plan-cta:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.this-month-panel .tmp-card{background:linear-gradient(135deg,#2563eb0f,#2563eb00 55%),var(--color-bg-secondary, #ffffff);border:1px solid var(--color-border, rgba(15, 23, 42, .08));border-left:3px solid var(--color-success, #16a34a);border-radius:var(--radius-lg, 1.25rem);padding:22px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, .08))}.this-month-panel--surplus .tmp-card{border-left-color:var(--color-warning, #d97706)}.this-month-panel--deficit .tmp-card{border-left-color:var(--color-danger, #dc2626)}.this-month-panel .tmp-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1fr) minmax(0,1fr);gap:24px}.this-month-panel .tmp-col{display:flex;flex-direction:column;gap:12px;min-width:0}.this-month-panel .tmp-col-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.this-month-panel .tmp-col-eyebrow-wrap{display:flex;flex-direction:column;gap:2px;line-height:1.1}.this-month-panel .tmp-eyebrow{font-size:.625rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--color-text-muted, #94a3b8)}.this-month-panel .tmp-eyebrow--row{display:inline-flex;align-items:center;gap:6px}.this-month-panel .tmp-col-title{font-size:.9375rem;color:var(--color-text-primary);font-weight:600}.this-month-panel .tmp-state-chip{padding:3px 10px;border-radius:var(--radius-full, 9999px);font-size:.6875rem;font-weight:600;white-space:nowrap;font-variant-numeric:tabular-nums}.this-month-panel .tmp-waterfall{display:flex;flex-direction:column;gap:5px;font-variant-numeric:tabular-nums}.this-month-panel .tmp-wf-row{display:flex;align-items:center;gap:8px}.this-month-panel .tmp-wf-row--last{padding-top:6px;margin-top:4px;border-top:1px dashed var(--color-border, rgba(15, 23, 42, .08))}.this-month-panel .tmp-wf-label{flex:0 0 78px;font-size:.6875rem;color:var(--color-text-secondary, #475569);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.this-month-panel .tmp-wf-row--first .tmp-wf-label,.this-month-panel .tmp-wf-row--last .tmp-wf-label{font-weight:700}.this-month-panel .tmp-wf-track{flex:1;position:relative;height:10px;border-radius:3px}.this-month-panel .tmp-wf-track--income{height:16px;background:#2563eb1a;border-radius:4px}.this-month-panel .tmp-wf-bar{position:absolute;top:0;bottom:0;border-radius:3px}.this-month-panel .tmp-wf-row--first .tmp-wf-bar{border-radius:4px}.this-month-panel .tmp-wf-amount{flex:0 0 70px;text-align:right;font-size:.75rem;font-weight:500;color:var(--color-text-secondary, #475569)}.this-month-panel .tmp-wf-row--first .tmp-wf-amount{color:var(--color-text-primary);font-weight:600}.this-month-panel .tmp-wf-row--last .tmp-wf-amount{font-weight:700}.this-month-panel .tmp-snapshot-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.this-month-panel .tmp-snapshot-meta{font-size:.6875rem;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.this-month-panel .tmp-snapshot-meta-suffix{color:var(--color-text-muted)}.this-month-panel .tmp-rows{display:flex;flex-direction:column;gap:6px}.this-month-panel .tmp-empty{padding:14px 12px;border:1px dashed var(--color-border);border-radius:var(--radius-md, 1rem);background:var(--color-bg-primary);color:var(--color-text-muted);font-size:.8125rem;text-align:center}.this-month-panel .tmp-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-bg-primary, #f8fafc);border-radius:var(--radius-sm, .625rem)}.this-month-panel .tmp-row-icon{width:28px;height:28px;border-radius:var(--radius-full, 9999px);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.this-month-panel .tmp-row-body{flex:1;min-width:0}.this-month-panel .tmp-row-name{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.this-month-panel .tmp-row-meta{font-size:.6875rem;color:var(--color-text-muted);display:flex;align-items:center;gap:6px;margin-top:1px;flex-wrap:wrap}.this-month-panel .tmp-row-dot{color:#0f172a33}.this-month-panel .tmp-row-funded{color:var(--color-success, #16a34a);font-weight:600}.this-month-panel .tmp-tabular{font-variant-numeric:tabular-nums}.this-month-panel .tmp-row-progress{height:3px;background:var(--color-bg-tertiary, #e2e8f0);border-radius:var(--radius-full, 9999px);margin-top:5px;overflow:hidden}.this-month-panel .tmp-row-progress-fill{height:100%;border-radius:var(--radius-full, 9999px);transition:width .25s ease-out}.this-month-panel .tmp-row-amount{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums;flex-shrink:0;text-align:right}@media(max-width:900px){.this-month-panel .tmp-grid{grid-template-columns:1fr;gap:18px}}@media(max-width:640px){.this-month-panel .tmp-card{padding:16px}.this-month-panel .tmp-wf-label{flex-basis:64px}}.coverage-card{background:var(--color-bg-secondary, #1a1a2e);border:1px solid var(--color-border, #2a2a3e);border-left:4px solid var(--color-border, #2a2a3e);border-radius:var(--radius-lg, 12px);padding:var(--spacing-md, 1rem);display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem)}.coverage-card--covered{border-left-color:var(--color-success, #2a9d3a)}.coverage-card--warning{border-left-color:var(--color-warning, #d99a28)}.coverage-card--short{border-left-color:var(--color-error, #d93a3a)}.coverage-card-header{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);min-width:0}.coverage-card-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text-primary, #e0e0e0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.coverage-card-badge{display:inline-block;flex-shrink:0;padding:2px 8px;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-sm, 4px);line-height:1.4}.coverage-card-badge--covered{background:color-mix(in srgb,var(--color-success, #2a9d3a) 20%,transparent);color:var(--color-success, #2a9d3a)}.coverage-card-badge--warning{background:color-mix(in srgb,var(--color-warning, #d99a28) 20%,transparent);color:var(--color-warning, #d99a28)}.coverage-card-badge--short{background:color-mix(in srgb,var(--color-error, #d93a3a) 20%,transparent);color:var(--color-error, #d93a3a)}.coverage-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm, .5rem)}.coverage-card-stat{display:flex;flex-direction:column;gap:2px}.coverage-card-stat-label{font-size:.7rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--color-text-secondary, #999)}.coverage-card-stat-value{font-size:1.05rem;font-weight:700;color:var(--color-text-primary, #e0e0e0);font-variant-numeric:tabular-nums}.coverage-card-stat-value--positive{color:var(--color-success, #2a9d3a)}.coverage-card-stat-value--negative{color:var(--color-error, #d93a3a)}.coverage-card-stat-value--warning{color:var(--color-warning, #d99a28)}.coverage-card-expenses{margin:0;font-size:.8rem;color:var(--color-text-secondary, #999);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coverage-card-timestamp{margin:0;font-size:.72rem;color:var(--color-text-tertiary, #666)}@media(max-width:360px){.coverage-card-stats{grid-template-columns:1fr 1fr}}.home-page{display:flex;flex-direction:column;gap:var(--spacing-lg, 24px);max-width:1200px;margin:0 auto;padding:var(--spacing-md, 16px) var(--spacing-lg, 24px) var(--spacing-xl, 40px)}.home-header h2{margin:0 0 4px;font-size:1.625rem;font-weight:700;color:var(--color-text-primary, #fff)}.home-subtitle{margin:0;font-size:.9375rem;color:var(--color-text-secondary, rgba(255, 255, 255, .6))}.home-section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm, 8px);margin-bottom:var(--spacing-sm, 12px)}.home-section-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary, #fff);text-transform:uppercase;letter-spacing:.05em}.home-cta{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;color:var(--color-accent-primary, #6366f1);border:1px solid var(--color-accent-primary, #6366f1);border-radius:var(--radius-md, 8px);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background-color .12s ease,color .12s ease}.home-cta:hover,.home-cta:focus-visible{background:var(--color-accent-primary, #6366f1);color:#fff;outline:none}.home-current{display:flex;flex-direction:column}.home-current .month-preview-card{max-width:480px}.home-upcoming-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:900px){.home-upcoming-grid{grid-template-columns:repeat(2,1fr)}}.home-coverage{display:flex;flex-direction:column}.home-coverage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-sm, 12px)}.home-warnings{display:flex;flex-direction:column}.home-warnings-empty{display:flex;align-items:center;gap:8px;padding:var(--spacing-md, 14px) var(--spacing-md, 16px);background:color-mix(in srgb,var(--color-success, #10b981) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-success, #10b981) 30%,transparent);border-radius:var(--radius-md, 8px);color:var(--color-success, #10b981);font-size:.875rem}.home-warnings-empty-icon{flex-shrink:0}.home-warnings-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs, 8px)}.home-warning{display:flex;align-items:center;gap:var(--spacing-sm, 10px);padding:var(--spacing-sm, 12px) var(--spacing-md, 16px);background:var(--color-bg-secondary, rgba(255, 255, 255, .04));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-left:3px solid var(--color-warning, #eab308);border-radius:var(--radius-md, 8px)}.home-warning--under-funded{border-left-color:var(--color-danger, #ef4444)}.home-warning--paused-sequence{border-left-color:var(--color-warning, #eab308)}.home-warning-icon{color:var(--color-warning, #eab308);display:inline-flex;flex-shrink:0}.home-warning--under-funded .home-warning-icon{color:var(--color-danger, #ef4444)}.home-warning-body{flex:1;font-size:.875rem;color:var(--color-text-primary, #fff);min-width:0}.home-warning-body strong{font-weight:600}.home-warning-cta{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:transparent;color:var(--color-accent-primary, #6366f1);border:1px solid var(--color-accent-primary, #6366f1);border-radius:var(--radius-md, 6px);font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:background-color .12s ease,color .12s ease}.home-warning-cta:hover,.home-warning-cta:focus-visible{background:var(--color-accent-primary, #6366f1);color:#fff;outline:none}@media(max-width:640px){.home-page{padding:var(--spacing-sm, 12px)}.home-upcoming-grid,.home-coverage-grid{grid-template-columns:1fr}.home-section-header,.home-warning{flex-wrap:wrap}.home-warning-body{flex-basis:100%}}.warnings-bell{position:relative;display:inline-flex;align-items:center}.warnings-bell-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--color-text-primary, #0f172a);cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.warnings-bell-btn:hover{background:#0f172a0f}.warnings-bell-btn:focus-visible{outline:2px solid var(--color-accent-primary, #2563eb);outline-offset:2px}.warnings-bell-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;box-shadow:0 0 0 2px var(--color-bg-primary, #fff);pointer-events:none}.warnings-bell-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;max-width:360px;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:12px;box-shadow:0 8px 28px #0f172a24;z-index:50;overflow:hidden;animation:warnings-bell-fade-in .15s ease-out;transform-origin:top right}@keyframes warnings-bell-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.warnings-bell-empty{display:flex;align-items:center;gap:8px;padding:16px;color:#0f172a;font-size:.875rem}.warnings-bell-empty-icon{color:#16a34a;flex-shrink:0}.warnings-bell-list{list-style:none;margin:0;padding:6px 0;max-height:360px;overflow-y:auto}.warnings-bell-item{margin:0}.warnings-bell-item+.warnings-bell-item{border-top:1px solid rgba(15,23,42,.05)}.warnings-bell-item-btn{width:100%;display:flex;align-items:flex-start;gap:10px;padding:10px 14px;font-size:.875rem;line-height:1.4;color:#0f172a;background:transparent;border:none;text-align:left;cursor:pointer;font-family:inherit;transition:background var(--transition-fast, .15s ease)}.warnings-bell-item-btn:hover{background:var(--color-accent-subtle, rgba(37, 99, 235, .06))}.warnings-bell-item-btn:focus-visible{outline:2px solid var(--color-accent-primary, #2563eb);outline-offset:-2px}.warnings-bell-item-cta{flex-shrink:0;font-size:.75rem;font-weight:600;color:var(--color-accent-primary, #2563eb);margin-top:1px;white-space:nowrap}.warnings-bell-item-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.warnings-bell-item--under-funded .warnings-bell-item-icon{color:#dc2626}.warnings-bell-item--paused-sequence .warnings-bell-item-icon{color:#d97706}.warnings-bell-item-body{flex:1}.warnings-bell-item-body strong{font-weight:600}@media(max-width:480px){.warnings-bell-dropdown{min-width:260px;max-width:calc(100vw - 24px)}}.ob-progress{margin-bottom:var(--spacing-xl)}.ob-progress-track{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-xs);position:relative}.ob-progress-track:before{content:"";position:absolute;top:14px;left:14px;right:14px;height:2px;background:var(--color-border);z-index:0}.ob-progress-step{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);position:relative;z-index:1;flex:1;min-width:0}.ob-progress-dot{width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-bg-secondary);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.ob-progress-dot-number{font-size:.7rem;font-weight:600;color:var(--color-text-muted)}.ob-progress-step.current .ob-progress-dot{background:var(--color-accent-primary);border-color:var(--color-accent-primary);transform:scale(1.1);box-shadow:0 0 0 4px #2563eb26}.ob-progress-step.current .ob-progress-dot-number{color:var(--color-text-inverse)}.ob-progress-step.completed .ob-progress-dot{background:var(--color-success);border-color:var(--color-success);color:#fff}.ob-progress-label{font-size:.7rem;color:var(--color-text-muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.ob-progress-step.current .ob-progress-label{color:var(--color-accent-primary);font-weight:600}.ob-progress-step.completed .ob-progress-label{color:var(--color-success)}.ob-progress-text{text-align:center;font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-sm);display:none}@media(max-width:480px){.ob-progress-label{display:none}.ob-progress-text{display:block}.ob-progress-dot{width:24px;height:24px}.ob-progress-track:before{top:12px;left:12px;right:12px}}.ob-step-title{font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-sm);text-align:center;color:var(--color-text-primary);letter-spacing:-.02em}.ob-step-subtitle{color:var(--color-text-secondary);text-align:center;margin-bottom:var(--spacing-xl);font-size:.95rem;line-height:1.5}.ob-form-group{margin-bottom:var(--spacing-lg)}.ob-form-group label{display:block;font-weight:500;margin-bottom:var(--spacing-xs);font-size:.9rem;color:var(--color-text-primary)}.ob-form-group input[type=text],.ob-form-group input[type=number],.ob-form-group input[type=password],.ob-form-group select{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.95rem;transition:border-color .15s ease;min-height:44px}.ob-form-group input:focus,.ob-form-group select:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2563eb1a}.ob-hint{display:block;font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.ob-actions{display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-xl);gap:var(--spacing-sm)}.ob-actions-right{display:flex;gap:var(--spacing-sm)}.ob-inline-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.ob-inline-row:last-child{border-bottom:none}.ob-inline-row input[type=text]{flex:1.5}.ob-inline-row input[type=number]{flex:1}.ob-row-remove{flex-shrink:0;background:none;border:none;color:var(--color-text-muted);font-size:1.2rem;padding:var(--spacing-xs);border-radius:var(--radius-sm);cursor:pointer;line-height:1;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.ob-row-remove:hover{color:var(--color-danger);background:#ef44441a}.ob-add-row{background:none;border:none;color:var(--color-accent-primary);font-size:.875rem;padding:var(--spacing-sm) 0;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-xs)}.ob-add-row:hover{text-decoration:underline}.ob-chip-group{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.ob-chip{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-bg-tertiary);border:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease;min-height:44px;display:flex;align-items:center}.ob-chip:hover{border-color:var(--color-accent-primary)}.ob-chip.selected{background:var(--color-accent-primary);color:var(--color-text-inverse);border-color:var(--color-accent-primary)}.ob-checkbox-label{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.85rem;color:var(--color-text-secondary);cursor:pointer;min-height:44px;padding:0 var(--spacing-xs)}.ob-checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent-primary)}.ob-running-total{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-top:var(--spacing-md);font-size:.9rem}.ob-running-total .ob-total-label{color:var(--color-text-secondary)}.ob-running-total .ob-total-value{font-weight:600;color:var(--color-text-primary)}.ob-running-total .ob-total-remaining{font-weight:500;color:var(--color-success)}.ob-running-total .ob-total-remaining.negative{color:var(--color-danger)}.ob-callout{padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--color-accent-primary);margin-bottom:var(--spacing-lg);font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.ob-csv-section{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);align-items:center}.ob-csv-section .btn{white-space:nowrap}.ob-csv-errors{padding:var(--spacing-sm) var(--spacing-md);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.8rem;color:var(--color-danger)}.ob-csv-errors ul{margin:var(--spacing-xs) 0 0 var(--spacing-md);padding:0}.ob-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.ob-stat-card{text-align:center;padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.ob-stat-card .ob-stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.ob-stat-card .ob-stat-value{font-size:1.1rem;font-weight:600;color:var(--color-text-primary)}.ob-suggestions{list-style:none;padding:0;margin:var(--spacing-md) 0 0 0}.ob-suggestions li{padding:var(--spacing-sm) 0;color:var(--color-text-secondary);font-size:.875rem;display:flex;align-items:center;gap:var(--spacing-sm)}.ob-suggestions li:before{content:"→";color:var(--color-accent-primary);font-weight:600}@media(max-width:600px){.ob-step-title{font-size:1.25rem}.ob-actions{flex-direction:column-reverse;gap:var(--spacing-sm)}.ob-actions-right{width:100%;justify-content:flex-end}.ob-actions>.btn{width:100%}.ob-inline-row{flex-wrap:wrap}.ob-inline-row input[type=text],.ob-inline-row input[type=number]{flex:1 1 100%}.ob-csv-section{flex-direction:column;align-items:stretch}}.ob-model-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.ob-model-card{padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.ob-model-icon{display:flex;align-items:center;justify-content:flex-start}.ob-model-card-title{font-size:.95rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.ob-model-card-body{font-size:.85rem;line-height:1.5;color:var(--color-text-secondary);margin:0}.ob-no-rollover{display:flex;gap:var(--spacing-sm);align-items:flex-start;padding:var(--spacing-md);background:#facc1514;border:1px solid rgba(250,204,21,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem;line-height:1.5;color:var(--color-text-primary)}.ob-no-rollover svg{color:#eab308;flex-shrink:0;margin-top:1px}.ob-no-rollover strong{color:var(--color-text-primary);font-weight:600}.ob-example-table{margin:0 0 var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ob-example-caption{font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm);text-align:left}.ob-example-row{display:flex;justify-content:space-between;padding:6px var(--spacing-xs);font-size:.875rem;font-variant-numeric:tabular-nums;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-subtle, rgba(255,255,255,.05))}.ob-example-row:last-child{border-bottom:none}.ob-example-header{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.ob-example-income{color:var(--color-success);font-weight:500}.ob-example-scheduled{color:var(--color-accent-primary)}.ob-example-total{font-weight:600;color:var(--color-text-primary);border-top:1px solid var(--color-border);margin-top:var(--spacing-xs);padding-top:var(--spacing-sm)}@media(max-width:600px){.ob-model-cards{grid-template-columns:1fr}}.ob-expense-list{max-height:360px;overflow-y:auto;margin-bottom:var(--spacing-sm)}.ob-expense-row{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.ob-expense-row:last-child{border-bottom:none}.ob-expense-main{display:flex;align-items:center;gap:var(--spacing-sm)}.ob-expense-name{flex:1.5;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.9rem;min-height:40px}.ob-expense-amount{flex:.8;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.9rem;min-height:40px}.ob-expense-name:focus,.ob-expense-amount:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2563eb1a}.ob-expense-flags{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs);padding-left:2px}@media(max-width:600px){.ob-expense-main{flex-wrap:wrap}.ob-expense-name,.ob-expense-amount{flex:1 1 100%}.ob-expense-flags{flex-wrap:wrap}}.ob-ef-card{padding:var(--spacing-md);background:#2563eb0f;border:1px solid rgba(37,99,235,.2);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.ob-ef-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.ob-ef-name{font-weight:600;color:var(--color-text-primary);flex:1}.ob-ef-tag{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);background:var(--color-accent-primary);color:var(--color-text-inverse);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.ob-ef-body{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5}.ob-gnm-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.ob-gnm-item{padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.ob-gnm-row{display:flex;gap:var(--spacing-sm);align-items:flex-end}.ob-gnm-kind{flex:0 0 auto;min-width:140px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.9rem;min-height:44px}.ob-gnm-name{flex:1;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.95rem;min-height:44px}.ob-gnm-name:focus,.ob-gnm-kind:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2563eb1a}@media(max-width:600px){.ob-gnm-row{flex-direction:column;align-items:stretch}.ob-gnm-kind,.ob-gnm-name{width:100%}}.ob-seq-icon-header{text-align:center;margin-bottom:var(--spacing-md)}.ob-seq-connect-card{padding:var(--spacing-lg);background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--spacing-lg)}.ob-seq-connect-card .btn{margin-top:var(--spacing-md)}.ob-seq-token-group{margin-top:var(--spacing-lg)}.ob-seq-token-row{display:flex;gap:var(--spacing-sm);align-items:center;margin-top:var(--spacing-sm)}.ob-seq-token-row input{flex:1;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.95rem;min-height:44px}.ob-seq-token-row input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2563eb1a}.ob-seq-success{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#22c55e14;border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);color:var(--color-success);font-weight:500;font-size:.95rem}.ob-seq-accounts{margin-bottom:var(--spacing-lg)}.ob-seq-accounts h4{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.95rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.ob-seq-account-list{list-style:none;padding:0;margin:0}.ob-seq-account-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);font-size:.9rem}.ob-seq-account-name{font-weight:500;color:var(--color-text-primary)}.ob-seq-account-balance{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.ob-seq-webhook{margin-bottom:var(--spacing-lg)}.ob-seq-webhook label{display:block;font-weight:500;font-size:.9rem;margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.ob-seq-webhook-row{display:flex;gap:var(--spacing-sm);align-items:center}.ob-seq-webhook-row input{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:.8rem;font-family:monospace;min-height:40px}.ob-seq-webhook-hint{font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.ob-seq-accounts-loading,.ob-seq-accounts-empty{padding:var(--spacing-md);text-align:center;color:var(--color-text-muted);font-size:.875rem}.ob-seq-error{padding:var(--spacing-sm) var(--spacing-md);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);margin-top:var(--spacing-sm);font-size:.85rem;color:var(--color-danger);display:flex;align-items:center;gap:var(--spacing-xs)}.ob-seq-setup-note{font-size:.875rem;color:var(--color-text-secondary);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);text-align:center}.ob-seq-skip-btn{font-size:.95rem}@media(max-width:600px){.ob-seq-token-row{flex-direction:column}.ob-seq-token-row input{width:100%}.ob-seq-webhook-row{flex-direction:column}.ob-seq-webhook-row input{width:100%}}.ob-finish-table{margin:var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.ob-finish-table-header{display:flex;justify-content:space-between;padding:var(--spacing-xs);font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xs)}.ob-finish-table-row{display:flex;justify-content:space-between;padding:6px var(--spacing-xs);font-size:.875rem;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.ob-finish-table-more{padding:var(--spacing-sm) var(--spacing-xs) 0;font-size:.8rem;color:var(--color-text-muted);font-style:italic}.onboarding-overlay{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);padding:var(--spacing-md)}.onboarding-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:620px;width:100%;padding:var(--spacing-2xl);position:relative}.onboarding-step-container{position:relative;overflow:hidden}.ob-step{animation:ob-step-enter .25s ease-out}.ob-step.ob-step-back{animation:ob-step-enter-back .25s ease-out}@keyframes ob-step-enter{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes ob-step-enter-back{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@media(prefers-reduced-motion:reduce){.ob-step,.ob-step.ob-step-back{animation:ob-step-fade .15s ease-out}@keyframes ob-step-fade{0%{opacity:0}to{opacity:1}}}.onboarding-skip-all{background:none;color:var(--color-text-muted);font-size:.8rem;text-decoration:underline;padding:var(--spacing-xs);margin-top:var(--spacing-lg);display:block;text-align:center;width:100%;cursor:pointer;border:none}.onboarding-skip-all:hover{color:var(--color-text-secondary)}.onboarding-skip-all:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media(max-width:600px){.onboarding-card{padding:var(--spacing-lg);border-radius:var(--radius-lg)}}.guided-tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:none}.guided-tour-backdrop{position:fixed;top:var(--spotlight-top);left:var(--spotlight-left);width:var(--spotlight-width);height:var(--spotlight-height);border-radius:8px;box-shadow:0 0 0 9999px #00000080;transition:all .3s ease;z-index:10001;pointer-events:auto}.guided-tour-tooltip{position:fixed;z-index:10002;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-lg);width:300px;max-width:calc(100vw - 16px);pointer-events:auto;animation:tour-tooltip-enter .2s ease-out}@keyframes tour-tooltip-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.guided-tour-title{font-size:.95rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.guided-tour-description{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.guided-tour-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-md);gap:var(--spacing-sm)}.guided-tour-counter{font-size:.75rem;color:var(--color-text-muted)}.guided-tour-buttons{display:flex;gap:var(--spacing-xs)}.btn-ghost{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);font-size:.8rem;border-radius:var(--radius-sm)}.btn-ghost:hover{color:var(--color-text-secondary);background:var(--color-bg-tertiary)}.btn-ghost:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}@media(max-width:600px){.guided-tour-tooltip{width:calc(100vw - 16px);max-width:90vw}}.premium-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;border:1px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);min-height:200px}.premium-gate-icon{color:var(--color-primary);margin-bottom:var(--spacing-md)}.premium-gate-title{margin:0 0 var(--spacing-sm) 0;font-size:1.25rem;color:var(--color-text)}.premium-gate-description{margin:0 0 var(--spacing-lg) 0;color:var(--color-text-secondary);max-width:400px;line-height:1.5}.premium-gate-plans{display:flex;gap:var(--spacing-md);flex-wrap:wrap;justify-content:center}.premium-gate-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm) var(--spacing-xl);min-width:140px;background:var(--color-primary);color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease}.premium-gate-btn:hover{background:var(--color-primary-hover, #1d4ed8);transform:translateY(-1px)}.premium-gate-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.premium-gate-btn--monthly{background:transparent;color:var(--color-primary)}.premium-gate-btn--monthly:hover{background:#2563eb14}.premium-gate-btn--annual{padding-top:calc(var(--spacing-sm) + 6px)}.premium-gate-btn-label{font-size:.9rem;font-weight:600}.premium-gate-btn-price{font-size:1.05rem;font-weight:700}.premium-gate-btn-badge{position:absolute;top:-10px;right:8px;background:var(--color-success, #16a34a);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.02em}.premium-gate--expired{border-color:var(--color-warning);background:var(--color-warning-bg, rgba(217, 119, 6, .05))}.premium-gate-icon--expired{color:var(--color-warning)}.toast-container{position:fixed;bottom:var(--spacing-lg);left:var(--spacing-lg);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-sm)}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);min-width:250px;max-width:400px;animation:slideIn .2s ease-out;box-shadow:var(--shadow-lg)}.toast-info{background:var(--color-accent-primary);color:#fff}.toast-success{background:var(--color-success);color:#fff}.toast-error{background:var(--color-danger);color:#fff}.toast-message{flex:1;font-size:.85rem}.toast-action{background:#fff3;border:1px solid rgba(255,255,255,.4);color:inherit;cursor:pointer;font-size:.8rem;font-weight:600;padding:2px 10px;border-radius:var(--radius-full);white-space:nowrap;transition:background .15s}.toast-action:hover{background:#ffffff59}.toast-close{background:none;border:none;color:inherit;opacity:.7;cursor:pointer;font-size:1.2rem;padding:0;line-height:1}.toast-close:hover{opacity:1}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--color-bg-secondary);border-top:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:var(--spacing-md) var(--spacing-xl);animation:slideUp .3s ease-out}.cookie-consent-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:var(--spacing-lg)}.cookie-consent-content p{margin:0;font-size:.85rem;color:var(--color-text-secondary);line-height:1.5}.cookie-consent-content a{color:var(--color-accent-primary);text-decoration:underline}.cookie-consent-content .btn{white-space:nowrap;flex-shrink:0}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.cookie-consent-content{flex-direction:column;text-align:center;gap:var(--spacing-md)}}.dashboard-grid{display:flex;flex-direction:column;gap:var(--spacing-xl)}.charts-row{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}.lists-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.list-col{display:flex;flex-direction:column;gap:var(--spacing-md)}.list-col h3{font-size:1.1rem;color:var(--color-text-secondary);margin:0;padding-left:var(--spacing-xs)}@media(max-width:1200px){.lists-row{grid-template-columns:1fr}}
