.dashboard{display:flex;flex-direction:column;gap:var(--space-8);width:100%;max-width:100%;overflow-x:hidden}.safe-to-spend{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);position:relative;overflow:hidden;text-align:center;box-shadow:var(--shadow-md)}.safe-to-spend__glow{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:300px;height:200px;background:radial-gradient(ellipse,rgba(99,102,241,.12),transparent 70%);pointer-events:none}.safe-to-spend__label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--font-semibold);letter-spacing:.02em;margin-bottom:var(--space-3)}.onboarding-card{background:var(--gradient-card);border:1px solid var(--color-accent);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.onboarding-card:before{content:"";position:absolute;inset:0;background:var(--color-accent-glow);opacity:.15;pointer-events:none;z-index:0}.onboarding-card>*{position:relative;z-index:1}.onboarding-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.onboarding-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 4px;color:var(--color-text-primary)}.onboarding-card__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.5}.onboarding-card__dismiss{background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-full);color:var(--color-text-tertiary);opacity:.6;flex-shrink:0;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.onboarding-card__dismiss:hover{opacity:1;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.onboarding-card__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.onboarding-step{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-primary);transition:background var(--transition-fast)}.onboarding-step:hover{background:var(--color-bg-tertiary)}.onboarding-step__icon{color:var(--color-text-tertiary);flex-shrink:0}.onboarding-step__icon--done{color:var(--color-success)}.onboarding-step__label{flex:1 1;font-size:var(--text-sm);font-weight:var(--font-medium)}.onboarding-step__arrow{color:var(--color-text-tertiary);flex-shrink:0}@media (max-width:480px){.onboarding-card{padding:var(--space-4)}.onboarding-card__title{font-size:var(--text-base)}.onboarding-card__subtitle{font-size:var(--text-xs)}}.safe-to-spend__help-btn{position:absolute;top:var(--space-3);right:var(--space-3);background:none;border:none;padding:6px;border-radius:var(--radius-full);color:var(--color-text-tertiary);cursor:pointer;opacity:.6;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;z-index:1}.safe-to-spend__help-btn:hover{opacity:1;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.help-modal .modal__body{padding:0}.help-list{list-style:none;margin:0;padding:0}.help-list__item{border-bottom:1px solid var(--color-border)}.help-list__item:last-child{border-bottom:none}.help-list__row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);background:none;border:none;cursor:pointer;text-align:left;text-decoration:none;transition:background var(--transition-fast)}.help-list__row:hover{background:var(--color-bg-tertiary)}.help-list__row--action{color:var(--color-accent)}.help-list__chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast)}.help-list__chevron--open{transform:rotate(180deg)}.help-list__body{padding:0 var(--space-5) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}.help-list__body p{margin:0 0 var(--space-2)}.help-list__body p:last-child{margin-bottom:0}.help-list__inline-link{display:inline-flex;align-items:center;gap:4px;color:var(--color-accent);text-decoration:none;font-weight:var(--font-medium)}.help-list__inline-link:hover{text-decoration:underline}.safe-to-spend__cycle-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;margin-bottom:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-tertiary);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-decoration:none;white-space:nowrap;transition:all var(--transition-fast)}.safe-to-spend__cycle-badge:hover{border-color:var(--color-accent);color:var(--color-text-primary);background:var(--color-bg-card-hover)}.safe-to-spend__cycle-badge-dot{opacity:.5}.safe-to-spend__cycle-badge-type{color:var(--color-text-tertiary)}.safe-to-spend__cycle-badge-arrow{opacity:.6}@media (max-width:480px){.safe-to-spend__cycle-badge{font-size:10px;padding:3px 8px;gap:4px}}.safe-to-spend__hide-toggle{background:none;border:none;cursor:pointer;margin-left:var(--space-2);padding:6px;border-radius:var(--radius-full);color:var(--color-text-tertiary);vertical-align:middle;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.safe-to-spend__hide-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.safe-to-spend__amount{font-size:var(--text-4xl);font-weight:var(--font-bold);letter-spacing:-.03em;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-4)}.safe-to-spend__amount--placeholder{opacity:.45;margin-bottom:var(--space-3)}.safe-to-spend__empty{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);max-width:320px;margin-left:auto;margin-right:auto;line-height:1.5}.safe-to-spend__cta{display:inline-flex;align-items:center;gap:6px;padding:var(--space-2) var(--space-4);background:var(--color-accent);color:white;font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-fast)}.safe-to-spend__cta:hover{filter:brightness(1.08);transform:translateY(-1px)}.safe-to-spend__cta:focus-visible,.safe-to-spend__cycle-badge:focus-visible,.safe-to-spend__help-btn:focus-visible,.safe-to-spend__hide-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.safe-to-spend__subtitle{font-size:var(--text-base);color:var(--color-text-secondary)}.safe-to-spend__meta{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.safe-to-spend__meta>span[aria-hidden=true]{color:var(--color-text-tertiary);opacity:.7}.safe-to-spend--danger{border-color:var(--color-danger-bg);background:linear-gradient(145deg,var(--color-bg-card),rgba(239,68,68,.04))}.safe-to-spend--danger .safe-to-spend__glow{background:radial-gradient(ellipse,rgba(239,68,68,.12),transparent 70%)}.safe-to-spend--danger .safe-to-spend__amount{background:var(--gradient-danger);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cycle-progress{margin-top:var(--space-6)}.cycle-progress--compact{margin-top:0}.cycle-progress--compact .cycle-progress__bar{margin-bottom:0}.cycle-progress__bar{width:100%;height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.cycle-progress__fill{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full);transition:width var(--transition-slow)}.cycle-progress__fill--danger{background:var(--gradient-danger)}.cycle-progress__labels{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--color-text-secondary)}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media (max-width:1280px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-stats{grid-template-columns:1fr 1fr;gap:var(--space-3)}}.dashboard-stat{background:var(--color-bg-card);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:all var(--transition-fast);min-width:0}.dashboard-stat:hover{border-color:var(--color-border-hover);transform:translateY(-1px)}.dashboard-stat--link{cursor:pointer}.dashboard-stat__head{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);min-width:0}.dashboard-stat__label{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-secondary);letter-spacing:.04em;text-transform:uppercase;min-width:0}.dashboard-stat__hint{width:20px;height:20px;border-radius:5px}.dashboard-stat__eye,.dashboard-stat__hint{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-stat__eye{background:none;border:none;cursor:pointer;padding:4px;margin:-4px;border-radius:var(--radius-sm);color:var(--color-text-tertiary);opacity:.5;transition:all var(--transition-fast)}.dashboard-stat__eye:hover{opacity:1;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.dashboard-stat__eye:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;opacity:1}.dashboard-stat__value{font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:-.02em;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-stat__trend{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-tertiary);white-space:nowrap;align-self:flex-start}.dashboard-stat__trend--up{color:var(--color-success)}.dashboard-stat__trend--down{color:var(--color-danger)}.dashboard-stat__meta,.dashboard-stat__trend--neutral{color:var(--color-text-tertiary)}.dashboard-stat__meta{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap;align-self:flex-start}.dashboard-stat__glow{position:absolute;top:-30px;right:-30px;width:80px;height:80px;border-radius:50%;opacity:.12;pointer-events:none}@media (max-width:768px){.dashboard-stat__trend{display:none}}@media (max-width:480px){.dashboard-stat{padding:var(--space-3) var(--space-3);gap:4px}.dashboard-stat__label{font-size:10px;letter-spacing:.05em}.dashboard-stat__value{font-size:var(--text-lg)}.dashboard-stat__hint{width:18px;height:18px;border-radius:4px}.dashboard-stat__meta{font-size:10px}}.dashboard-content{display:grid;grid-template-columns:1fr 340px;align-items:start;gap:var(--space-8)}.dashboard-main,.dashboard-sidebar{display:flex;flex-direction:column;gap:var(--space-8);min-width:0}@media (max-width:1024px){.dashboard-content{display:flex;flex-direction:column;gap:var(--space-8)}.dashboard-content,.dashboard-main,.dashboard-sidebar{width:100%;max-width:100%}}.recent-transactions{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.recent-transactions__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border)}.recent-transactions__title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.recent-transactions__view-all{font-size:var(--text-sm);color:var(--color-accent);font-weight:var(--font-medium);cursor:pointer;transition:opacity var(--transition-fast)}.recent-transactions__view-all:hover{opacity:.8}.recent-transactions__list{padding:var(--space-2)}.quick-shortcuts-panel{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;width:100%;max-width:100%}.quick-shortcuts-panel__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.quick-shortcuts-panel__title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.quick-shortcuts-panel__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);padding:var(--space-4);width:100%;max-width:100%}@media (max-width:1024px){.quick-shortcuts-panel__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2);padding:var(--space-3)}.shortcut-btn{padding:var(--space-2) var(--space-1);min-width:0}.shortcut-btn__icon{width:34px;height:34px}.shortcut-btn__icon svg{width:18px;height:18px}.shortcut-btn__label{font-size:var(--text-sm)}.shortcut-btn__amount{font-size:var(--text-xs)}}@media (max-width:768px){.safe-to-spend{padding:var(--space-5)}}.shortcut-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background:var(--color-bg-tertiary);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.shortcut-btn:hover{border-color:var(--color-border-hover);background:var(--color-bg-card-hover);transform:translateY(-1px)}.shortcut-btn:active{transform:scale(.97)}.shortcut-btn__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--color-accent-glow);color:var(--color-accent)}.shortcut-btn__label{font-weight:var(--font-medium)}.shortcut-btn__amount,.shortcut-btn__label{font-size:var(--text-sm);color:var(--color-text-secondary);width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-widget{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;padding:var(--space-5);width:100%;max-width:100%;margin:0;box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}a.dashboard-widget:hover{border-color:var(--color-border-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.dashboard-stat--link:focus-visible,a.dashboard-widget:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.quick-shortcuts-panel,.recent-transactions{box-shadow:var(--shadow-sm)}.quick-shortcuts-panel,.recent-transactions,.safe-to-spend{margin:0}.category-breakdown__list{display:flex;flex-direction:column;gap:var(--space-4)}.category-breakdown__row{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2);margin:calc(var(--space-2) * -1);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:background var(--transition-fast);cursor:pointer}.category-breakdown__row:hover{background:var(--color-bg-tertiary)}.category-breakdown__row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.category-breakdown__row-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.category-breakdown__name{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);min-width:0}.category-breakdown__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-breakdown__amount{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);white-space:nowrap}.category-breakdown__bar{width:100%;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.category-breakdown__bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base)}.category-breakdown__pct{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:var(--font-medium)}.dashboard-widget__title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.health-signals{display:flex;gap:var(--space-3);flex-wrap:wrap}.health-signal{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);border:1px solid transparent;text-decoration:none;transition:all var(--transition-fast)}.health-signal:hover{filter:brightness(1.1)}.iou-widget:hover{border-color:var(--color-border-hover);background:var(--color-bg-card-hover)}.health-signal--warning{background:var(--color-warning-bg);color:var(--color-warning)}.health-signal--danger{background:var(--color-danger-bg);color:var(--color-danger)}.health-signal--success{background:var(--color-success-bg);color:var(--color-success)}.health-signal--info{background:var(--color-info-bg);color:var(--color-info)}.week-pips{display:flex;gap:6px;justify-content:space-between;align-items:stretch}.week-pip{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-2) 4px;border-radius:var(--radius-md);text-decoration:none;color:inherit;min-height:48px;cursor:default;transition:background var(--transition-fast),transform .15s ease}.week-pip--interactive{cursor:pointer}.week-pip--interactive:hover{background:var(--color-bg-tertiary)}.week-pip--interactive:hover .week-pip__dot{transform:scale(1.15)}.week-pip--interactive:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.week-pip__dot{width:100%;max-width:32px;aspect-ratio:1;border-radius:50%;transition:transform .15s ease}.week-pip__label{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:var(--font-medium)}.week-legend{display:flex;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap}.week-legend__item{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--color-text-secondary)}.week-legend__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}@media (max-width:1024px){.dashboard-content,.dashboard-main,.dashboard-sidebar{display:contents}.dashboard-section--onboarding{order:0}.dashboard-section--health{order:1}.dashboard-section--hero{order:2}.dashboard-section--budget{order:3}.dashboard-section--upcoming{order:4}.dashboard-section--stats{order:5}.dashboard-section--week{order:6}.dashboard-section--categories{order:7}.dashboard-section--quick{order:8}.dashboard-section--recent{order:9}.dashboard-section--forecast{order:10}.dashboard-section--savings{order:11}.dashboard-section--iou{order:12}}