:root{--dashboard-sidebar-width: 240px}html,body{overflow-x:hidden;max-width:100vw}.app-layout{display:flex;min-height:100vh;background:var(--dv-bg);width:100%;max-width:100%;overflow-x:hidden}.sidebar{width:var(--dashboard-sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--dv-border);z-index:500}.main-content{flex:1;margin-left:var(--dashboard-sidebar-width);width:calc(100% - var(--dashboard-sidebar-width));padding:var(--space-8);box-sizing:border-box;min-width:0}.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:var(--space-8);width:100%}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--dv-border);z-index:400;padding:0 var(--space-4);align-items:center;justify-content:space-between}.mobile-menu-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--dv-text)}.mobile-logo{display:flex;align-items:center;gap:var(--space-2);font-weight:700;font-size:1.25rem}.mobile-logo .logo-img{width:32px;height:32px}.mobile-profile-btn .avatar-small{width:36px;height:36px;border-radius:50%;background:var(--dv-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.sidebar{width:var(--dashboard-sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--dv-border);display:flex;flex-direction:column;z-index:500;transition:transform var(--transition)}.sidebar-header{padding:var(--space-6);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--dv-border)}.brand{display:flex;align-items:center;gap:var(--space-3);font-weight:700;font-size:1.25rem;color:var(--dv-text)}.brand-logo{width:36px;height:36px}.sidebar-close{display:none;width:32px;height:32px;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--dv-text-secondary)}.sidebar-close:hover{background:var(--dv-bg-elevated)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-4)}.nav-section{margin-bottom:var(--space-6)}.nav-label{display:block;padding:var(--space-2) var(--space-3);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--dv-text-muted);margin-bottom:var(--space-2)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-lg);color:var(--dv-text-secondary);font-size:.9375rem;font-weight:500;margin-bottom:var(--space-1);transition:all var(--transition-fast)}.nav-link:hover{background:var(--dv-bg-elevated);color:var(--dv-text)}.nav-link-button{width:100%;border:none;background:none;cursor:pointer;text-align:left;font:inherit;color:inherit}.nav-link.active{background:linear-gradient(135deg,var(--dv-accent),var(--dv-accent-hover));color:#fff;box-shadow:0 4px 12px #6d5df54d}.nav-icon{flex-shrink:0}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--dv-border)}.user-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);margin-bottom:var(--space-3);border-radius:var(--radius-lg);background:var(--dv-bg-elevated)}.user-card .avatar{width:40px;height:40px;border-radius:50%;background:var(--dv-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.user-name{font-weight:600;font-size:.9375rem;color:var(--dv-text)}.user-plan{font-size:.75rem;color:var(--dv-text-muted)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8125rem}.w-full{width:100%}.sidebar-overlay.active{opacity:1}.top-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);gap:var(--space-4)}.page-title{font-size:1.875rem;font-weight:800;color:var(--dv-text);margin-bottom:var(--space-1)}.page-subtitle{color:var(--dv-text-secondary);font-size:1rem}.header-right{display:flex;align-items:center;gap:var(--space-3)}.wallet-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--dv-bg-elevated);border:1px solid var(--dv-border);border-radius:var(--radius-full);font-weight:600;color:var(--dv-success)}.trust-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,#0e7c861a,#6d5df51a);border:1px solid rgba(14,124,134,.2);border-radius:var(--radius-xl);margin-bottom:var(--space-8);font-size:.9375rem;color:var(--dv-text)}.dashboard-hero{margin-bottom:var(--space-12)}.hero-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-8)}.glass-card-hero{background:#ffffff73;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:0 8px 32px #0000000f;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}body.dark .glass-card-hero{background:#1e293b80;border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px #0003}.hero-card{display:flex;flex-direction:column;gap:var(--space-2)}.hero-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--dv-text-muted)}.hero-value{font-size:1.75rem;font-weight:800;color:var(--dv-text);line-height:1.2}.hero-value-row{display:flex;align-items:baseline;gap:var(--space-3);flex-wrap:wrap}.hero-trend{font-size:.8125rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full)}.hero-trend.positive{background:#10b98126;color:var(--dv-success)}.hero-trend.negative{background:#ef44441f;color:var(--dv-danger)}.hero-suffix{font-size:.75rem;color:var(--dv-text-muted)}.hero-card-streak .hero-streak-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.hero-streak-icon{display:inline-flex;color:#f59e0b;animation:flame-pulse 2s ease-in-out infinite}.hero-streak-icon svg{width:28px;height:28px}.hero-streak-num{font-size:1.75rem}.hero-milestone{margin-bottom:var(--space-6)}.milestone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.milestone-target{font-size:.875rem;font-weight:700;color:var(--dv-accent)}.milestone-bar-wrap{height:10px;background:#0000000f;border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}body.dark .milestone-bar-wrap{background:#ffffff14}.milestone-bar-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--dv-primary),var(--dv-accent));transition:width .8s cubic-bezier(.16,1,.3,1)}.hero-card-streak.streak-paused{filter:grayscale(40%);box-shadow:0 0 0 1px #94a3b833}.hero-card-streak.streak-paused .hero-streak-icon{animation:none;opacity:.9}.strategy-control-card{margin-top:var(--space-6);padding:var(--space-5)}.strategy-control-title{margin:0 0 var(--space-4) 0;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--dv-text-muted)}.strategy-control-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--dv-border)}.strategy-control-row:last-of-type{border-bottom:none}.strategy-control-label-wrap{display:flex;flex-direction:column;gap:2px}.strategy-control-label{font-size:.9375rem;font-weight:600;color:var(--dv-text)}.strategy-control-sublabel{font-size:.75rem;color:var(--dv-text-muted)}.ios-switch-wrap{position:relative;display:inline-block;width:51px;height:31px;flex-shrink:0}.ios-switch-input{opacity:0;width:0;height:0}.ios-switch-track{position:absolute;cursor:pointer;inset:0;background:var(--dv-border);border-radius:31px;transition:background .25s ease,box-shadow .2s ease}.ios-switch-track:after{content:"";position:absolute;height:27px;width:27px;left:2px;top:2px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;transition:transform .25s cubic-bezier(.4,0,.2,1)}.ios-switch-input:checked+.ios-switch-track{background:var(--dv-success)}.ios-switch-input:checked+.ios-switch-track:after{transform:translate(20px)}.ios-switch-input:focus-visible+.ios-switch-track{outline:2px solid var(--dv-primary);outline-offset:2px}.payments-status-indicator{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.8125rem;font-weight:600}.payments-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.payments-status-active .payments-status-dot{background:var(--dv-success);animation:status-pulse 2s ease-in-out infinite}.payments-status-paused .payments-status-dot{background:var(--dv-danger);animation:none}.payments-status-active{color:var(--dv-success)}.payments-status-paused{color:var(--dv-danger)}@keyframes status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.strategy-control-payments .quick-action-sidebar-btn{min-width:100px}.quick-actions-row{display:flex;flex-wrap:wrap;gap:var(--space-3)}.quick-action-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-weight:600;font-size:.9375rem;border:none;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}.quick-action-btn:hover{transform:translateY(-2px)}.quick-action-btn.btn-primary{background:linear-gradient(135deg,var(--dv-accent),var(--dv-accent-hover));color:#fff;box-shadow:0 4px 14px #6d5df559}.quick-action-btn.btn-primary:hover{box-shadow:0 6px 20px #6d5df573}.quick-actions-sidebar{display:flex;flex-direction:column;gap:var(--space-2)}.quick-action-sidebar-btn{width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;transition:transform var(--transition),box-shadow var(--transition)}.quick-action-sidebar-btn:hover{transform:translateY(-2px);box-shadow:var(--dv-shadow-md)}.section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--dv-text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:var(--space-10)}.grid-main{display:flex;flex-direction:column;gap:var(--space-12);width:100%;min-width:0}.grid-sidebar{display:flex;flex-direction:column;gap:var(--space-6)}.payoff-tracker{padding:var(--space-6)}.tracker-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6)}.card-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-1)}.card-subtitle{color:var(--dv-text-secondary);font-size:.9375rem}.streak-badge{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#fb923c26,#fb923c0d);border:1px solid rgba(251,146,60,.3);border-radius:var(--radius-lg)}.streak-icon{font-size:1.5rem}.streak-info{display:flex;flex-direction:column;align-items:flex-start}.streak-number{font-size:1.5rem;font-weight:800;color:var(--dv-text);line-height:1}.streak-label{font-size:.75rem;color:var(--dv-text-secondary);text-transform:uppercase;letter-spacing:.05em}.progress-section{margin-bottom:var(--space-6)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);font-size:.9375rem;font-weight:600}.progress-text{margin-top:var(--space-2);font-size:.875rem;color:var(--dv-text-secondary)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--dv-border)}.stat-item{display:flex;flex-direction:column;gap:var(--space-1)}.stat-label{font-size:.875rem;color:var(--dv-text-secondary)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--dv-success)}.stat-suffix{font-size:.75rem;color:var(--dv-text-muted)}.vaults-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);width:100%}.vaults-section .section-header{width:100%;align-self:stretch}.section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.section-title{font-size:1.5rem;font-weight:700}.section-subtitle{color:var(--dv-text-secondary);font-size:.9375rem;margin-top:var(--space-1)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);background:var(--dv-bg-card);border:2px dashed var(--dv-border);border-radius:var(--radius-xl);width:100%;max-width:480px}.empty-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2)}.vault-card{background:var(--dv-bg-card);border:1px solid var(--dv-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition);position:relative;overflow:hidden}.vault-card:hover,.vault-card-modern:hover{transform:translateY(-4px);box-shadow:var(--dv-shadow-lg),0 0 0 2px var(--dv-accent),0 0 20px #6d5df533;border-color:var(--dv-accent);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.vault-card:before,.vault-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--dv-primary),var(--dv-accent));opacity:0;transition:opacity var(--transition)}.vault-card:hover:before,.vault-card-modern:hover:before{opacity:1}.vault-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.vault-name{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-1)}.vault-type{font-size:.875rem;color:var(--dv-text-secondary)}.vault-menu-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--dv-text-secondary);opacity:0;transition:all var(--transition-fast)}.vault-balance{font-size:1.875rem;font-weight:800;margin-bottom:var(--space-4);background:linear-gradient(135deg,var(--dv-text),var(--dv-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.vault-progress{margin-bottom:var(--space-4)}.vault-meta{display:flex;justify-content:space-between;font-size:.875rem;color:var(--dv-text-secondary)}.vault-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--dv-border)}.vault-actions .btn{flex:1}.premium-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-3)}.premium-title-group{display:flex;align-items:center;gap:var(--space-3)}.widget{padding:var(--space-5)}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.widget-title{font-size:1rem;font-weight:600}.weather-icon{font-size:1.5rem}.weather-text{color:var(--dv-text-secondary);font-size:.9375rem;line-height:1.6}.payouts-list{display:flex;flex-direction:column;gap:var(--space-3)}.payout-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);background:var(--dv-bg-elevated);border-radius:var(--radius-lg);font-size:.9375rem}.payout-item.empty{color:var(--dv-text-muted);font-style:italic;background:transparent;padding:var(--space-4);text-align:center;justify-content:center}.connection-list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.connection-item{display:flex;align-items:center;gap:var(--space-3)}.connection-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--dv-bg-elevated)}.connection-icon.plaid{color:#00d64f}.connection-icon.stripe{color:#635bff}.connection-info{display:flex;flex-direction:column;flex:1}.connection-name{font-weight:600;font-size:.9375rem}.connection-status{font-size:.75rem;color:var(--dv-text-muted)}.connection-status.connected{color:var(--dv-success)}.connection-actions{display:flex;flex-direction:column;gap:var(--space-2)}.tip-widget{text-align:center}.tip-icon{font-size:2rem;margin-bottom:var(--space-3)}.tip-text{font-size:.9375rem;color:var(--dv-text-secondary);line-height:1.6}.fab{position:fixed;bottom:var(--space-6);right:var(--space-6);width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--dv-accent),var(--dv-accent-hover));color:#fff;box-shadow:0 4px 20px #6d5df566;display:flex;align-items:center;justify-content:center;z-index:300;transition:transform var(--transition)}.fab:active{transform:scale(.95)}.coach-fab{position:fixed;bottom:var(--space-6);right:calc(var(--space-6) + 72px);width:56px;height:56px;border-radius:50%;background:var(--dv-bg-elevated);border:2px solid var(--dv-border);display:flex;align-items:center;justify-content:center;z-index:300;cursor:pointer;transition:all var(--transition)}.coach-fab:hover{transform:translateY(-2px);box-shadow:var(--dv-shadow-md);border-color:var(--dv-accent)}.coach-avatar{font-size:1.5rem}.coach-pulse{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid var(--dv-accent);animation:pulse-ring 2s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(1);opacity:1}to{transform:scale(1.5);opacity:0}}.modal{display:none;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center;padding:var(--space-4);opacity:0;transition:opacity var(--transition)}.modal.active{display:flex;opacity:1}.modal-content{background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--dv-border);border-radius:var(--radius-2xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--dv-shadow-lg);transform:translateY(20px);transition:transform var(--transition)}.modal.active .modal-content{transform:translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--dv-border)}.modal-header h2{font-size:1.25rem;font-weight:700}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:1.5rem;color:var(--dv-text-secondary);line-height:1}.modal-close:hover{background:var(--dv-bg-elevated);color:var(--dv-text)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--dv-border);background:var(--dv-bg-elevated);border-radius:0 0 var(--radius-2xl) var(--radius-2xl)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--dv-text);margin-bottom:var(--space-2)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-hint{display:block;margin-top:var(--space-1);font-size:.75rem;color:var(--dv-text-muted)}.toast{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%) translateY(100px);background:var(--dv-text);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:.9375rem;font-weight:500;box-shadow:var(--dv-shadow-lg);z-index:2000;opacity:0;transition:all var(--transition)}.toast.show{transform:translate(-50%) translateY(0);opacity:1}@media(max-width:1024px){.dashboard-grid,.hero-cards{grid-template-columns:1fr}.grid-sidebar{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}}@media(max-width:640px){.quick-actions-row{flex-direction:column}.quick-action-btn{width:100%;justify-content:center}}@media(max-width:480px){.vaults-grid,.grid-sidebar{grid-template-columns:1fr}.trust-banner{font-size:.875rem}.modal-content{margin:var(--space-2);max-height:calc(100vh - var(--space-4))}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--dv-bg-elevated) 25%,var(--dv-border) 50%,var(--dv-bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}.vaults-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6);width:100%}.vaults-grid.hidden{display:none}.vault-card{position:relative;padding:var(--space-6);transition:all var(--transition);border:1px solid transparent}.vault-card:hover{transform:translateY(-4px);border-color:var(--dv-accent)}.vault-debt{border-left:4px solid var(--dv-danger)}.vault-savings{border-left:4px solid var(--dv-success)}.vault-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.vault-title-wrapper{flex:1}.vault-type-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.vault-name{font-size:1.25rem;font-weight:700;color:var(--dv-text);margin:0}.vault-menu-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--dv-text-secondary);opacity:0;transition:all var(--transition-fast)}.vault-dropdown{position:absolute;top:100%;right:0;width:200px;background:var(--dv-bg-elevated);border:1px solid var(--dv-border);border-radius:var(--radius-lg);box-shadow:var(--dv-shadow-lg);padding:var(--space-2);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:100}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius);font-size:.9375rem;color:var(--dv-text);transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--dv-bg)}.dropdown-item.danger{color:var(--dv-danger)}.dropdown-divider{height:1px;background:var(--dv-border);margin:var(--space-2) 0}.vault-balance-section{margin-bottom:var(--space-4)}.vault-balance-main{display:flex;align-items:flex-start;gap:2px}.vault-currency{font-size:1.5rem;font-weight:700;color:var(--dv-text);line-height:1}.vault-amount{font-size:2.5rem;font-weight:800;color:var(--dv-text);line-height:1;background:linear-gradient(135deg,var(--dv-text),var(--dv-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.vault-target{font-size:.875rem;color:var(--dv-text-secondary);margin-top:var(--space-1)}.vault-progress-section{margin-bottom:var(--space-5)}.vault-progress{height:8px;margin-bottom:var(--space-2)}.vault-progress-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--dv-text-muted)}.vault-debt-section{background:#ef44440d;border:1px solid rgba(239,68,68,.1);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.creditor-info{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.creditor-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--dv-text-muted)}.creditor-name{font-weight:600;color:var(--dv-text)}.billpay-status{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--dv-success)}.billpay-status .status-dot{width:8px;height:8px;background:var(--dv-success);border-radius:50%;animation:pulse 2s infinite}.link-creditor-btn.locked{opacity:.6;cursor:not-allowed}.vault-automation-section{margin-bottom:var(--space-4);padding:var(--space-4);background:var(--dv-bg-elevated);border-radius:var(--radius-lg)}.automation-toggle{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.automation-checkbox{display:none}.toggle-slider{position:relative;width:44px;height:24px;background:var(--dv-border);border-radius:var(--radius-full);transition:background var(--transition-fast);flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--dv-shadow-sm)}.automation-checkbox:checked+.toggle-slider{background:var(--dv-success)}.automation-checkbox:checked+.toggle-slider:after{transform:translate(20px)}.toggle-label{display:flex;flex-direction:column;gap:2px}.toggle-title{font-size:.9375rem;font-weight:600;color:var(--dv-text)}.toggle-value{font-size:.75rem;color:var(--dv-text-muted)}.vault-actions-row{display:flex;gap:var(--space-3)}.vault-actions-row .btn{flex:1;justify-content:center}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);background:var(--dv-bg-card);border:2px dashed var(--dv-border);border-radius:var(--radius-xl);width:100%;max-width:520px;transition:opacity .3s ease,transform .3s ease}.empty-state.hidden{display:none!important}.empty-state-welcome .empty-state-icon-wrap{width:96px;height:96px;margin:0 auto var(--space-6);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6d5df51f,#0e7c8614);border-radius:50%;color:var(--dv-accent)}.empty-state-welcome .empty-state-icon{width:48px;height:48px}.empty-state-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-3);color:var(--dv-text)}.empty-state-text{color:var(--dv-text-secondary);max-width:400px;margin:0 auto var(--space-8);line-height:1.6;font-size:.9375rem}.btn-cta-empty{padding:var(--space-4) var(--space-8);font-size:1rem;font-weight:700;box-shadow:0 4px 20px #6d5df559;transition:transform var(--transition),box-shadow var(--transition)}.btn-cta-empty:hover{transform:translateY(-3px);box-shadow:0 8px 28px #6d5df566}.empty-icon{width:80px;height:80px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:var(--dv-bg-elevated);border-radius:50%;color:var(--dv-text-muted)}.empty-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2);color:var(--dv-text)}.empty-text{color:var(--dv-text-secondary);max-width:400px;margin:0 auto var(--space-6)}.sidebar-nav .nav-link{transition:background .2s ease,color .2s ease,transform .2s ease}.main-content{animation:dashboardFadeIn .4s ease}@keyframes dashboardFadeIn{0%{opacity:0}to{opacity:1}}.creditor-connect-section{margin:16px 0;padding:12px;background:var(--dv-bg-elevated);border-radius:var(--radius-lg);border:1px dashed var(--dv-border)}.btn-connect-creditor{width:100%;padding:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:var(--radius);font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all var(--transition)}.btn-connect-creditor:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.btn-connect-creditor.btn-locked{background:var(--dv-border);cursor:not-allowed;opacity:.7}.upgrade-hint{display:block;text-align:center;font-size:.75rem;color:var(--dv-warning);margin-top:6px}.vault-mode-toggle-section{padding:12px 16px;border-bottom:1px solid var(--dv-border);background:var(--dv-bg-elevated)}.toggle-row{display:flex;align-items:center;justify-content:space-between}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-weight:600;font-size:.9rem}.toggle-status{font-size:.8rem;color:var(--dv-text-muted)}.toggle-status.active{color:var(--dv-success)}.hero-glass-card{background:#ffffff0d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #1f26875e;transition:all .3s ease-in-out}.hero-glass-card:hover{background:#ffffff1a;transform:translateY(-5px);border:1px solid rgba(255,255,255,.2)}:root{--sidebar-width: 280px;--dashboard-sidebar-width: 240px;--header-height: 64px;--dv-bg: #f5f7fa;--dv-card: #ffffff;--dv-text: #0f172a;--dv-subtext: #475569;--dv-primary: #0E7C86;--dv-primary-dark: #0A5F64;--dv-purple: #6d5df5;--dv-accent: #6d5df5;--dv-accent-hover: #5a4be0;--dv-border: rgba(0,0,0,.08);--dv-bg-elevated: rgba(0,0,0,.02);--dv-bg-card: rgba(255,255,255,.9);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--transition: .25s ease;--transition-fast: .15s ease;--dv-shadow-sm: 0 4px 14px rgba(0,0,0,.05);--dv-shadow-md: 0 6px 22px rgba(0,0,0,.08);--dv-shadow-lg: 0 14px 40px rgba(0,0,0,.14)}body.dark{--dv-bg: #0D1117;--dv-card: #1A1F27;--dv-text: #E6ECF4;--dv-subtext: #A7B1C2;--dv-primary: #0BB3C8;--dv-primary-dark: #0892A3;--dv-purple: #7b6df8;--dv-border: rgba(255,255,255,.08);--dv-bg-elevated: rgba(255,255,255,.05);--dv-bg-card: rgba(26,31,39,.95);--dv-shadow-sm: 0 4px 18px rgba(0,0,0,.25);--dv-shadow-md: 0 8px 28px rgba(0,0,0,.35);--dv-shadow-lg: 0 20px 55px rgba(0,0,0,.45)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--dv-bg);color:var(--dv-text);-webkit-tap-highlight-color:transparent;width:100%;overflow-x:hidden}.hidden{display:none!important}.app-layout{display:flex;min-height:100vh;width:100%;max-width:100%;overflow-x:hidden;background:var(--dv-bg)}.sidebar-glass{width:var(--dashboard-sidebar-width);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;gap:32px;padding:32px 22px;background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--dv-border);box-shadow:var(--dv-shadow-sm);z-index:500;transition:transform var(--transition)}body.dark .sidebar-glass{background:#1a1f27d9;border-right:1px solid rgba(255,255,255,.05)}.dashboard-main{flex:1;margin-left:var(--sidebar-width);padding:50px 40px;width:calc(100% - var(--sidebar-width));min-height:100vh;max-width:none}.sidebar-header{display:flex;align-items:center;gap:12px;padding-bottom:20px;border-bottom:1px solid var(--dv-border)}.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.4rem;color:var(--dv-text);text-decoration:none}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-label{display:block;padding:8px 12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--dv-subtext);opacity:.7;margin-bottom:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-lg);text-decoration:none;color:var(--dv-subtext);font-size:.96rem;font-weight:500;transition:all var(--transition);margin-bottom:4px}.sidebar-link:hover{background:var(--dv-bg-elevated);transform:translate(3px);color:var(--dv-text)}.sidebar-link.active{background:var(--dv-purple);color:#fff;box-shadow:0 4px 12px #6d5df54d}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid var(--dv-border)}.user-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-lg);background:var(--dv-bg-elevated);margin-bottom:12px}.user-card .avatar{width:40px;height:40px;border-radius:50%;background:var(--dv-purple);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.user-info{display:flex;flex-direction:column;overflow:hidden}.user-name{font-weight:600;font-size:.95rem;color:var(--dv-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-plan{font-size:.8rem;color:var(--dv-subtext)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border:none;background:transparent;color:var(--dv-subtext);font-size:.9rem;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.logout-btn:hover{background:#dc26261a;color:#dc2626}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:34px;gap:16px;flex-wrap:wrap}.welcome-title{font-size:2.1rem;font-weight:800;margin:0;line-height:1.2}.page-subtitle{color:var(--dv-subtext);font-size:1rem;margin-top:6px}.header-right{display:flex;align-items:center;gap:16px}.wallet-badge{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--dv-bg-card);border:1px solid var(--dv-border);border-radius:var(--radius-full);font-weight:700;color:var(--dv-primary);box-shadow:var(--dv-shadow-sm)}.avatar-circle{width:44px;height:44px;border-radius:50%;background:var(--dv-purple);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;box-shadow:var(--dv-shadow-sm);cursor:pointer;transition:transform var(--transition)}.avatar-circle:hover{transform:scale(1.05)}.dashboard-grid{display:grid;grid-template-columns:1fr 400px;gap:32px;width:100%;align-items:start}.grid-main{display:flex;flex-direction:column;gap:28px;min-width:0}.grid-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:32px}.card-float{background:var(--dv-card);padding:28px;border-radius:var(--radius-xl);box-shadow:var(--dv-shadow-md);border:1px solid var(--dv-border);transition:transform .25s ease,box-shadow .25s ease}.card-float:hover{transform:translateY(-2px);box-shadow:var(--dv-shadow-lg)}.dashboard-summary-card{padding:20px 28px}.dashboard-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:center}.dashboard-summary-item{display:flex;flex-direction:column;gap:4px}.dashboard-summary-label{font-size:.8125rem;font-weight:600;color:var(--dv-subtext);text-transform:uppercase;letter-spacing:.02em}.dashboard-summary-value{font-size:1.5rem;font-weight:700;color:var(--dv-text)}.summary-total-saved .dashboard-summary-value{color:var(--dv-success)}.summary-debt-remaining .dashboard-summary-value{color:var(--dv-danger)}@media(max-width:640px){.dashboard-summary-grid{grid-template-columns:1fr;gap:16px}}.payoff-tracker-card{display:grid;grid-template-columns:1fr auto auto;gap:32px;align-items:center;padding:28px}.payoff-tracker-title{margin:0 0 20px;font-size:1.25rem;font-weight:700;grid-column:1 / -1}.payoff-tracker-progress-block{min-width:200px}.payoff-tracker-progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.9rem;color:var(--dv-subtext)}.payoff-tracker-pct{font-weight:700;color:var(--dv-primary);font-size:1.1rem}.payoff-tracker-progress-bar{height:12px;background:#00000014;border-radius:20px;overflow:hidden}body.dark .payoff-tracker-progress-bar{background:#ffffff1a}.payoff-tracker-progress-fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--dv-primary),var(--dv-primary-dark));transition:width .6s ease}.payoff-tracker-subtext{margin:10px 0 0;font-size:.85rem}.payoff-timeline-card{display:block;grid-template-columns:unset}.payoff-timeline-card.hidden{display:none}.payoff-timeline-hero{margin:12px 0}.payoff-timeline-label{display:block;font-size:.9rem;color:var(--dv-subtext)}.payoff-timeline-date{font-size:1.35rem;font-weight:700;color:var(--dv-primary)}.payoff-timeline-list{list-style:none;padding:0;margin:12px 0 0}.payoff-timeline-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--dv-border);font-size:.9rem}.payoff-timeline-item:last-child{border-bottom:none}.payoff-timeline-vault-name{font-weight:500}.payoff-timeline-vault-date{color:var(--dv-subtext)}.payoff-timeline-item-no-date .payoff-timeline-vault-date{font-style:italic;font-weight:400}.payoff-timeline-empty{margin:12px 0 0;font-size:.9rem;color:var(--dv-subtext)}.notifications-list{max-height:240px;overflow-y:auto}.notification-item{padding:10px 0;border-bottom:1px solid var(--dv-border);font-size:.9rem}.notification-item:last-child{border-bottom:none}.notification-item.read{opacity:.8}.notification-item-title{font-weight:600;color:var(--dv-text)}.notification-item-body{margin-top:4px;color:var(--dv-subtext);font-size:.85rem}.notification-item-time{margin-top:4px;font-size:.75rem;color:var(--dv-subtext)}.notification-item-action{display:inline-block;margin-top:6px;font-size:.85rem;font-weight:600;color:var(--dv-primary);text-decoration:none}.notification-item-action:hover{text-decoration:underline}.notification-item.empty{font-weight:400;color:var(--dv-subtext)}.btn-notification-clear{font-size:.75rem;font-weight:500;color:var(--dv-primary);background:none;border:none;cursor:pointer;padding:2px 6px}.btn-notification-clear:hover{text-decoration:underline}.deposit-schedule-label{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:.85rem}.deposit-schedule-label .label{color:var(--dv-subtext)}.deposit-schedule-label .value{font-weight:500}.payoff-tracker-streak-block{display:flex;align-items:center;gap:14px;padding:16px 24px;background:#fb923c1f;border-radius:var(--radius-lg);border:1px solid rgba(251,146,60,.25)}.payoff-tracker-flame{font-size:2.2rem;line-height:1;animation:flame-pulse 2s ease-in-out infinite}@keyframes flame-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.payoff-tracker-streak-info{display:flex;flex-direction:column}.payoff-tracker-streak-label{font-size:.8rem;color:var(--dv-subtext);text-transform:uppercase;letter-spacing:.05em}.payoff-tracker-streak-num{font-size:1.8rem;font-weight:800;color:var(--dv-text)}.payoff-tracker-interest-block{display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding:16px 24px;background:#10b9811a;border-radius:var(--radius-lg);border:1px solid rgba(16,185,129,.25)}.payoff-tracker-interest-label{font-size:.8rem;color:var(--dv-subtext)}.payoff-tracker-interest-value{font-size:1.8rem;font-weight:800;color:#059669}body.dark .payoff-tracker-interest-value{color:#34d399}.payoff-tracker-interest-suffix{font-size:.75rem;color:var(--dv-subtext)}.vaults-section{display:flex;flex-direction:column;gap:24px}.section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.section-title{font-size:1.5rem;font-weight:700;margin:0}.section-subtitle{color:var(--dv-subtext);font-size:.95rem;margin-top:4px}.vaults-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;width:100%}.vault-card{background:var(--dv-card);border:1px solid var(--dv-border);border-radius:var(--radius-xl);padding:24px;transition:all var(--transition);position:relative;overflow:hidden}.vault-card:hover{transform:translateY(-4px);box-shadow:var(--dv-shadow-lg);border-color:var(--dv-purple)}.vault-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--dv-primary),var(--dv-purple));opacity:0;transition:opacity var(--transition)}.vault-card:hover:before{opacity:1}.vault-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.vault-title-group{flex:1}.vault-type-badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--dv-bg-elevated);color:var(--dv-subtext);margin-bottom:8px}.vault-name{font-size:1.2rem;font-weight:700;margin:0;color:var(--dv-text)}.vault-balance{font-size:2rem;font-weight:800;margin:16px 0;background:linear-gradient(135deg,var(--dv-text),var(--dv-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.vault-progress-container{background:#00000014;border-radius:20px;height:10px;margin:16px 0;overflow:hidden}body.dark .vault-progress-container{background:#ffffff1a}.vault-progress-fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--dv-primary),var(--dv-purple));transition:width .6s ease}.vault-meta{display:flex;justify-content:space-between;font-size:.875rem;color:var(--dv-subtext);margin-top:12px}.vault-menu-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:none;border:none;color:var(--dv-subtext);cursor:pointer;opacity:0;transition:all var(--transition-fast)}.vault-card:hover .vault-menu-btn{opacity:1}.vault-menu-btn:hover{background:var(--dv-bg-elevated);color:var(--dv-text)}.vault-dropdown{position:absolute;top:40px;right:0;width:180px;background:var(--dv-card);border:1px solid var(--dv-border);border-radius:var(--radius-lg);box-shadow:var(--dv-shadow-lg);padding:8px 0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:100}.vault-dropdown button{width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:.9rem;color:var(--dv-text);cursor:pointer;transition:background var(--transition-fast)}.vault-dropdown button:hover{background:var(--dv-bg-elevated)}.vault-dropdown button.danger{color:#dc2626}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-lg);font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition);border:none;text-decoration:none}.btn-primary{background:var(--dv-purple);color:#fff;box-shadow:0 4px 12px #6d5df54d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6d5df566;background:var(--dv-accent-hover)}.btn-secondary{background:var(--dv-bg-elevated);color:var(--dv-text);border:1px solid var(--dv-border)}.btn-secondary:hover{background:var(--dv-bg);transform:translateY(-1px)}.trust-banner{display:flex;align-items:center;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#0e7c8614,#6d5df514);border:1px solid rgba(14,124,134,.2);border-radius:var(--radius-xl);margin-bottom:32px;font-size:.95rem;color:var(--dv-text)}.trust-banner svg{color:var(--dv-primary);flex-shrink:0}.empty-state{text-align:center;padding:60px 24px;background:var(--dv-card);border:2px dashed var(--dv-border);border-radius:var(--radius-xl)}.empty-icon{width:80px;height:80px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;background:var(--dv-bg-elevated);border-radius:50%;color:var(--dv-subtext);font-size:2rem}.empty-title{font-size:1.25rem;font-weight:600;margin-bottom:8px}.empty-text{color:var(--dv-subtext);max-width:400px;margin:0 auto 24px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--dv-bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--dv-border);z-index:400;padding:0 16px;align-items:center;justify-content:space-between}.hamburger{display:none;position:fixed;top:18px;left:18px;font-size:1.8rem;font-weight:700;cursor:pointer;z-index:600;width:40px;height:40px;align-items:center;justify-content:center;background:var(--dv-card);border-radius:var(--radius);box-shadow:var(--dv-shadow-sm);border:1px solid var(--dv-border)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:450;opacity:0;transition:opacity var(--transition)}.sidebar-overlay.active{display:block;opacity:1}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr;gap:24px}.grid-sidebar{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;position:static}}@media(max-width:768px){.hamburger,.mobile-header{display:flex}.sidebar-glass{transform:translate(-100%);width:280px;z-index:500}.sidebar-glass.open{transform:translate(0)}.dashboard-main{margin-left:0;width:100%;padding:80px 20px 20px}.welcome-title{font-size:1.5rem}.payoff-tracker-card{grid-template-columns:1fr;gap:20px}.payoff-tracker-streak-block,.payoff-tracker-interest-block{align-items:flex-start}.vaults-grid{grid-template-columns:1fr}.vault-menu-btn{opacity:1}}@media(max-width:480px){.dashboard-main{padding:80px 16px 16px}.card-float{padding:20px}.section-header{flex-direction:column;align-items:stretch}.btn{width:100%}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.modal-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:#0f172a80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .28s cubic-bezier(.16,1,.3,1);z-index:10000}body.dark .modal-overlay{background:#0000008c}.modal-overlay.active{display:flex;opacity:1;pointer-events:auto}.modal-overlay.center{padding:var(--space-4, 1rem)}.modal-card,.modal-card.glass-morphism{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);width:100%;max-width:440px;padding:var(--space-8, 2rem);border-radius:var(--radius-xl, 1.25rem);opacity:0;transform:scale(.96) translateY(16px);transition:opacity .28s,transform .28s cubic-bezier(.16,1,.3,1);position:relative}.modal-overlay.active .modal-card,.modal-overlay.active .modal-card.glass-morphism{opacity:1;transform:scale(1) translateY(0)}.modal-content.billpay-modal-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-xl);padding:var(--space-8);max-width:440px;width:100%}.modal-drawer{position:fixed;top:0;right:-420px;width:420px;max-width:100vw;height:100%;padding:var(--space-8);background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--glass-border);box-shadow:-8px 0 32px #00000026;opacity:0;transition:right .35s ease,opacity .25s ease;z-index:11000;overflow-y:auto}.modal-drawer.active{right:0;opacity:1}.modal-drawer-inner{position:relative;width:100%;min-height:100%}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;background:none;border:none;color:var(--dv-text-muted);cursor:pointer;transition:color .2s,background .2s;z-index:2;border-radius:var(--radius)}.modal-close:hover{color:var(--dv-text);background:var(--dv-bg-elevated)}.modal-title{font-size:1.35rem;font-weight:700;color:var(--dv-text);margin:0 0 var(--space-6) 0;padding-right:2rem}.modal-row{margin-bottom:var(--space-4)}.modal-row label,.modal-card label,.modal-drawer label,.modal-content label{display:block;font-size:.8125rem;font-weight:600;color:var(--dv-text-secondary);margin-bottom:var(--space-2)}.modal-card input:not([type=hidden]),.modal-card select,.modal-card textarea,.modal-drawer input:not([type=hidden]),.modal-drawer select,.modal-drawer textarea,.modal-input,.modal-content .modal-input,.modal-content input[type=number],.modal-content select{width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--dv-border);background:var(--dv-bg-elevated);color:var(--dv-text);font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.modal-card input:focus,.modal-card select:focus,.modal-card textarea:focus,.modal-drawer input:focus,.modal-drawer select:focus,.modal-drawer textarea:focus,.modal-input:focus,.modal-content .modal-input:focus{outline:none;border-color:var(--dv-primary);box-shadow:0 0 0 3px #0d948826}body.dark .modal-card input,body.dark .modal-card select,body.dark .modal-card textarea,body.dark .modal-drawer input,body.dark .modal-drawer select,body.dark .modal-drawer textarea{background:var(--dv-bg-elevated);border-color:#ffffff1a}.modal-subtext{font-size:.8125rem;color:var(--dv-text-muted);margin:var(--space-2) 0 var(--space-4) 0}.modal-balance{font-size:1.125rem;font-weight:700;color:var(--dv-text);margin-bottom:var(--space-4)}.modal-btn-primary,.modal-card .modal-btn-primary,.modal-drawer .modal-btn-primary,.modal-card .btn-primary,.modal-content .btn-primary{background:linear-gradient(135deg,var(--dv-primary),var(--dv-primary-dark));color:var(--dv-text-inverse);padding:var(--space-3) var(--space-5);font-size:.9375rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:transform .2s,box-shadow .2s}.modal-btn-primary:hover,.modal-card .modal-btn-primary:hover,.modal-drawer .modal-btn-primary:hover,.modal-card .btn-primary:hover,.modal-content .btn-primary:hover{box-shadow:0 4px 14px #0d948859;transform:translateY(-1px)}.modal-btn-secondary,.modal-card .modal-btn-secondary,.modal-drawer .modal-btn-secondary,.modal-card .btn-secondary,.modal-content .btn-secondary{background:transparent;color:var(--dv-text-muted);padding:var(--space-3) var(--space-4);font-size:.9375rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:color .2s,background .2s}.modal-btn-secondary:hover,.modal-card .modal-btn-secondary:hover,.modal-drawer .modal-btn-secondary:hover,.modal-card .btn-secondary:hover,.modal-content .btn-secondary:hover{color:var(--dv-text);background:var(--dv-bg-elevated)}.modal-btns{margin-top:var(--space-6);display:flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-3)}.modal-btn{padding:var(--space-3) var(--space-5);font-size:.9375rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s}.modal-btn-danger{background:var(--dv-danger);color:#fff}.modal-btn-danger:hover{filter:brightness(1.1)}.modal-card .btn.full,.modal-content .full-width{width:100%;justify-content:center}#vaultCoachModal .modal-card{max-width:520px;max-height:82vh;display:flex;flex-direction:column}#chatContainer{flex:1;min-height:220px;max-height:380px;margin-top:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);background:var(--dv-bg-elevated);border:1px solid var(--dv-border);overflow-y:auto}.coach-msg.user{background:var(--dv-primary);color:var(--dv-text-inverse)}.coach-msg.ai{background:var(--dv-bg-elevated);border:1px solid var(--dv-border)}.coach-input{border-radius:var(--radius-full);border:1px solid var(--dv-border);padding:var(--space-3) var(--space-4)}.coach-input:focus{border-color:var(--dv-primary)}.coach-send-btn{background:linear-gradient(135deg,var(--dv-primary),var(--dv-primary-dark));color:#fff;border-radius:50%}.upgrade-popup{background:var(--glass-bg);border:1px solid var(--dv-accent);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow)}@media(max-width:768px){.modal-drawer{width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-card{max-width:100%}}.coach-btn,#vaultCoachBtn{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:.6rem;padding:.8rem 1.35rem;border-radius:999px;border:none;background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;font-family:Inter,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 15px 30px #0f766e73;transition:transform .15s ease,box-shadow .2s ease;z-index:15000;touch-action:manipulation}.coach-btn:hover{transform:translateY(-3px);box-shadow:0 18px 35px #0f766e8c}.coach-btn:active{transform:scale(.97)}#vaultCoachModal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:13000}#vaultCoachModal.active{display:flex;pointer-events:auto}#vaultCoachModal:not(.active){pointer-events:none}#vaultCoachModal .coach-card{width:100%;max-width:520px;max-height:82vh;background:#fff;border-radius:1.25rem;padding:1.4rem 1.25rem;display:flex;flex-direction:column;position:relative;box-shadow:0 25px 50px #0f172a73;animation:coach-fade-up .25s ease-out;z-index:13001}body.dark #vaultCoachModal .coach-card{background:#1e293b;color:#e2e8f0}@keyframes coach-fade-up{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.coach-close,[data-close=vaultCoachModal]{position:absolute;top:12px;right:14px;background:transparent;border:none;font-size:1.4rem;cursor:pointer;color:#9ca3af;transition:color .2s ease}.coach-close:hover,[data-close=vaultCoachModal]:hover{color:#111827}.coach-header{margin-bottom:.4rem;padding-left:2.5rem;position:relative}.coach-header:before{content:"🤖";position:absolute;left:0;top:0;font-size:1.7rem}.coach-title{margin:0;font-size:1.15rem;font-weight:700}.coach-subtitle{margin:.2rem 0 0;font-size:.85rem;color:#6b7280}#chatContainer{flex:1;min-height:220px;max-height:380px;margin-top:.75rem;padding:.85rem;border-radius:.9rem;background:#f3f4f6;overflow-y:auto;display:flex;flex-direction:column;gap:.55rem}body.dark #chatContainer{background:#0f172a}.coach-msg{max-width:80%;padding:.65rem .9rem;border-radius:1rem;font-size:.9rem;line-height:1.4}.coach-msg.user{margin-left:auto;background:#0f766e;color:#ecfeff;border-bottom-right-radius:.25rem}.coach-msg.ai{margin-right:auto;background:#fff;color:#111827;border:1px solid #e5e7eb;border-bottom-left-radius:.25rem}body.dark .coach-msg.ai{background:#1e293b;border-color:#334155}.coach-input-row{margin-top:1rem;display:flex;align-items:center;gap:.65rem}.coach-input{flex:1;border-radius:999px;border:1px solid #d1d5db;padding:.6rem 1rem;font-size:.9rem;outline:none}.coach-input:focus{border-color:#0f766e;box-shadow:0 0 0 2px #0f766e40}.coach-send-btn{width:42px;height:42px;border-radius:999px;border:none;cursor:pointer;background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;display:flex;align-items:center;justify-content:center}@media(max-width:640px){.coach-btn,#vaultCoachBtn{bottom:20px;right:16px;padding:.65rem 1.1rem}#vaultCoachModal .coach-card{max-width:100%;height:82vh}#chatContainer{max-height:none}}#vaultCoachModal[style*="display: block"],#vaultCoachModal[style*="display: flex"],#vaultCoachModal.active{display:flex!important;pointer-events:auto!important;opacity:1!important}@media(max-width:768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.sidebar-overlay.active{display:block}.sidebar-close{display:flex}.main-content{margin-left:0;width:100%;max-width:100%;padding:calc(var(--header-height, 64px) + 16px) 16px 16px;box-sizing:border-box}.dashboard-main{margin-left:0;width:100%;max-width:100%}.top-header{flex-direction:column}.page-title{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start}.section-header .btn{width:100%}.form-row,.vaults-grid{grid-template-columns:1fr}.vault-menu-btn{opacity:1}.vault-amount{font-size:2rem}.coach-fab{right:var(--space-6);bottom:calc(var(--space-6) + 72px)}}@media(max-width:1024px){.dashboard-main{max-width:100%}.vault-grid-2col{grid-template-columns:1fr!important}}@media(max-width:880px){.sidebar-glass{transform:translate(-260px);opacity:0;pointer-events:none}.sidebar-glass.open{transform:translate(0);opacity:1;pointer-events:auto;z-index:2000}.hamburger{display:block}.dashboard-main{margin-left:0;width:100%;padding:30px 20px}.dashboard-header{flex-direction:column;align-items:flex-start;gap:12px}}@media(max-width:600px){html,body{width:100%;overflow-x:hidden}body,body *{transition:none!important}.welcome-title{font-size:1.5rem}.vault-card{padding:18px;margin-bottom:16px;width:100%}.vault-title{font-size:1rem}.vault-type{font-size:.8rem}.vault-header-row{display:flex;justify-content:space-between;align-items:flex-start}.vault-menu-btn{font-size:1.1rem;padding:6px}.vault-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px}.vault-actions button{width:100%;padding:14px;font-size:1rem;border-radius:12px}#newVaultBtn{width:100%;position:static!important;transform:none!important}.weather-container{flex-direction:column;text-align:center;padding:20px}.weather-icon{font-size:2rem}.vault-forecast-card{padding:18px;margin:16px 0}.interest-saved-hero .value-highlight{font-size:1.8rem}.floating-nudge{left:16px;right:80px;bottom:20px;max-width:none}button,.btn-primary,.btn-secondary,.vault-menu-btn,.scheduler-btn,.creditor-link-btn,.link-creditor-btn{min-height:44px}}#vaultContainer{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem;padding:1rem 0}@media(max-width:768px){#vaultContainer{grid-template-columns:1fr;gap:1rem}}.vault-skeleton{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);height:400px;animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.vault-card-modern{position:relative;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;transition:all .3s ease;animation:fadeInUp .5s ease forwards;opacity:0;transform:translateY(20px)}.vault-card-modern:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0003,var(--shadow-glow)}.vault-card-modern.vault-card-paused{position:relative;filter:grayscale(50%);box-shadow:0 0 0 1px #94a3b840,0 4px 14px #0000000f}body.dark .vault-card-modern.vault-card-paused{box-shadow:0 0 0 1px #94a3b826,0 4px 14px #0003}.vault-paused-badge{position:absolute;top:var(--space-3, .75rem);right:var(--space-3, .75rem);padding:.25rem .6rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dv-danger, #ef4444);background:#ef444426;border:1px solid rgba(239,68,68,.35);border-radius:var(--radius-full, 9999px);z-index:2;pointer-events:none}.vault-control-glass{background:#fff6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-md, .75rem);padding:.75rem 1rem;border:1px solid rgba(255,255,255,.5)}body.dark .vault-control-glass{background:#ffffff0f;border-color:#ffffff14}.vault-pause-resume-row{margin-top:.5rem}.vault-pause-resume-row .vault-pause-resume-btn{width:100%;min-width:100px}.vault-short-pause-row{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.vault-short-pause-row .paused-until-label{font-size:.875rem;color:var(--dv-muted)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.vault-card-header{display:flex;align-items:flex-start;gap:1rem}.vault-icon-wrapper{position:relative;width:48px;height:48px;background:var(--bg-secondary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.status-dot{position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg-primary)}.status-dot.debt{background:var(--danger)}.status-dot.savings{background:var(--success)}.vault-title-section{flex:1;min-width:0}.vault-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vault-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.vault-type-badge.debt{background:#ef44441a;color:var(--danger)}.vault-type-badge.savings{background:#22c55e1a;color:var(--success)}.vault-badges-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.vault-status-badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:var(--radius-full)}.vault-status-badge.vault-status-on-track{background:#10b98126;color:var(--success)}.vault-status-badge.vault-status-behind{background:#f59e0b26;color:#f59e0b}.vault-menu-wrapper{position:relative}.vault-menu-btn{width:36px;height:36px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.vault-menu-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.vault-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:.5rem;min-width:180px;box-shadow:0 10px 40px #0003;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:100}.vault-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.vault-dropdown button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}.vault-dropdown button:hover{background:var(--bg-secondary);color:var(--text-primary)}.vault-dropdown button.danger{color:var(--danger)}.vault-dropdown button.danger:hover{background:#ef44441a}.vault-progress-section{background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem}.progress-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem}.progress-amount{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.progress-target{font-size:.875rem;color:var(--text-muted)}.progress-bar-container{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:.5rem}.progress-bar{height:100%;border-radius:var(--radius-full);transition:width .6s ease}.progress-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-muted)}.streak-badge-small{background:#f59e0b1a;color:#f59e0b;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.vault-content{display:flex;flex-direction:column;gap:1rem}.creditor-info{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.creditor-info .label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.creditor-info .value{font-weight:600;color:var(--text-primary)}.liability-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.liability-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.liability-item .label{font-size:.75rem;color:var(--text-muted)}.liability-item .value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.liability-item .value.debt{color:var(--danger)}.due-date{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.payoff-progress{margin-top:.5rem}.payoff-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:.5rem}.payoff-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--success));border-radius:var(--radius-full);transition:width .6s ease}.payoff-text{font-size:.8rem;color:var(--text-muted)}.interest-saved{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:linear-gradient(135deg,#6366f11a,#a855f71a);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-primary)}.sparkle{font-size:1rem}.balance-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.balance-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.balance-item .label{font-size:.75rem;color:var(--text-muted)}.balance-item .value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.automation-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.toggle-info{display:flex;flex-direction:column;gap:.25rem}.toggle-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.toggle-status{font-size:.75rem;color:var(--text-muted)}.toggle-status.active{color:var(--success)}.toggle-switch{position:relative;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-tertiary);border-radius:24px;transition:.3s}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}input:checked+.toggle-slider{background:linear-gradient(135deg,var(--primary),var(--secondary))}input:checked+.toggle-slider:before{transform:translate(24px)}input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.daily-amount-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.daily-amount-row .label{font-size:.875rem;color:var(--text-secondary)}.daily-amount-row .amount{font-weight:600;color:var(--primary)}.creditor-link-section{display:flex;flex-direction:column;gap:.5rem}.btn-locked{opacity:.6;cursor:not-allowed}.upgrade-hint{font-size:.75rem;color:var(--text-muted);text-align:center}.vault-actions-row{display:flex;gap:.75rem;margin-top:.5rem}.vault-actions-row .btn{flex:1}.vault-actions-row .btn-ghost{flex:0 0 auto;width:44px;padding:0}.btn-full{width:100%;justify-content:center}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;max-width:400px;margin:0 auto}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid var(--glass-border)}.history-item:last-child{border-bottom:none}.history-action{font-size:.875rem;color:var(--text-secondary)}.history-amount{font-weight:600;color:var(--text-primary)}.history-date{font-size:.75rem;color:var(--text-muted)}.history-empty,.history-error{text-align:center;padding:2rem;color:var(--text-muted)}@media(max-width:480px){.vault-card-modern{padding:1rem}.vault-icon-wrapper{width:40px;height:40px;font-size:1.25rem}.vault-title,.progress-amount{font-size:1rem}.liability-grid,.balance-grid{grid-template-columns:1fr}.vault-actions-row{flex-wrap:wrap}.vault-actions-row .btn{flex:1 1 calc(50% - .375rem)}}
