:root{--white: #FFFFFF;--bg: #F8F9FC;--bg-card: #FFFFFF;--text-primary: #1A1D29;--text-secondary: #6B7080;--text-muted: #9CA3B4;--border: #E8EBF0;--border-light: #F0F2F5;--blue: #4A7CFF;--blue-light: #E8EFFF;--blue-dark: #3A63D4;--green: #22C55E;--green-light: #E6F9EE;--green-dark: #16A34A;--gradient: linear-gradient(135deg, #4A7CFF 0%, #22C55E 100%);--gradient-soft: linear-gradient(135deg, #EEF2FF 0%, #E6F9EE 100%);--gradient-hero: linear-gradient(160deg, #F0F4FF 0%, #F8F9FC 40%, #EDFCF2 100%);--red: #EF4444;--red-light: #FEE2E2;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow: 0 0 40px rgba(74, 124, 255, .15);--font-heading: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 999px;--ease: cubic-bezier(.4, 0, .2, 1);--duration: .25s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:64px;background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light)}.footer-brand{font-family:var(--font-heading);font-weight:800;font-size:1.2rem;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:8px}.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary);font-weight:800;font-size:1.25rem;font-family:var(--font-heading);letter-spacing:-.02em}.nav-logo-img{height:36px;width:auto;object-fit:contain}.logo-icon{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.1rem}.nav-links{display:flex;gap:8px}.nav-link{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:6px 16px;border-radius:var(--radius-full);transition:all var(--duration) var(--ease)}.nav-link:hover,.nav-link.active{color:var(--blue);background:var(--blue-light)}.user-profile{display:flex;align-items:center;gap:12px;margin-left:8px;padding-left:20px;border-left:1px solid var(--border-light)}.nav-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1px solid var(--border);background:var(--bg)}.user-info{display:flex;flex-direction:column;justify-content:center}.nav-user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);line-height:1.2}.logout-link{font-size:.75rem;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;text-align:left;padding:0;margin-top:2px;transition:color var(--duration) var(--ease)}.logout-link:hover{color:var(--red)}.page{display:none}.page.active{display:block;animation:fadeIn .4s var(--ease)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hero{position:relative;text-align:center;padding:100px 24px 80px;background:var(--gradient-hero);overflow:hidden}.hero-glow{position:absolute;top:-120px;left:50%;transform:translate(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(74,124,255,.08) 0%,transparent 70%);pointer-events:none}.hero-eyebrow{font-size:.85rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:24px}.hero-headline{font-family:var(--font-heading);font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;line-height:1.1;letter-spacing:-1.5px;margin-bottom:24px}.hero-sub{font-size:1.1rem;color:var(--text-secondary);max-width:540px;margin:0 auto 16px;line-height:1.7}.hero-bold{font-family:var(--font-heading);font-weight:700;font-size:1.25rem;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:40px}.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-weight:600;font-size:.9rem;border:none;cursor:pointer;border-radius:var(--radius-full);padding:12px 28px;transition:all var(--duration) var(--ease);text-decoration:none}.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 14px #4a7cff40}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a7cff59}.btn-secondary{background:var(--white);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--blue);color:var(--blue)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:8px 18px;font-size:.825rem}.btn-icon{font-size:1.1rem;font-weight:400}.btn-icon-sm{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:var(--radius-full);background:var(--white);border:1px solid var(--border);cursor:pointer;transition:all var(--duration) var(--ease);color:var(--text-secondary)}.btn-icon-sm:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.section-dreams{max-width:1100px;margin:0 auto;padding:60px 24px 80px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.section-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:800;letter-spacing:-.5px}.section-subtitle{color:var(--text-muted);font-size:.9rem;margin-top:4px}.dreams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.dream-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:28px;transition:all var(--duration) var(--ease);position:relative;cursor:pointer;overflow:hidden}.dream-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient);opacity:0;transition:opacity var(--duration) var(--ease)}.dream-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-3px)}.dream-card:hover:before{opacity:1}.dream-card-title{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;margin-bottom:16px;padding-right:60px}.dream-card-progress{display:flex;align-items:center;gap:12px;margin-bottom:20px}.dream-card-bar{flex:1;height:6px;background:var(--border-light);border-radius:99px;overflow:hidden}.dream-card-bar-fill{height:100%;background:var(--gradient);border-radius:99px;transition:width .6s var(--ease)}.dream-card-pct{font-size:.8rem;font-weight:700;color:var(--blue);min-width:36px;text-align:right}.dream-card-actions{display:flex;gap:8px}.dream-card-btn{font-family:var(--font-body);font-size:.8rem;font-weight:600;padding:6px 16px;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--duration) var(--ease)}.dream-card-btn.open{background:var(--blue-light);color:var(--blue)}.dream-card-btn.open:hover{background:var(--blue);color:#fff}.dream-card-btn.edit{background:var(--border-light);color:var(--text-secondary)}.dream-card-btn.edit:hover{color:var(--text-primary)}.dream-card-btn.delete{background:var(--red-light);color:var(--red)}.dream-card-btn.delete:hover{background:var(--red);color:#fff}.empty-state{text-align:center;padding:80px 24px}.empty-icon{font-size:3rem;margin-bottom:16px}.empty-state h3{font-family:var(--font-heading);font-size:1.25rem;margin-bottom:8px}.empty-state p{color:var(--text-muted);margin-bottom:24px}.motivation-banner{text-align:center;padding:48px 24px;background:var(--gradient-soft)}.motivation-banner p{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--text-secondary);font-style:italic;max-width:600px;margin:0 auto;line-height:1.7}.dream-header{max-width:1100px;margin:0 auto;padding:32px 24px 24px}.btn-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:.85rem;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:6px 0;margin-bottom:16px;transition:color var(--duration) var(--ease)}.btn-back:hover{color:var(--blue)}.dream-title-row{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.dream-title{font-family:var(--font-heading);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:900;letter-spacing:-.5px}.dream-progress-badge{display:none}.dream-switcher-wrapper{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.dream-switcher{appearance:none;-webkit-appearance:none;font-family:var(--font-heading);font-size:clamp(1.3rem,3.5vw,1.75rem);font-weight:600;color:var(--text-primary);background:linear-gradient(135deg,#fff,#f8faff);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);padding:10px 44px 10px 20px;cursor:pointer;outline:none;transition:all var(--duration) var(--ease);max-width:500px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;letter-spacing:-.3px}.dream-switcher option{font-family:var(--font-body);font-size:.95rem;font-weight:500;color:var(--text-primary);padding:10px 16px;background:var(--white)}.dream-switcher:hover{border-color:var(--blue);background:linear-gradient(135deg,#f0f5ff,#e8efff);box-shadow:0 2px 12px #4a7cff1a}.dream-switcher:focus{border-color:var(--blue);box-shadow:0 0 0 3px #4a7cff26}.dream-switcher-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--duration) var(--ease)}.dream-switcher-wrapper:hover .dream-switcher-arrow{color:var(--blue)}.month-picker-row{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:20px;flex-wrap:wrap}.current-month-label{font-family:var(--font-heading);font-size:1.4rem;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;padding-top:8px}.month-picker{flex-shrink:0}.year-selector{display:flex;align-items:center;gap:8px;margin-bottom:10px;justify-content:center}.year-label{font-family:var(--font-heading);font-weight:800;font-size:1.2rem;letter-spacing:-.5px;min-width:50px;text-align:center}.month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.month-btn{padding:7px 12px;font-family:var(--font-body);font-size:.78rem;font-weight:600;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--white);color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease)}.month-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.month-btn.active{background:var(--gradient);color:#fff;border-color:transparent;font-weight:700;box-shadow:0 2px 8px #4a7cff40}.main-progress-wrapper{margin-bottom:8px}.main-progress-bar{height:32px;background:var(--border-light);border-radius:var(--radius-md);overflow:hidden;position:relative}.main-progress-fill{height:100%;background:var(--gradient);border-radius:var(--radius-md);transition:width .6s var(--ease);width:0%;display:flex;align-items:center;justify-content:center;min-width:40px;position:relative}.main-progress-text{font-family:var(--font-heading);font-size:.8rem;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);white-space:nowrap}.execution-section{max-width:100%;margin:0 auto;padding:24px 12px 16px}.habit-tracker-wrapper{overflow-x:hidden;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-card)}.habit-grid-container{width:100%}.habit-grid{width:100%;border-collapse:collapse;table-layout:fixed}.habit-grid th,.habit-grid td{padding:4px 1px;text-align:center;font-size:.7rem;border-bottom:1px solid var(--border-light)}.habit-grid thead th{position:sticky;top:0;background:var(--bg);font-weight:600;color:var(--text-muted);z-index:2;padding:8px 1px}.day-header.is-today{color:#fff!important;position:relative;z-index:5}.day-header.is-today:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:26px;height:26px;background:var(--blue);border-radius:50%;z-index:-1;box-shadow:0 4px 12px #4a7cff4d}.habit-grid th.habit-name-col{text-align:left;padding-left:8px;width:110px;min-width:110px;max-width:110px;position:sticky;left:0;z-index:3;background:var(--bg)}.habit-grid td.habit-name-cell{text-align:left;padding-left:8px;font-weight:600;font-size:.75rem;color:var(--text-primary);width:110px;min-width:110px;max-width:110px;position:sticky;left:0;background:var(--bg-card);z-index:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-name-inner{display:flex;align-items:center;gap:8px}.habit-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.7rem;transition:all var(--duration) var(--ease);flex-shrink:0;opacity:0}.habit-name-cell:hover .habit-delete-btn{opacity:1}.habit-delete-btn:hover{background:var(--red-light);color:var(--red)}.goal-col{width:44px!important;min-width:44px!important}.goal-input{width:38px;padding:2px;font-family:var(--font-body);font-size:.7rem;font-weight:700;color:var(--blue);text-align:center;border:1.5px solid var(--border);border-radius:6px;background:var(--white);outline:none;transition:all var(--duration) var(--ease);-moz-appearance:textfield;appearance:textfield}.goal-input::-webkit-outer-spin-button,.goal-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.goal-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}.day-header{font-variant-numeric:tabular-nums}.habit-grid th.progress-col,.habit-grid td.progress-col{width:36px;min-width:36px;font-weight:700;font-size:.65rem;color:var(--blue)}.habit-grid th.progress-end-col,.habit-grid td.progress-end-col{width:110px;min-width:110px;text-align:center;padding:4px 6px}.habit-progress-visual{display:flex;flex-direction:column;align-items:center;gap:3px}.habit-progress-bar-bg{width:100%;height:5px;background:var(--border-light);border-radius:99px;overflow:hidden}.habit-progress-bar-fg{height:100%;border-radius:99px;transition:width .4s var(--ease)}.habit-progress-text{font-size:.6rem;color:var(--text-secondary);white-space:nowrap}.habit-progress-text b{color:var(--blue);font-weight:700}.day-checkbox{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid var(--border);border-radius:4px;cursor:pointer;position:relative;transition:all var(--duration) var(--ease);background:var(--white);margin:0;padding:0;display:block;margin-inline:auto}.day-checkbox:hover{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}.day-checkbox:checked{background:var(--gradient);border-color:transparent;animation:checkPop .3s var(--ease)}.day-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.6rem;font-weight:700}@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.day-na{display:inline-block;font-size:.55rem;font-weight:600;color:var(--text-muted);opacity:.5;-webkit-user-select:none;user-select:none}.day-tri{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border);background:var(--white);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:0;padding:0;transition:all .15s ease;line-height:1}.day-tri:hover{border-color:var(--blue);box-shadow:0 0 0 2px #4a7cff1f}.day-tri.state-done{background:var(--green);border-color:var(--green);color:#fff;font-size:.65rem;font-weight:700}.day-tri.state-na{background:var(--bg-secondary);border-color:transparent;color:var(--text-muted);font-size:.5rem;font-weight:700;opacity:.6}.day-tri.state-empty{background:var(--white);border-color:var(--border)}.daily-summary-row td{font-weight:700!important;color:var(--text-primary)!important;padding-top:12px!important;padding-bottom:12px!important;border-bottom:none!important;background:var(--gradient-soft)!important}.daily-pct{display:inline-block;padding:1px 3px;border-radius:var(--radius-full);font-size:.55rem;font-weight:700}.daily-pct.full{background:var(--green-light);color:var(--green-dark)}.daily-pct.partial{background:var(--blue-light);color:var(--blue)}.daily-pct.zero{background:var(--border-light);color:var(--text-muted)}.daily-summary-section,.monthly-summary{max-width:1100px;margin:0 auto;padding:32px 24px}.subsection-title{font-family:var(--font-heading);font-weight:700;font-size:1.15rem;margin-bottom:20px}.daily-chart-wrapper{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;height:280px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.stat-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:24px;text-align:center;transition:all var(--duration) var(--ease)}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.stat-card-accent{background:var(--gradient-soft);border-color:#4a7cff26}.stat-value{font-family:var(--font-heading);font-size:2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}.stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500;margin-top:6px}.stat-top-habit-name-wrapper{display:flex;align-items:center;gap:8px}.status-badge{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.05em}.status-success{background:#22c55e1a;color:var(--green)}.status-info{background:#4a7cff1a;color:var(--blue)}.stat-habit-name{font-size:.75rem;font-weight:600;color:var(--blue);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-header{text-align:center;padding:60px 24px 40px;background:var(--gradient-hero)}.dashboard-title{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:900;letter-spacing:-1px;margin-bottom:8px}.dashboard-sub{color:var(--text-secondary);font-size:1rem}.dash-stats-grid{max-width:1100px;margin:-30px auto 0;padding:0 24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;position:relative;z-index:1}.dash-stats-grid .stat-card{box-shadow:var(--shadow-sm)}.dash-section{max-width:1100px;margin:0 auto;padding:40px 24px}.dreams-comparison{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.dream-compare-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px;cursor:pointer;transition:all var(--duration) var(--ease)}.dream-compare-card:hover{box-shadow:var(--shadow-sm);border-color:var(--blue)}.dream-compare-title{font-weight:700;font-size:.95rem;margin-bottom:12px}.dream-compare-bar{height:8px;background:var(--border-light);border-radius:99px;overflow:hidden;margin-bottom:8px}.dream-compare-bar-fill{height:100%;background:var(--gradient);border-radius:99px;transition:width .6s var(--ease)}.dream-compare-pct{font-size:.8rem;font-weight:700;color:var(--blue)}.top-habits-table-wrapper{overflow-x:auto;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-card)}.top-habits-table{width:100%;border-collapse:collapse}.top-habits-table th{text-align:left;padding:14px 16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border-light);background:var(--bg)}.top-habits-table td{padding:12px 16px;font-size:.875rem;border-bottom:1px solid var(--border-light)}.top-habits-table tr:last-child td{border-bottom:none}.top-habits-table tr:hover td{background:var(--gradient-soft)}.habit-progress-mini{display:flex;align-items:center;gap:8px}.habit-progress-mini-bar{flex:1;height:6px;background:var(--border-light);border-radius:99px;overflow:hidden;max-width:100px}.habit-progress-mini-fill{height:100%;background:var(--gradient);border-radius:99px}.habit-progress-mini-pct{font-weight:700;font-size:.8rem;color:var(--blue);min-width:40px}.chart-wrapper{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;height:320px}.footer{text-align:center;padding:60px 24px;background:var(--text-primary);color:var(--white)}.footer-quote{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;line-height:1.6;margin-bottom:24px;opacity:.9}.footer-brand{font-family:var(--font-heading);font-weight:800;font-size:.9rem;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-overlay.open{display:flex;animation:fadeIn .2s var(--ease)}.modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:modalSlide .3s var(--ease)}.modal-sm{max-width:380px}@keyframes modalSlide{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 0}.modal-header h3{font-family:var(--font-heading);font-weight:700;font-size:1.15rem}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--border-light);font-size:1.2rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--duration) var(--ease)}.modal-close:hover{background:var(--red-light);color:var(--red)}.modal-body{padding:24px 28px}.modal-footer{padding:0 28px 24px;display:flex;gap:12px;justify-content:flex-end}.input-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.input-field{width:100%;padding:12px 16px;font-family:var(--font-body);font-size:.95rem;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--bg);color:var(--text-primary);outline:none;transition:all var(--duration) var(--ease)}.input-field:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-light)}.input-field::placeholder{color:var(--text-muted)}@media(max-width:768px){.navbar{padding:0 16px}.hero{padding:60px 16px 50px}.hero-sub br{display:none}.section-dreams{padding:40px 16px 60px}.dreams-grid{grid-template-columns:1fr}.dream-header,.execution-section,.daily-summary-section,.monthly-summary{padding:20px 16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.dreams-comparison,.dash-charts-row{grid-template-columns:1fr}.dash-stats-grid{grid-template-columns:repeat(2,1fr);padding:0 16px}.dash-section{padding:24px 16px}.achievements-grid{grid-template-columns:repeat(4,1fr)}.dream-compare-right{min-width:100px}}@media(max-width:480px){.hero-headline{font-size:2rem}.hero-actions{flex-direction:column;align-items:center}.stats-grid{grid-template-columns:1fr 1fr}.dash-stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:16px 12px}.stat-value{font-size:1.5rem}.stat-card-momentum .stat-value{font-size:1.8rem}.achievements-grid{grid-template-columns:repeat(2,1fr)}.heatmap-grid{grid-template-columns:repeat(7,1fr)}}.dashboard-header{text-align:center;padding:40px 0 32px}.dashboard-title{font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:900;letter-spacing:-1px;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.dashboard-sub{color:var(--text-muted);font-size:.95rem;margin-top:4px}.dash-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px 20px;text-align:center;position:relative;overflow:visible;transition:all var(--duration) var(--ease);z-index:10}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000f;z-index:110}.stat-icon{font-size:1.5rem;margin-bottom:8px;opacity:.85}.stat-value{font-family:var(--font-heading);font-size:2rem;font-weight:800;letter-spacing:-1px;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.78rem;font-weight:500;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.stat-sub{font-size:.72rem;font-weight:500;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-card-momentum .stat-sub{color:#ffffffe6;background:#00000026;padding:2px 10px;border-radius:20px;font-size:.65rem;font-weight:700;letter-spacing:1px;display:inline-block;margin-bottom:5px}.stat-card-momentum{background:linear-gradient(135deg,#312e81,#4c1d95);border:1px solid rgba(255,255,255,.1);color:#fff;position:relative;overflow:visible;box-shadow:0 10px 40px -10px #312e8180,0 0 20px #4c1d9533;transition:transform .3s ease,box-shadow .3s ease}.stat-card-momentum:hover{transform:translateY(-4px);box-shadow:0 15px 40px -5px #4f46e580,0 0 30px #7c3aed4d}.stat-card-momentum:hover .momentum-tooltip,.stat-card-streak:hover .momentum-tooltip,.stat-card-focus:hover .momentum-tooltip{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.momentum-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(12px);width:320px;background:#1a1d29;border:1px solid rgba(255,255,255,.2);padding:20px;border-radius:12px;box-shadow:0 10px 30px #0009;z-index:9999;opacity:0;pointer-events:none;transition:all .3s var(--ease);color:#fff;text-align:left}#page-dashboard,.dash-stats-grid{overflow:visible!important}.momentum-tooltip ul li{font-size:.85rem;margin-bottom:10px;display:flex;align-items:flex-start;gap:8px}.streak-tooltip ul li:before{content:"🏆";font-size:.8rem}.streak-tooltip-dead-code{display:none}.momentum-last-bit{content:"ðŸ†";font-size:.8rem}.focus-tooltip ul li:before{content:"⚡";font-size:.8rem}.momentum-tooltip h4{font-size:.9rem;font-weight:700;margin-bottom:10px;color:#60a5fa;display:flex;align-items:center;gap:6px}.momentum-tooltip h4:before{content:"💡"}.momentum-tooltip ul{list-style:none;padding:0;margin:0}.momentum-tooltip li{font-size:.8rem;line-height:1.5;margin-bottom:8px;padding-left:14px;position:relative;color:#d1d5db}.momentum-tooltip li:before{content:"•";position:absolute;left:0;color:#60a5fa;font-weight:700}.momentum-tooltip li strong{color:#fff}.stat-card-momentum .stat-value{color:#fff;font-size:3.2rem;font-weight:800;display:flex;align-items:baseline;justify-content:center;gap:4px;filter:drop-shadow(0 0 15px rgba(255,255,255,.2));margin:12px 0;line-height:1}.stat-card-momentum .stat-value #dash-momentum{color:#10b981;text-shadow:0 0 20px rgba(16,185,129,.5)}.stat-card-momentum .stat-value small{font-size:1.1rem;font-weight:600;color:#ffffff80;letter-spacing:1px}.stat-card-momentum .stat-label{color:#ffffffd9;font-size:.7rem;font-weight:700}.stat-card-momentum .stat-icon{background:#fff3;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}.stat-card-streak:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f59e0b,#ef4444)}.stat-card-today:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#22c55e,#06b6d4)}.stat-card-focus:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8b5cf6,#ec4899)}.stat-card-focus .stat-value{font-size:1rem;font-weight:700;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.dash-card-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.3px}.dash-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.dash-charts-row .dash-card{margin-bottom:0}.chart-wrapper{position:relative;height:240px}.chart-wrapper-pie{height:260px}.chart-wrapper-line{height:240px}.heatmap-container{padding:8px 0}.heatmap-label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.heatmap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(32px,1fr));gap:4px}.heatmap-cell{aspect-ratio:1;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:default;transition:transform .15s ease;position:relative}.heatmap-cell:hover{transform:scale(1.15);z-index:1}.heatmap-day{font-size:.6rem;font-weight:600;color:#00000059}.heatmap-cell.level-0{background:#f0f2f5}.heatmap-cell.level-0 .heatmap-day{color:#0003}.heatmap-cell.level-1{background:#dbeafe}.heatmap-cell.level-1 .heatmap-day{color:#3b82f699}.heatmap-cell.level-2{background:#93c5fd}.heatmap-cell.level-2 .heatmap-day{color:#ffffffb3}.heatmap-cell.level-3{background:#4a7cff}.heatmap-cell.level-3 .heatmap-day{color:#fffc}.heatmap-cell.level-4{background:#22c55e}.heatmap-cell.level-4 .heatmap-day{color:#ffffffe6}.heatmap-legend{display:flex;flex-direction:column;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light)}.heatmap-legend-info{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.heatmap-legend-cells{display:flex;justify-content:flex-end;gap:4px}.heatmap-cell-mini{width:12px;height:12px;border-radius:2px}.dash-insights-card{border-left:3px solid var(--blue)}.insights-list{display:flex;flex-direction:column;gap:12px}.insight-row{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg);transition:all .15s ease}.insight-row:hover{transform:translate(4px)}.insight-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.insight-text{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.insight-text strong{color:var(--text-primary);font-weight:700}.insight-positive{background:#22c55e0f;border-left:2px solid #22C55E}.insight-warning{background:#f59e0b0f;border-left:2px solid #F59E0B}.insight-neutral{background:#4a7cff0a;border-left:2px solid transparent}.top-habits-list{display:flex;flex-direction:column;gap:10px}.top-habit-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);background:var(--bg);transition:all .15s ease}.top-habit-row:hover{background:#4a7cff0a}.top-habit-rank{font-family:var(--font-heading);font-weight:800;font-size:.85rem;color:var(--text-muted);min-width:20px;text-align:center}.top-habit-info{flex:1;min-width:0}.top-habit-name{font-weight:600;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-habit-dream{font-size:.72rem;color:var(--text-muted);margin-top:1px}.top-habit-progress{display:flex;align-items:center;gap:8px;min-width:100px}.top-habit-bar{flex:1;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.top-habit-bar-fill{height:100%;border-radius:3px;transition:width .4s var(--ease)}.top-habit-pct{font-family:var(--font-heading);font-size:.78rem;font-weight:700;color:var(--text-secondary);min-width:32px;text-align:right}.dreams-comparison{display:flex;flex-direction:column;gap:10px}.dream-compare-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:all var(--duration) var(--ease)}.dream-compare-card:hover{background:#4a7cff0f;transform:translate(4px)}.dream-compare-left{flex:1;min-width:0}.dream-compare-title{font-weight:700;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dream-compare-meta{font-size:.72rem;color:var(--text-muted);margin-top:2px;display:block}.dream-compare-right{display:flex;align-items:center;gap:10px;min-width:140px}.dream-compare-bar{flex:1;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.dream-compare-bar-fill{height:100%;border-radius:3px;background:var(--gradient);transition:width .4s var(--ease)}.dream-compare-pct{font-family:var(--font-heading);font-size:.85rem;font-weight:700;color:var(--blue);min-width:36px;text-align:right}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.badge-card{text-align:center;padding:16px 10px;border-radius:var(--radius-lg);transition:all .2s ease}.badge-unlocked{background:linear-gradient(135deg,#4a7cff0f,#6366f114);border:1px solid rgba(74,124,255,.15)}.badge-unlocked:hover{transform:translateY(-3px);box-shadow:0 6px 20px #4a7cff1f}.badge-locked{background:var(--bg);border:1px solid transparent;opacity:.5}.badge-icon{font-size:1.8rem;margin-bottom:6px}.badge-name{font-weight:700;font-size:.72rem;color:var(--text-primary);margin-bottom:2px}.badge-desc{font-size:.62rem;color:var(--text-muted)}.motivation-banner{text-align:center;padding:32px 20px;margin:20px 0;color:var(--text-muted);font-style:italic;font-size:.95rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(max-width:768px){.navbar{padding:0 16px;height:auto;min-height:64px;flex-wrap:wrap;justify-content:space-between;gap:8px;padding:12px 16px!important}.nav-right{width:100%;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light);display:flex;align-items:center}.nav-links{gap:4px}.nav-link{padding:6px 12px;font-size:.8rem}.user-profile{border-left:none;padding-left:0;margin-left:0;gap:8px}.nav-user-name{display:none}.dreams-grid,.stats-grid,.dashboard-main,.hero-actions,.dash-main-grid,.stat-card-row{grid-template-columns:1fr!important}.execution-section{padding:16px 8px}.habit-tracker-wrapper{overflow-x:auto!important;-webkit-overflow-scrolling:touch;width:100%;border-radius:var(--radius-md)}.habit-grid{min-width:1100px;table-layout:fixed}.habit-name-col{position:sticky;left:0;z-index:50;background:#fff!important;width:140px!important;min-width:140px!important;box-shadow:4px 0 8px #0000000d}.habit-name{position:sticky;left:0;z-index:50;background:#fff!important}.day-header,.day-cell,.summary-day{width:38px!important;min-width:38px!important;height:48px}.dream-title-row{flex-direction:column;align-items:flex-start;gap:12px}.month-picker-row{flex-direction:column;gap:20px;align-items:stretch}.month-grid{grid-template-columns:repeat(4,1fr);width:100%}.current-month-label{font-size:1.25rem;text-align:center}.dash-stats-grid{grid-template-columns:1fr!important;gap:16px}.chart-card{height:300px}}@media(max-width:480px){.hero-headline{font-size:2.5rem}.section-dreams{padding:40px 16px}.dream-card{padding:24px 20px}.month-btn{padding:8px 4px;font-size:.7rem}.dream-switcher{width:100%!important;max-width:100%!important;font-size:1.1rem}}
