:root{--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-base: 1.5;--line-height-tight: 1.3;--font-size-xs: .7rem;--font-size-sm: .85rem;--font-size-base: .9rem;--font-size-md: 1rem;--font-size-lg: 1.1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--primary-color: #0066cc;--primary-hover: #0052a3;--success-color: #28a745;--success-hover: #218838;--danger-color: #dc3545;--danger-hover: #c82333;--warning-color: #ffc107;--info-color: #17a2b8;--priority-high-bg: #fee2e2;--priority-high-text: #dc2626;--priority-medium-bg: #fef3c7;--priority-medium-text: #d97706;--priority-low-bg: #d1fae5;--priority-low-text: #059669;--status-active-bg: rgba(16, 185, 129, .1);--status-active-text: #10b981;--status-inactive-bg: rgba(156, 163, 175, .15);--status-inactive-text: #6b7280;--status-completed-bg: rgba(40, 167, 69, .1);--status-completed-border: #28a745;--category-purple-bg: #e9d5ff;--category-purple-text: #7c3aed;--heatmap-empty: #ebedf0;--heatmap-level-1: #9be9a8;--heatmap-level-2: #40c463;--heatmap-level-3: #30a14e;--heatmap-level-4: #216e39;--overlay-dark: rgba(0, 0, 0, .8);--overlay-light: rgba(0, 0, 0, .1);--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #212529;--text-secondary: #6c757d;--border-color: #dee2e6;--border-radius-sm: 4px;--border-radius-md: 6px;--border-radius-lg: 8px;--border-radius-xl: 12px;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .2);--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 10;--z-sticky: 100;--z-modal: 1000;--z-tooltip: 1001;--breakpoint-mobile: 768px;--breakpoint-tablet: 900px;font-family:var(--font-family);line-height:var(--line-height-base);font-weight:var(--font-weight-normal);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #404040;--text-primary: #ffffff;--text-secondary: #a0a0a0;--border-color: #404040;--shadow: 0 2px 4px rgba(0, 0, 0, .3);--shadow-hover: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--heatmap-empty: #161b22;--heatmap-level-1: #0e4429;--heatmap-level-2: #006d32;--heatmap-level-3: #26a641;--heatmap-level-4: #39d353}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background-color:var(--bg-secondary);color:var(--text-primary);transition:background-color var(--transition-slow),color var(--transition-slow);min-height:100vh}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}ul,ol{list-style:none}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.hidden{display:none!important}.auth-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.auth-modal-backdrop{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1002}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#4285f4;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-modal-content{background:var(--bg-primary);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-hover);max-width:400px;width:90%;position:relative;z-index:1001}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xl) var(--space-xl) 0}.auth-modal-header h3{margin:0;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:var(--font-size-2xl);color:var(--text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:background-color var(--transition-base)}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.auth-modal-body{padding:var(--space-lg) var(--space-xl) var(--space-xl);text-align:center}.auth-modal-body p{margin-bottom:var(--space-lg);color:var(--text-secondary)}.auth-modal-body ul{text-align:left;margin:var(--space-lg) 0;padding-left:var(--space-lg)}.auth-modal-body li{color:var(--text-secondary);margin-bottom:var(--space-sm)}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);margin:var(--space-lg) 0}.google-signin-primary{padding:1rem var(--space-xl);font-size:1.125rem;font-weight:var(--font-weight-semibold);border:2px solid #4285F4;background:linear-gradient(to bottom,#fff,#f8f9fa);box-shadow:0 2px 4px #0000001a}.google-signin-btn:hover{border-color:var(--primary-color);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.google-signin-primary:hover{box-shadow:0 4px 12px #4285f44d;transform:translateY(-2px)}.auth-privacy{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.auth-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-md) 0;color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.email-toggle-btn{width:100%;padding:var(--space-md) var(--space-lg);background:transparent;border:2px solid var(--border-color);border-radius:var(--border-radius-lg);color:var(--text-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);cursor:pointer;margin-bottom:var(--space-lg);transition:all var(--transition-base)}.email-toggle-btn:hover{background:var(--bg-secondary);border-color:var(--text-primary)}.email-auth-container{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.email-mode-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-md);justify-content:center}.email-mode-btn{padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base)}.email-mode-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.email-mode-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.auth-form{display:none;flex-direction:column;gap:var(--space-md);margin:var(--space-lg) 0}.auth-form.active{display:flex}.auth-form input{padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);font-size:var(--font-size-md);background:var(--bg-secondary);color:var(--text-primary);transition:border-color var(--transition-base)}.auth-form input:focus{outline:none;border-color:var(--primary-color)}.auth-form button{width:100%}.auth-error{padding:var(--space-sm) var(--space-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--border-radius-md);color:#dc2626;font-size:var(--font-size-sm);text-align:left}#app{min-height:100vh;display:flex;flex-direction:column}.main-grid{flex:1;padding:var(--space-2xl);display:grid;gap:var(--space-2xl);max-width:1600px;margin:0 auto;width:100%;grid-template-areas:"overview overview" "weekly weekly" "subscriptions subscriptions" "daily avoidance" "habits streaks" "trends trends";grid-template-columns:1fr 1fr}.daily-goals{grid-area:daily}.weekly-goals{grid-area:weekly;display:flex;flex-direction:column;gap:.5rem}.habits-stats{grid-area:habits}.streaks-stats{grid-area:streaks}.habit-heatmap-stats{grid-area:trends}.goals-overview{grid-area:overview}.avoidance-card{grid-area:avoidance}.subscription-tracker{grid-area:subscriptions}.card{background-color:var(--bg-primary);border-radius:var(--border-radius-xl);padding:var(--space-xl);box-shadow:var(--shadow);transition:box-shadow var(--transition-slow);border:1px solid var(--border-color)}.card:hover{box-shadow:var(--shadow-hover)}.card.no-hover:hover{box-shadow:var(--shadow)}.card h2{margin-bottom:var(--space-xl);color:var(--text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.card h3{margin-bottom:var(--space-lg);color:var(--text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl)}.card-header h2{margin:0}.day-info,.week-info{display:flex;flex-direction:column;gap:.25rem;text-align:right;align-items:flex-end}.week-navigation{display:flex;gap:.5rem;margin-top:.5rem}.week-nav-btn{min-width:30px!important;height:30px!important;font-size:var(--font-size-md)!important;padding:0!important;border-radius:var(--border-radius-sm)}#current-day,#current-week{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-md)}.current-date,.week-dates{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-normal)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:1px solid transparent;border-radius:var(--border-radius-md);font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn:hover{transform:translateY(-1px)}.btn-primary{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-color)}.btn-secondary:hover{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--text-secondary)}.btn-success{background-color:var(--success-color);color:#fff;border-color:var(--success-color)}.btn-success:hover{background-color:var(--success-hover)}.btn-danger{background-color:var(--danger-color);color:#fff;border-color:var(--danger-color)}.btn-danger:hover{background-color:var(--danger-hover)}.btn-warning{background-color:var(--warning-color);color:#000;border-color:var(--warning-color)}.btn-warning:hover{background-color:#e0a800}.btn-small{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm)}.btn-icon{padding:var(--space-sm);border-radius:var(--border-radius-md);background-color:transparent;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;font-weight:var(--font-weight-semibold)}.btn-icon:hover{background-color:var(--bg-tertiary);transform:translateY(-1px)}.btn-success.btn-icon{background-color:var(--success-color);border-color:var(--success-color);color:#fff}.btn-success.btn-icon:hover{background-color:var(--success-hover);border-color:var(--success-hover)}.btn-danger.btn-icon{background-color:var(--danger-color);border-color:var(--danger-color);color:#fff}.btn-danger.btn-icon:hover{background-color:var(--danger-hover);border-color:var(--danger-hover)}.btn-warning.btn-icon{background-color:var(--warning-color);border-color:var(--warning-color);color:#000}.btn-warning.btn-icon:hover{background-color:#e0a800;border-color:#e0a800}@media (max-width: 900px){.main-grid{grid-template-areas:"overview" "weekly" "daily" "avoidance" "habits" "streaks" "trends" "subscriptions";grid-template-columns:1fr;padding:1rem;gap:1.5rem}}@media (max-width: 768px){.main-grid{padding:1rem;gap:1rem}.card{padding:var(--space-lg);border-radius:var(--border-radius-lg);margin:0;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.card h2{font-size:var(--font-size-lg);margin-bottom:var(--space-lg)}.card-header{flex-direction:column;gap:var(--space-sm);align-items:flex-start;margin-bottom:var(--space-lg)}.day-info,.week-info{align-self:flex-end;text-align:right}.auth-modal-content{margin:1rem;width:calc(100% - 2rem)}}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.header-logo{width:32px;height:32px;margin-right:.75rem;object-fit:contain;display:block}.user-info{display:flex;align-items:center;gap:.5rem}.user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover;display:block}.user-name{font-weight:500;color:var(--text-primary)}.header h1{font-size:1.5rem;color:var(--primary-color);font-weight:600;position:absolute;left:50%;transform:translate(-50%)}@media (max-width: 768px){.header{padding:1rem}.header h1{font-size:1.2rem;position:static;transform:none}.user-name{display:none}}.footer{background-color:var(--bg-primary);border-top:1px solid var(--border-color);box-shadow:0 -2px 4px #0000001a;padding:1.5rem 2rem;margin-top:auto}.footer-content{max-width:1600px;margin:0 auto;display:flex;justify-content:center;align-items:center}.footer-text{color:var(--text-secondary);font-size:1rem;margin:0;text-align:center;display:flex;align-items:center;gap:.75rem}.footer-separator{color:var(--text-secondary);opacity:.5}.footer-link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.footer-link:hover{color:var(--primary-color);text-decoration:underline}@media (max-width: 768px){.footer{padding:1rem}.footer-text{font-size:.85rem}}.priority-legend{display:flex;gap:1rem;padding:.75rem;background-color:var(--bg-secondary);border-radius:6px;margin-bottom:1rem;font-size:.85rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.legend-item .priority-badge{margin-right:0}.weekly-goal-header{display:flex;gap:.75rem;margin-bottom:1.5rem;align-items:stretch}#add-weekly-goal-btn{min-height:48px;padding:.75rem 1.25rem;border-radius:12px}.form-input,.weekly-goal-header input,.weekly-goal-header select{flex:1;width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:border-color .3s ease}.weekly-goal-header select,.weekly-goal-header input[type=date],.weekly-goal-header input[type=number]{flex:0 0 auto;width:auto;min-width:100px}#goal-priority{position:relative;padding-left:.75rem;text-align:center;font-weight:600}#goal-priority::placeholder{font-weight:500;text-align:left}.form-input:focus,.weekly-goal-header input:focus,.weekly-goal-header select:focus{outline:none;border-color:var(--primary-color)}.weekly-goal-sections{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.weekly-goal-section{display:flex;flex-direction:column}.weekly-goal-section h3{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--text-primary);flex-shrink:0}.weekly-goal-section .weekly-goals{display:flex;flex-direction:column;gap:.5rem;max-height:500px;overflow-y:auto;padding-right:.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.weekly-goal-section .weekly-goals::-webkit-scrollbar{width:6px}.weekly-goal-section .weekly-goals::-webkit-scrollbar-track{background:var(--bg-secondary, #f9fafb);border-radius:3px}.weekly-goal-section .weekly-goals::-webkit-scrollbar-thumb{background:var(--border-color, #d1d5db);border-radius:3px;transition:background .2s ease}.weekly-goal-section .weekly-goals::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #9ca3af)}.weekly-goal-section .weekly-goals{scrollbar-width:thin;scrollbar-color:var(--border-color, #d1d5db) var(--bg-secondary, #f9fafb)}.goal-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem;background-color:var(--bg-secondary);border-radius:8px;transition:all .3s ease}.goal-item:hover{background-color:var(--bg-tertiary)}.goal-item.completed,.goal-item.done{background-color:var(--status-completed-bg);border:1px solid var(--status-completed-border)}.goal-item.completed .goal-text,.goal-item.done .goal-text{text-decoration:line-through;opacity:.7}.goal-text{flex:1;font-weight:450;display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:1rem}.goal-text-content{flex:1}.goal-badges{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.goal-actions{display:flex;gap:.5rem;flex-shrink:0}.goal-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.85rem;font-weight:600}.priority-high{background:var(--priority-high-bg);color:var(--priority-high-text)}.priority-medium{background:var(--priority-medium-bg);color:var(--priority-medium-text)}.priority-low{background:var(--priority-low-bg);color:var(--priority-low-text)}.category-badge{background:var(--category-purple-bg);color:var(--category-purple-text);padding:2px 8px;border-radius:4px;font-size:.85rem}.goal-deadline{font-size:.9rem;color:var(--text-secondary);font-weight:700}.goal-item:not(.done) .editable-field{cursor:pointer;position:relative}.goal-item:not(.done) .editable-field:hover:after{content:"Double-click to edit";position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--overlay-dark);color:#fff;padding:4px 8px;border-radius:4px;font-size:.7rem;white-space:nowrap;margin-bottom:4px}.goals-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.goals-overview-header h2{margin:0}.category-controls{display:flex;gap:.5rem;align-items:center}.category-filter{padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .3s ease}.category-filter:focus{outline:none;border-color:var(--primary-color)}.goals-overview-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column-reverse;justify-content:flex-start}.overview-week-group{border-top:1px solid var(--border-color);padding-top:.5rem;margin-top:.5rem}.overview-week-group:first-child{border-top:none;margin-top:0}.overview-week-header{font-weight:600;color:var(--text-primary);font-size:.9rem;margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:center}.overview-week-stats{font-size:.8rem;color:var(--text-secondary)}.overview-goal-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin:.25rem 0;background-color:var(--bg-secondary);border-radius:6px;font-size:1rem}.overview-goal-status{font-weight:600;font-size:.75rem;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.overview-goal-status.done{background-color:var(--status-completed-bg);color:var(--success-color)}.overview-goal-status.pending{background-color:var(--status-inactive-bg);color:var(--text-secondary)}.overview-goal-text{flex:1;color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-weight:450}.overview-goal-item.done .overview-goal-text{text-decoration:line-through;opacity:.7}.avoidance-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.avoidance-input-section{display:flex;gap:.75rem;align-items:center;margin-bottom:1.5rem}.avoidance-input-section input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.avoidance-input-section input:focus{outline:none;border-color:var(--primary-color)}.avoidance-sections{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.avoidance-section h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.avoidance-list,.tackled-list{display:flex;flex-direction:column;gap:.75rem}.avoidance-item,.tackled-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:.75rem;transition:all .2s ease}.avoidance-item:hover,.tackled-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-hover)}.avoidance-text,.tackled-text{flex:1;font-weight:500;color:var(--text-primary);line-height:1.4}.tackled-text{color:var(--success-color)}.avoidance-actions,.tackled-actions{display:flex;gap:.5rem;flex-shrink:0}.no-items{text-align:center;color:var(--text-secondary);font-style:italic;padding:2rem}@media (max-width: 768px){.goals-overview-header{flex-direction:column;align-items:flex-start;gap:1rem}.category-controls{width:100%;flex-wrap:wrap}.category-filter{flex:1;min-width:120px}.weekly-goal-sections{grid-template-columns:1fr;gap:1rem}.weekly-goal-section .weekly-goals{max-height:none;overflow-y:visible}.weekly-goal-header{flex-direction:column;gap:.5rem}.weekly-goal-header input{width:100%;box-sizing:border-box}.goal-item{padding:.5rem;flex-direction:column;gap:.5rem}.goal-text{font-size:.9rem;flex-direction:column;gap:.35rem}.goal-text-content{width:100%}.goal-item .goal-badges{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:.35rem}.goal-item .goal-actions{align-self:center;margin-top:.25rem}.goal-actions{justify-content:center}.overview-goal-item .goal-deadline{font-size:.8rem}.overview-goal-item .category-badge{font-size:.75rem}.overview-goal-item .goal-text-content{font-size:.9rem}.overview-goal-item .goal-badge{font-size:.75rem;padding:1px 6px}.avoidance-input-section{flex-direction:column;align-items:stretch;gap:.5rem}.avoidance-sections{grid-template-columns:1fr;gap:1.5rem}.avoidance-item,.tackled-item{flex-direction:column;gap:.75rem;align-items:stretch}.avoidance-actions,.tackled-actions{align-self:flex-end}}.daily-habits{display:flex;flex-direction:column;gap:1rem}.habit{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;background-color:var(--bg-secondary);pointer-events:none}.habit input,.habit label{pointer-events:auto}.habit-label{display:flex;align-items:center;gap:.5rem;flex:1;cursor:pointer}.habit-name-display{flex:1}.habit .edit-habit-btn{opacity:1}.habit .delete-habit-btn{opacity:0;transition:opacity .2s ease}.habit:hover .delete-habit-btn{opacity:1}.habit input[type=checkbox]{width:20px;height:20px;accent-color:var(--success-color);cursor:pointer}.habit label{font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.habit.completed{background-color:var(--status-completed-bg);border:1px solid var(--status-completed-border)}.habit.completed label{text-decoration:line-through;opacity:.7}.add-habit-section{display:flex;gap:.5rem;align-items:center;padding:.5rem!important;background-color:transparent!important}.add-habit-section input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.add-habit-section button{padding:.5rem 1rem;white-space:nowrap}#add-habit-btn{border-radius:12px}.habits-empty-state{text-align:center;padding:2rem;color:var(--text-secondary)}.habits-empty-state h4{margin-bottom:.5rem;color:var(--text-primary)}.habits-tracker{background-color:var(--bg-secondary);border-radius:8px;padding:1rem;overflow-x:auto}.tracker-header{display:grid;grid-template-columns:100px repeat(7,1fr);gap:.5rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.day-header{text-align:center;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:.5rem .25rem}.habits-rows{display:flex;flex-direction:column;gap:.5rem}.habit-row{display:grid;grid-template-columns:100px repeat(7,1fr);gap:.5rem;align-items:center;padding:.25rem 0;border-radius:6px;transition:background-color .2s ease}.habit-row:hover{background-color:var(--bg-tertiary);padding:.5rem;margin:-.25rem 0}.habit-name{font-weight:600;color:var(--text-primary);margin-left:-1em}.day-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;background-color:var(--bg-primary);border:2px solid var(--border-color);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;-webkit-user-select:none;user-select:none}.day-cell:hover{transform:scale(1.05);box-shadow:var(--shadow)}.day-cell.completed{background-color:var(--success-color);border-color:var(--success-color);color:#fff}.day-cell.completed:before{content:"✓";font-size:.8rem}.day-cell:not(.completed){color:var(--text-secondary)}.day-cell:not(.completed):before{content:"○";font-size:.6rem;opacity:.5}.day-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:var(--text-primary);color:var(--bg-primary);padding:.25rem .5rem;border-radius:4px;font-size:.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10}.day-cell:hover .day-tooltip{opacity:1}.tracker-summary{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-secondary)}.completion-rate{font-weight:600;color:var(--success-color)}.streaks{display:flex;flex-direction:column;gap:.75rem}.streak-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:var(--bg-secondary);border-radius:6px}.streak-info{flex:1}.streak-name{font-weight:500;margin-bottom:.25rem}.streak-stats{display:flex;gap:1rem;font-size:.85rem}.streak-current{font-weight:600;color:var(--primary-color)}.streak-best{color:var(--text-secondary)}.streak-best.is-record{color:var(--success-color);font-weight:600}.heatmap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.heatmap-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.heatmap-subtitle{margin:0;font-size:.85rem;color:var(--text-secondary);font-weight:400}.habit-heatmap{padding:1rem;background-color:var(--bg-secondary);border-radius:8px;overflow-x:auto;width:fit-content}.heatmap-container{display:flex;flex-direction:column;gap:.5rem;width:fit-content;max-width:100%}.heatmap-months{display:grid;grid-auto-flow:column;gap:3px;margin-left:25px;height:15px;align-items:center}.heatmap-month-label{font-size:.75rem;color:var(--text-secondary);font-weight:400}.heatmap-content{display:flex;gap:5px}.heatmap-days-labels{display:grid;grid-template-rows:repeat(7,1fr);gap:3px;font-size:.7rem;color:var(--text-secondary)}.heatmap-day-label{line-height:11px}.heatmap-grid-container{overflow-x:auto;width:100%}.heatmap-grid{display:grid;grid-template-rows:repeat(7,1fr);grid-auto-flow:column;gap:3px;width:max-content}.heatmap-day{width:11px;height:11px;border-radius:2px;cursor:pointer;transition:all .2s ease;background-color:var(--heatmap-empty)}.heatmap-day-empty{width:11px;height:11px}.heatmap-day:hover{transform:scale(1.2);box-shadow:0 0 0 1px var(--overlay-light);z-index:10;position:relative}.heatmap-day[data-level="0"]{background-color:var(--heatmap-empty)}.heatmap-day[data-level="1"]{background-color:var(--heatmap-level-1)}.heatmap-day[data-level="2"]{background-color:var(--heatmap-level-2)}.heatmap-day[data-level="3"]{background-color:var(--heatmap-level-3)}.heatmap-day[data-level="4"]{background-color:var(--heatmap-level-4)}[data-theme=dark] .heatmap-day[data-level="0"]{background-color:var(--heatmap-empty)}[data-theme=dark] .heatmap-day[data-level="1"]{background-color:var(--heatmap-level-1)}[data-theme=dark] .heatmap-day[data-level="2"]{background-color:var(--heatmap-level-2)}[data-theme=dark] .heatmap-day[data-level="3"]{background-color:var(--heatmap-level-3)}[data-theme=dark] .heatmap-day[data-level="4"]{background-color:var(--heatmap-level-4)}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:.35rem;margin-top:.75rem;font-size:.7rem;color:var(--text-secondary)}.heatmap-legend-label{font-size:.7rem}.heatmap-legend-scale{display:flex;gap:2px}.heatmap-legend-day{width:10px;height:10px;border-radius:2px;cursor:pointer}.heatmap-legend-day:hover{outline:1px solid var(--overlay-light)}.heatmap-legend-day[data-level="0"]{background-color:var(--heatmap-empty)}.heatmap-legend-day[data-level="1"]{background-color:var(--heatmap-level-1)}.heatmap-legend-day[data-level="2"]{background-color:var(--heatmap-level-2)}.heatmap-legend-day[data-level="3"]{background-color:var(--heatmap-level-3)}.heatmap-legend-day[data-level="4"]{background-color:var(--heatmap-level-4)}[data-theme=dark] .heatmap-legend-day[data-level="0"]{background-color:var(--heatmap-empty)}[data-theme=dark] .heatmap-legend-day[data-level="1"]{background-color:var(--heatmap-level-1)}[data-theme=dark] .heatmap-legend-day[data-level="2"]{background-color:var(--heatmap-level-2)}[data-theme=dark] .heatmap-legend-day[data-level="3"]{background-color:var(--heatmap-level-3)}[data-theme=dark] .heatmap-legend-day[data-level="4"]{background-color:var(--heatmap-level-4)}.heatmap-tooltip{position:fixed;background:var(--text-primary);color:var(--bg-primary);padding:.5rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;pointer-events:none;z-index:1000;opacity:0;transition:opacity .2s ease;white-space:nowrap;transform:translate(-50%)}.heatmap-tooltip.visible{opacity:1}.heatmap-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--text-primary)}@media (max-width: 768px){.habits-tracker{padding:.75rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.tracker-header,.habit-row{grid-template-columns:70px repeat(7,minmax(32px,1fr));gap:.25rem;min-width:320px}.habit-name{font-size:.75rem;padding:.25rem .5rem;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.day-header{font-size:.65rem;padding:.25rem .1rem}.day-cell{min-height:28px;min-width:28px;font-size:.6rem}.streak-item{padding:.5rem;gap:.5rem}.streak-name{font-size:.9rem}}.subscription-tracker{margin-top:2rem;padding:var(--space-2xl);background:var(--bg-primary, #ffffff);border-radius:12px;box-shadow:0 2px 8px #0000000d}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color, #e5e7eb)}.subscription-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1f2937)}.subscription-header h2>span{color:var(--text-secondary, #6b7280);font-size:1rem;font-weight:400}.subscription-header h2 .ytd-spending{font-size:.85rem;color:var(--text-secondary, #6b7280);margin-left:.5rem}.subscription-summary{display:flex;align-items:center;gap:1.5rem}.ytd-spending strong{color:var(--text-primary, #1f2937);font-weight:600}.total-monthly-cost{font-size:1.25rem;font-weight:700;color:var(--primary-color, #0066cc)}.total-monthly-cost .frequency{font-size:1rem;color:var(--text-secondary, #6b7280);font-weight:400}.subscription-controls{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem}.subscription-controls select{padding:.5rem 1rem;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:var(--bg-secondary, #f9fafb);color:var(--text-primary, #1f2937);font-size:.9rem;cursor:pointer}.subscription-controls button{padding:.5rem 1rem;font-size:.9rem;white-space:nowrap}.subscription-content{display:grid;grid-template-columns:2fr 3fr;gap:2rem}.subscription-list{display:flex;flex-direction:column;gap:1rem}.subscription-tiles{display:flex;flex-direction:column;gap:.75rem;max-height:500px;overflow-y:auto;padding-right:.5rem}.subscription-tiles::-webkit-scrollbar{width:6px}.subscription-tiles::-webkit-scrollbar-track{background:var(--bg-secondary, #f9fafb);border-radius:3px}.subscription-tiles::-webkit-scrollbar-thumb{background:var(--border-color, #d1d5db);border-radius:3px}.subscription-tiles::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #9ca3af)}.subscription-tile{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary, #f9fafb);border-left:4px solid var(--primary-color, #0066cc);border-radius:8px;transition:all .3s ease;position:relative}.subscription-tile:hover{background:var(--bg-tertiary, #f3f4f6);transform:translate(4px);box-shadow:0 4px 12px #0000001a}.subscription-tile[data-status=ended]{opacity:.6;border-left-color:var(--text-secondary, #9ca3af)}.subscription-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.subscription-header-row{display:flex;align-items:center;gap:.5rem}.subscription-icon{font-size:1.5rem;line-height:1;display:flex;align-items:center}.subscription-name{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0!important}.subscription-tile[data-status=ended] .subscription-name{text-decoration:line-through}.subscription-badge{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;font-weight:600;text-transform:uppercase}.subscription-badge.active{background:var(--status-active-bg);color:var(--status-active-text)}.subscription-badge.paused{background:#ffc1071a;color:var(--warning-color)}.subscription-badge.ended{background:var(--status-inactive-bg);color:var(--status-inactive-text)}.subscription-details{display:flex;gap:1rem;align-items:baseline;flex-wrap:wrap}.subscription-price{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1f2937)}.subscription-price .frequency{font-size:.85rem;font-weight:400;color:var(--text-secondary, #6b7280)}.monthly-equivalent{font-size:.85rem;color:var(--text-secondary, #6b7280);font-style:italic}.subscription-meta{font-size:.85rem;color:var(--text-secondary, #6b7280)}.subscription-actions{display:flex;gap:.5rem;align-items:center}.subscription-chart-container{background:var(--bg-secondary, #f9fafb);border-radius:8px;padding:var(--space-2xl);height:500px;display:flex;flex-direction:column}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937)}.chart-nav{display:flex;gap:.5rem}#subscription-chart{flex:1;max-height:450px}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #6b7280)}.empty-state p:first-child{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:.5rem}@media (max-width: 900px){.subscription-content{grid-template-columns:1fr}.subscription-chart-container{order:-1;height:300px}.subscription-tiles{max-height:none}.total-monthly-cost{font-size:1.5rem}}@media (max-width: 768px){.subscription-tracker{padding:1rem}.subscription-header{flex-direction:column;align-items:flex-start;gap:1rem}.subscription-summary{align-items:flex-start;width:100%}.subscription-controls{flex-direction:column;width:100%}.subscription-controls select,.subscription-controls button{width:100%}.subscription-tile{flex-direction:column;align-items:flex-start}.subscription-actions{align-self:flex-end;margin-top:.5rem}}@media (prefers-color-scheme: dark){.subscription-tracker{background:var(--bg-primary-dark, #1f2937)}.subscription-tile{background:var(--bg-secondary-dark, #374151)}.subscription-tile:hover{background:var(--bg-tertiary-dark, #4b5563)}}
