@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--font: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--bg-page: #06060c;--bg-card: rgba(255, 255, 255, .032);--bg-card-hover: rgba(255, 255, 255, .058);--bg-inset: rgba(255, 255, 255, .022);--bg-elevated: rgba(22, 22, 30, .97);--glass-bg: rgba(255, 255, 255, .035);--glass-border: rgba(255, 255, 255, .08);--glass-blur: saturate(180%) blur(24px);--glass-glow: rgba(255, 255, 255, .02);--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .11);--text-1: rgba(255, 255, 255, .95);--text-2: rgba(255, 255, 255, .52);--text-3: rgba(255, 255, 255, .26);--accent: #0A84FF;--accent-soft: rgba(10, 132, 255, .12);--accent-border: rgba(10, 132, 255, .25);--accent-glow: rgba(10, 132, 255, .3);--green: #30D158;--green-soft: rgba(48, 209, 88, .1);--amber: #FF9F0A;--amber-soft: rgba(255, 159, 10, .1);--red: #FF453A;--red-soft: rgba(255, 69, 58, .1);--purple: #BF5AF2;--purple-soft: rgba(191, 90, 242, .1);--teal: #5AC8FA;--teal-soft: rgba(90, 200, 250, .1);--grad-hero: linear-gradient(145deg, rgba(10, 132, 255, .08) 0%, rgba(191, 90, 242, .06) 50%, rgba(255, 100, 130, .04) 100%);--grad-card: linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%);--grad-accent: linear-gradient(135deg, #0A84FF 0%, #5E5CE6 50%, #BF5AF2 100%);--grad-success: linear-gradient(135deg, #30D158 0%, #00C7BE 100%);--grad-warm: linear-gradient(135deg, #FF9F0A 0%, #FF6482 100%);--grad-mesh: radial-gradient(ellipse at 20% 0%, rgba(10,132,255,.06) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(191,90,242,.04) 0%, transparent 50%);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-xs: 8px;--radius-sm: 12px;--radius-md: 18px;--radius-lg: 24px;--radius-xl: 28px;--radius-full: 9999px;--ease-out: cubic-bezier(.25, 1, .5, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--dur-fast: .15s;--dur-normal: .3s;--dur-slow: .5s;--shadow-card: 0 1px 2px rgba(0,0,0,.3), 0 4px 16px rgba(0,0,0,.2);--shadow-card-elevated: 0 2px 4px rgba(0,0,0,.4), 0 8px 32px rgba(0,0,0,.35);--shadow-modal: 0 -4px 20px rgba(0,0,0,.5), 0 8px 60px rgba(0,0,0,.7);--shadow-fab: 0 4px 24px rgba(10, 132, 255, .45), 0 0 0 1px rgba(10,132,255,.2);--shadow-glow-blue: 0 0 20px rgba(10, 132, 255, .2), 0 0 60px rgba(10, 132, 255, .1);--shadow-glow-green: 0 0 20px rgba(48, 209, 88, .2), 0 0 60px rgba(48, 209, 88, .08);--shadow-glow-purple: 0 0 20px rgba(191, 90, 242, .2), 0 0 60px rgba(191, 90, 242, .08)}@media(prefers-color-scheme:light){:root{--bg-page: #f5f5fa;--bg-card: rgba(255,255,255,.85);--bg-card-hover: rgba(255,255,255,1);--bg-inset: rgba(0,0,0,.028);--bg-elevated: rgba(255,255,255,.97);--glass-bg: rgba(255,255,255,.65);--glass-border: rgba(0,0,0,.06);--border: rgba(0,0,0,.055);--border-strong: rgba(0,0,0,.1);--text-1: rgba(0,0,0,.88);--text-2: rgba(0,0,0,.48);--text-3: rgba(0,0,0,.22);--grad-hero: linear-gradient(145deg, rgba(10,132,255,.06) 0%, rgba(191,90,242,.04) 50%, transparent 100%);--grad-card: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(248,248,252,1) 100%);--grad-mesh: radial-gradient(ellipse at 20% 0%, rgba(10,132,255,.04) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(191,90,242,.03) 0%, transparent 50%)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-page);background-image:var(--grad-mesh);background-attachment:fixed;color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.5;letter-spacing:-.01em}#root{min-height:100vh}button{cursor:pointer;border:none;background:none;font-family:var(--font);color:inherit;-webkit-tap-highlight-color:transparent;transition:transform var(--dur-fast) var(--ease-out),opacity var(--dur-fast)}button:active{transform:scale(.97)}input,textarea,select{font-family:var(--font);color:var(--text-1);background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease;letter-spacing:-.01em}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-card);transition:transform var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out),border-color var(--dur-normal)}.card:hover{box-shadow:var(--shadow-card-elevated);border-color:#ffffff1a}.label-xs{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}.label-sm{font-size:13px;font-weight:500;color:var(--text-2)}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-size:clamp(26px,6vw,34px);font-weight:800;letter-spacing:-.8px;line-height:1.15}.page-header p{margin-top:4px;font-size:14px;color:var(--text-2);line-height:1.4}::-webkit-scrollbar{width:0;height:0}*{scrollbar-width:none}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gradient-border{position:relative}.gradient-border:before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:var(--grad-accent);background-size:300% 300%;animation:gradient-shift 4s ease infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.5}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:shimmer 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #0a84ff4d}50%{box-shadow:0 0 0 8px #0a84ff00}}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}@keyframes celebrate{0%{transform:scale(0) rotate(0);opacity:1}50%{transform:scale(1.2) rotate(180deg);opacity:.8}to{transform:scale(0) rotate(360deg);opacity:0}}@keyframes float-up{0%{transform:translateY(0);opacity:1}to{transform:translateY(-30px);opacity:0}}.cal-heatmap{padding:4px 0}.cal-stats{display:flex;align-items:baseline;gap:6px;margin-bottom:14px}.cal-stat-num{font-size:22px;font-weight:800;letter-spacing:-.5px}.cal-stat-label{font-size:12px;color:var(--text-3)}.cal-stat-pct{margin-left:auto;font-size:14px;font-weight:700}.cal-month-row{display:flex;margin-bottom:4px}.cal-day-labels-spacer{width:18px;flex-shrink:0}.cal-month-labels{display:grid;grid-template-columns:repeat(53,1fr);flex:1;overflow:hidden}.cal-month-label{font-size:9px;font-weight:500;color:var(--text-3);white-space:nowrap}.cal-grid-wrap{display:flex;overflow-x:auto;padding-bottom:4px}.cal-day-labels{display:flex;flex-direction:column;gap:2px;margin-right:4px;flex-shrink:0}.cal-day-label{height:12px;font-size:8px;color:var(--text-3);display:flex;align-items:center;line-height:1}.cal-grid{display:flex;gap:2px}.cal-col{display:flex;flex-direction:column;gap:2px}.cal-cell{width:12px;height:12px;border-radius:2.5px;background:#ffffff0a;transition:transform .1s ease}.cal-cell.empty{background:transparent}.cal-tooltip{display:flex;flex-wrap:wrap;gap:4px 10px;padding:8px 12px;margin-top:8px;border-radius:var(--radius-sm);background:var(--bg-inset);border:1px solid var(--border);font-size:12px;align-items:center}.cal-tooltip-date{font-weight:600;color:var(--text-1)}.cal-tooltip-status{font-weight:600}.cal-tooltip-status.done{color:#30d158}.cal-tooltip-status.missed{color:var(--text-3)}.cal-tooltip-qty{color:var(--accent);font-weight:500}.cal-tooltip-note{color:var(--text-2);font-style:italic;width:100%}.cal-legend{display:flex;align-items:center;gap:3px;margin-top:10px;justify-content:flex-end}.cal-legend-label{font-size:9px;color:var(--text-3);margin:0 3px}.cal-legend-cell{width:12px;height:12px;border-radius:2.5px;background:#ffffff0a}@media(prefers-color-scheme:light){.cal-cell,.cal-legend-cell{background:#0000000d}}.journal-backdrop{position:fixed;inset:0;z-index:600;background:#00000080;display:flex;align-items:flex-end;justify-content:center}.journal-sheet{width:100%;max-width:480px;max-height:85vh;overflow-y:auto;background:var(--bg-elevated);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:14px 18px 28px;box-shadow:var(--shadow-modal)}.journal-handle{width:36px;height:4px;border-radius:99px;background:#ffffff26;margin:0 auto 14px}.journal-header{margin-bottom:18px}.journal-habit-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-full);border:1px solid;font-size:14px;font-weight:600}.journal-habit-badge span:first-child{font-size:18px}.journal-complete-msg{font-size:13px;font-weight:600;color:#30d158;margin-top:8px}.journal-qty-section{margin-bottom:16px}.journal-label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:8px}.journal-target-hint{font-weight:400;color:var(--text-3);font-size:11px;margin-left:4px}.journal-optional{font-weight:400;color:var(--text-3)}.journal-qty-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.journal-qty-input{width:80px;padding:10px 14px;border-radius:var(--radius-sm);font-size:18px;font-weight:700;text-align:center;background:var(--bg-inset);border:1px solid var(--border);color:var(--text-1)}.journal-qty-input:focus{border-color:var(--accent)}.journal-qty-unit{font-size:14px;color:var(--text-2);font-weight:500}.journal-qty-bar-wrap{flex:1;height:8px;border-radius:99px;background:#ffffff0d;overflow:hidden;min-width:80px}.journal-qty-bar{height:100%;border-radius:99px;transition:background-color .3s}.journal-input-section{margin-bottom:16px}.journal-textarea{width:100%;padding:12px 14px;border-radius:var(--radius-sm);font-size:14px;line-height:1.5;background:var(--bg-inset);border:1px solid var(--border);color:var(--text-1);resize:vertical;min-height:60px;font-family:var(--font)}.journal-textarea:focus{border-color:var(--accent)}.journal-textarea::placeholder{color:var(--text-3)}.journal-actions{display:flex;justify-content:flex-end;gap:10px;margin-bottom:18px}.journal-skip{padding:10px 18px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-2);background:var(--bg-inset);border:1px solid var(--border)}.journal-save{padding:10px 24px;border-radius:var(--radius-full);font-size:14px;font-weight:700;color:#fff;background:var(--accent);transition:background .25s,transform .1s}.journal-recent{border-top:1px solid var(--border);padding-top:14px}.journal-recent-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:10px}.journal-recent-entry{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.03)}.journal-recent-date{font-size:11px;color:var(--text-3);font-weight:500;white-space:nowrap;min-width:48px}.journal-recent-text{font-size:13px;color:var(--text-2);line-height:1.4}@media(prefers-color-scheme:light){.journal-sheet{background:#fffffffa}.journal-handle{background:#0000001f}}.hd-backdrop{position:fixed;inset:0;background:#0009;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:400;display:flex;align-items:flex-end;justify-content:center}.hd-sheet{position:relative;width:100%;max-width:480px;max-height:92vh;background:#101016f5;backdrop-filter:saturate(180%) blur(30px);-webkit-backdrop-filter:saturate(180%) blur(30px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid rgba(255,255,255,.08);border-bottom:none;box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden}.hd-handle{width:38px;height:4px;background:#ffffff24;border-radius:2px;margin:12px auto 0;flex-shrink:0}.hd-close{position:absolute;top:14px;right:18px;width:30px;height:30px;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);font-size:12px;color:var(--text-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur-fast)}.hd-close:hover{background:#ffffff1a}.hd-hero{display:flex;align-items:center;gap:13px;padding:18px 20px 16px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0;background-image:var(--grad-hero)}.hd-hero-icon{width:52px;height:52px;border-radius:16px;border:1.5px solid;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}.hd-hero-text{flex:1;min-width:0}.hd-habit-name{font-size:20px;font-weight:700;letter-spacing:-.3px}.hd-habit-identity{font-size:13px;font-weight:500;margin-top:2px}.hd-today-status{width:34px;height:34px;border-radius:50%;background:#ffffff0a;border:1.5px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#ffffff26;flex-shrink:0}.hd-today-status.done{background:#30d1581f;border-color:#30d15859;color:#30d158;box-shadow:0 0 16px #30d15833}.hd-tab-bar{display:flex;padding:0 20px;gap:0;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.hd-tab{flex:1;padding:12px 0;font-size:13px;font-weight:500;color:var(--text-3);text-align:center;border-bottom:2px solid transparent;transition:all var(--dur-fast);cursor:pointer;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font)}.hd-tab.active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent)}.hd-body{flex:1;overflow-y:auto;padding:0 0 calc(32px + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch}.hd-body::-webkit-scrollbar{display:none}.hd-section{padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.04)}.hd-section-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:13px}.hd-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.hd-info-item{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border)}.hd-info-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3)}.hd-info-value{font-size:13px;font-weight:550;color:var(--text-2)}.hd-stats-row{display:flex;gap:10px}.hd-stat-pill{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;padding:16px 8px}.hd-stat-value{font-size:24px;font-weight:800;letter-spacing:-.8px;line-height:1}.hd-stat-label{font-size:10px;color:var(--text-3);font-weight:500;text-align:center}.hd-no-mood{font-size:13px;color:var(--text-3);line-height:1.5;font-style:italic}.hd-mood-summary{font-size:13px;color:var(--text-2);margin-bottom:13px}.hd-mood-summary strong{color:var(--text-1)}.hd-mood-bars{display:flex;flex-direction:column;gap:8px}.hd-mood-bar-row{display:flex;align-items:center;gap:10px}.hd-mood-bar-emoji{font-size:18px;width:24px;text-align:center;flex-shrink:0}.hd-mood-bar-track{flex:1;height:7px;background:#ffffff0a;border-radius:4px;overflow:hidden}.hd-mood-bar-fill{height:100%;border-radius:4px;min-width:4px}.hd-mood-bar-count{font-size:12px;color:var(--text-3);width:22px;text-align:right;flex-shrink:0}.hd-recovery-prompt{margin:16px 20px 0;background:#ff9f0a12;border:1px solid rgba(255,159,10,.22);border-radius:18px;padding:16px;overflow:hidden}.hd-recovery-prompt-top{display:flex;align-items:flex-start;gap:11px;margin-bottom:13px}.hd-recovery-icon{font-size:24px;color:#ff9f0a;flex-shrink:0;line-height:1}.hd-recovery-title{font-size:14px;font-weight:600;color:#ff9f0a;margin-bottom:3px}.hd-recovery-sub{font-size:12px;color:var(--text-2);line-height:1.45}.hd-recovery-actions{display:flex;gap:8px}.hd-recovery-btn-skip{flex:1;padding:11px;border-radius:12px;background:var(--glass-bg);border:1px solid var(--glass-border);font-size:13px;color:var(--text-2);font-weight:500;cursor:pointer;font-family:var(--font)}.hd-recovery-btn-do{flex:2.5;padding:11px;border-radius:12px;background:#ff9f0a26;border:1px solid rgba(255,159,10,.35);font-size:13px;color:#ff9f0a;font-weight:600;cursor:pointer;font-family:var(--font);text-align:left;line-height:1.3}.hd-credit-clear{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#30d1580f;border:1px solid rgba(48,209,88,.15);border-radius:14px}.hd-credit-clear-icon{font-size:16px;color:#30d158}.hd-credit-clear-text{font-size:13px;color:var(--text-2)}.hd-credit-section{background:#ff9f0a0f;border:1px solid rgba(255,159,10,.18);border-radius:16px;padding:16px}.hd-credit-header{display:flex;align-items:center;gap:10px;margin-bottom:13px}.hd-credit-icon{font-size:20px;color:#ff9f0a;flex-shrink:0}.hd-credit-title{font-size:14px;font-weight:600;color:#ff9f0a;margin-bottom:2px}.hd-credit-sub{font-size:12px;color:var(--text-3)}.hd-credit-sessions{margin-left:auto;font-size:13px;font-weight:700;color:#ff9f0a;background:#ff9f0a1f;padding:4px 10px;border-radius:var(--radius-full);flex-shrink:0}.hd-credit-track{height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;margin-bottom:7px}.hd-credit-fill{height:100%;background:linear-gradient(90deg,#ff9f0a,#ff6b00);border-radius:3px}.hd-credit-progress-label{font-size:11px;color:var(--text-3);margin-bottom:12px}.hd-credit-science{font-size:12px;color:var(--text-3);line-height:1.55;font-style:italic;margin-bottom:13px}.hd-credit-cta{width:100%;padding:12px;border-radius:12px;background:#ff9f0a26;border:1px solid rgba(255,159,10,.35);color:#ff9f0a;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);text-align:left}.hd-credit-done-badge{padding:12px 14px;border-radius:12px;background:#30d15814;border:1px solid rgba(48,209,88,.2);color:#30d158;font-size:13px;font-weight:600}.hd-elastic-intro{font-size:13px;color:var(--text-3);margin-bottom:12px;line-height:1.45}.hd-elastic{display:flex;flex-direction:column;gap:8px}.hd-elastic-row{display:flex;align-items:flex-start;gap:11px;padding:13px 14px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px}.hd-elastic-badge{font-size:9px;font-weight:800;letter-spacing:.09em;padding:4px 9px;border-radius:7px;border:1px solid;flex-shrink:0;margin-top:1px}.hd-elastic-content{flex:1}.hd-elastic-desc{font-size:14px;font-weight:600;margin-bottom:3px}.hd-elastic-hint{font-size:12px;color:var(--text-3)}.hd-journal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.hd-journal-header .hd-section-label{margin-bottom:0}.hd-journal-add-btn{font-size:12px;font-weight:600;color:var(--accent);padding:6px 14px;border-radius:var(--radius-full);background:var(--accent-soft);border:1px solid var(--accent-border);cursor:pointer;font-family:var(--font)}.hd-journal-list{display:flex;flex-direction:column;gap:2px}.hd-journal-entry{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.03)}.hd-journal-date{font-size:11px;color:var(--text-3);font-weight:500;white-space:nowrap;min-width:48px;flex-shrink:0}.hd-journal-text{font-size:13px;color:var(--text-2);line-height:1.45}.hd-journal-cta{display:block;width:calc(100% - 40px);margin:8px 20px 20px;padding:13px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);font-size:14px;font-weight:500;color:var(--text-2);cursor:pointer;text-align:center;font-family:var(--font);transition:all var(--dur-fast)}.hd-journal-cta:hover{background:#ffffff0f;border-color:#ffffff1a}.habit-detail-btn{width:28px;height:28px;border-radius:8px;background:var(--glass-bg);border:1px solid var(--glass-border);font-size:14px;color:#ffffff2e;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all var(--dur-fast)}.habit-detail-btn:hover{background:#ffffff12;color:#fff6}@media(prefers-color-scheme:light){.hd-sheet{background:#fffffff7}.hd-close{background:#0000000a}}.modal-overlay{position:fixed;inset:0;z-index:500;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.modal-sheet{width:100%;max-width:480px;max-height:92vh;background:#101016f5;backdrop-filter:saturate(180%) blur(30px);-webkit-backdrop-filter:saturate(180%) blur(30px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-modal)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 6px;position:relative}.modal-drag-handle{position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;border-radius:99px;background:#ffffff26}.modal-title{font-size:17px;font-weight:700;color:var(--text-1)}.modal-close-btn{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#ffffff14;color:var(--text-2);transition:background .15s}.modal-close-btn:hover{background:#ffffff24}.step-indicators{display:flex;gap:6px;justify-content:center;padding:10px 0 4px}.step-dot{width:8px;height:8px;border-radius:50%;background:#ffffff1a;transition:background .3s,transform .3s}.step-dot.active{background:var(--accent);transform:scale(1.15)}.modal-body{padding:12px 18px 24px;overflow-y:auto;flex:1}.modal-step-title{font-size:20px;font-weight:700;margin-bottom:16px;line-height:1.3}.modal-step-sub{font-size:13px;color:var(--text-2);margin:-10px 0 18px;line-height:1.45}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:8px}.form-optional{font-weight:400;color:var(--text-3)}.form-hint{font-weight:400;font-size:11px;color:var(--text-3)}.form-hint-text{font-size:12px;color:var(--text-3);margin:-4px 0 10px;line-height:1.4}.form-micro-hint{font-size:11px;color:var(--text-3);margin-top:6px}.form-input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);font-size:15px;background:var(--bg-inset);border:1px solid var(--border);color:var(--text-1);transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-3)}.form-error{color:var(--red);font-size:13px;margin-bottom:12px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--red-soft)}.icon-picker-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:4px}.icon-pick{aspect-ratio:1;border-radius:10px;font-size:20px;display:grid;place-items:center;background:var(--bg-inset);border:2px solid transparent;transition:all .15s;padding:0}.icon-pick:hover{background:#ffffff0f}.icon-pick.selected{border-color:var(--accent)}.color-picker-row{display:flex;gap:6px;flex-wrap:wrap}.color-swatch{width:32px;height:32px;border-radius:50%;border:2.5px solid transparent;transition:transform .15s,border-color .15s,box-shadow .2s;display:grid;place-items:center;padding:0}.color-swatch:hover{transform:scale(1.12)}.color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2.5px #fff3,0 0 16px currentColor;transform:scale(1.15)}.swatch-check{font-size:14px;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.cat-pill{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--text-2);background:var(--bg-inset);border:1.5px solid var(--border);transition:all .15s}.cat-pill span:first-child{font-size:18px}.cat-pill:hover{background:#ffffff0f}.cat-pill.active{font-weight:600}.freq-pills{display:flex;gap:6px;flex-wrap:wrap}.freq-pill{padding:8px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-2);background:var(--bg-inset);border:1px solid var(--border);transition:all .15s}.freq-pill:hover{border-color:var(--accent-border)}.freq-pill.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:600}.day-picker{display:flex;gap:5px}.day-btn{flex:1;padding:10px 0;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-3);background:var(--bg-inset);border:1.5px solid var(--border);transition:all .15s;text-align:center}.day-btn:hover{border-color:#ffffff26}.day-btn.active{font-weight:700}.time-input{max-width:160px}.clear-reminder-btn{margin-top:6px;font-size:12px;color:var(--red);padding:4px 10px;border-radius:var(--radius-full);background:var(--red-soft)}.target-row{display:flex;gap:8px}.target-input{max-width:80px;text-align:center}.unit-input{flex:1}.target-preview{margin-top:8px;font-size:13px;color:var(--accent);background:var(--accent-soft);padding:8px 12px;border-radius:var(--radius-sm)}.stacking-preview{display:flex;flex-direction:column;gap:8px}.stack-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.stack-select{width:100%;padding:12px 14px;font-size:14px;appearance:none;cursor:pointer}.stack-action-pill{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--accent-soft);border:1px solid var(--accent-border);font-size:14px;font-weight:500;color:var(--text-1)}.modal-actions{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}.modal-back-btn{display:flex;align-items:center;gap:4px;padding:10px 16px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-2);background:var(--bg-inset);border:1px solid var(--border)}.modal-next-btn{display:flex;align-items:center;gap:4px;padding:10px 20px;border-radius:var(--radius-full);font-size:14px;font-weight:600;color:#fff;background:var(--accent);transition:opacity .15s}.modal-next-btn:hover{opacity:.88}.modal-submit-btn{display:flex;align-items:center;gap:6px;padding:12px 22px;border-radius:var(--radius-full);font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#5E5CE6);box-shadow:0 4px 16px #0a84ff59;transition:opacity .15s,transform .15s}.modal-submit-btn:hover{opacity:.9;transform:scale(1.01)}@media(prefers-color-scheme:light){.modal-sheet{background:#fffffffa}.modal-drag-handle{background:#0000001f}.modal-close-btn{background:#0000000f}.icon-pick{background:#0000000a}.icon-pick:hover{background:#00000012}.color-swatch.selected{border-color:#000}.swatch-check{color:#fff}}.apple-login-overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9999;padding:1rem;animation:appleFadeIn .3s ease-out forwards}@keyframes appleFadeIn{0%{opacity:0}to{opacity:1}}.apple-login-card{width:100%;max-width:360px;background:#1c1c1ed9;border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:2.5rem 2rem;box-shadow:0 20px 40px #0009,inset 0 1px 1px #ffffff1a;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;animation:appleSlideUp .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes appleSlideUp{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.apple-close-btn{position:absolute;top:1.25rem;right:1.25rem;background:#ffffff1a;border:none;color:#fff9;cursor:pointer;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:all .2s}.apple-close-btn:hover{background:#fff3;color:#fff}.apple-login-header{text-align:center;margin-bottom:2rem}.apple-logo-holder{width:48px;height:48px;background:linear-gradient(135deg,#505050,#1e1e1e);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#fff;box-shadow:0 4px 10px #0000004d;border:1px solid rgba(255,255,255,.2)}.apple-login-header h2{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .5rem;letter-spacing:-.5px}.apple-login-header p{font-size:.95rem;color:#fff9;margin:0;line-height:1.4}.apple-login-body{display:flex;flex-direction:column}.provider-list{display:flex;flex-direction:column;gap:.8rem}.apple-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.85rem;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.25,1,.5,1);border:none}.apple-btn:active{transform:scale(.97)}.apple-sso{background:#fff;color:#000}.apple-sso:hover{background:#f0f0f0}.google-sso{background:#f4f4f4;color:#333}.google-sso:hover{background:#e5e5e5}.meta-sso{background:#1877f2;color:#fff}.meta-sso:hover{background:#166fe5}.email-sso{background:#ffffff1a;color:#fff}.email-sso:hover{background:#ffffff26}.apple-divider{display:flex;align-items:center;text-align:center;margin:.5rem 0;color:#fff6;font-size:.85rem}.apple-divider:before,.apple-divider:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.1)}.apple-divider span{padding:0 .8rem}.apple-form{display:flex;flex-direction:column;gap:1rem}.apple-input-group{position:relative}.apple-input{width:100%;background:#0003;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.9rem 1rem;border-radius:12px;font-size:1rem;transition:all .2s;box-sizing:border-box}.apple-input::placeholder{color:#fff6}.apple-input:focus{outline:none;border-color:#0a84ff;background:#0000004d;box-shadow:0 0 0 4px #0a84ff26}.apple-otp-input{text-align:center;letter-spacing:.5rem;font-size:1.5rem;font-weight:600;padding:1rem}.apple-btn-primary{background:#0a84ff;color:#fff;font-weight:600;margin-top:.5rem}.apple-btn-primary:hover{background:#0070e0}.apple-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.apple-text-link{background:transparent;border:none;color:#0a84ff;font-size:.95rem;cursor:pointer;padding:0;font-weight:500;transition:color .2s}.apple-text-link:hover{color:#5ac8fa;text-decoration:underline}.apple-footer-text{text-align:center;color:#fff9;font-size:.9rem;margin-top:1rem}.mt-4{margin-top:1rem;display:block;text-align:center}.apple-error-banner{background:#ff453a26;border:1px solid rgba(255,69,58,.3);color:#ff453a;padding:.8rem;border-radius:10px;margin-bottom:1.5rem;font-size:.9rem;text-align:center;font-weight:500}.summary-view{padding:52px 16px 20px;min-height:100vh}.summary-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px}.summary-title{font-size:34px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:4px;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.summary-date{font-size:13px;color:var(--text-3);font-weight:400}.summary-header-right{display:flex;align-items:center;gap:8px}.profile-btn{width:38px;height:38px;border-radius:50%;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;color:var(--text-2);flex-shrink:0;transition:all var(--dur-fast)}.profile-btn:hover{background:#ffffff14;border-color:#ffffff1f}.add-habit-fab{width:38px;height:38px;border-radius:50%;background:var(--grad-accent);color:#fff;font-size:20px;font-weight:300;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-fab);transition:transform var(--dur-fast),opacity var(--dur-fast);line-height:1}.add-habit-fab:hover{opacity:.9;transform:scale(1.05)}.bento-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;gap:10px;margin-bottom:26px}.bento-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;transition:all var(--dur-normal) var(--ease-out);overflow:hidden;position:relative}.bento-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);pointer-events:none}.bento-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}.bento-big-num{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1}.bento-small-label{font-size:11px;color:var(--text-3);margin-top:4px}.bento-hero{grid-column:1 / -1;align-items:center;padding:22px 14px 20px;background:var(--glass-bg);background-image:var(--grad-hero)}.bento-hero-sub{font-size:14px;font-weight:600;margin-top:8px;letter-spacing:-.2px}.bento-score,.bento-recovery{justify-content:space-between}.bento-week{padding:14px 16px;justify-content:space-between}.bento-badges-summary{grid-column:1 / -1;flex-direction:row;align-items:center;gap:14px;padding:14px 16px}.bento-badges-summary .bento-label{margin-bottom:0}.bento-badges-summary .bento-big-num{font-size:28px}.bento-badge-dots{display:flex;flex-wrap:wrap;gap:4px;flex:1}.badge-dot{width:8px;height:8px;border-radius:50%;background:#ffffff0d;transition:all .4s var(--ease-out)}.badge-dot.earned{background:#ff9f0a;box-shadow:0 0 6px #ff9f0a80}.hero-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;margin:4px 0}.hero-ring-center{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none}.hero-ring-num{font-size:46px;font-weight:900;letter-spacing:-2.5px;line-height:1;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-ring-denom{font-size:13px;color:var(--text-3);font-weight:500}.sparkline-inner{display:flex;flex-direction:column;gap:8px;width:100%}.sparkline-top{display:flex;align-items:center;justify-content:space-between}.sparkline-avg{font-size:20px;font-weight:800;letter-spacing:-.8px}.sparkline-svg{width:100%;height:40px;display:block;overflow:visible}.sparkline-days{display:flex;justify-content:space-between;font-size:10px;color:var(--text-3);font-weight:500}.summary-section{margin-bottom:20px}.section-header-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.section-title{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3)}.section-hint{font-size:11px;color:var(--text-3)}.mini-rings-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.mini-rings-scroll::-webkit-scrollbar{display:none}.mini-ring-btn{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;padding:8px 6px 6px;border-radius:16px;border:none;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);cursor:pointer;font-family:var(--font);color:inherit;transition:all var(--dur-fast);-webkit-tap-highlight-color:transparent}.mini-ring-btn:active{background:#ffffff0f;transform:scale(.95)}.mini-ring-svg-wrap{position:relative;display:flex;align-items:center;justify-content:center}.mini-ring-icon{position:absolute;font-size:16px;line-height:1}.mini-ring-name{font-size:10px;font-weight:500;color:var(--text-2);max-width:58px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-ring-pct{font-size:11px;font-weight:700;line-height:1}.mini-ring-streak{font-size:9px;color:var(--amber);font-weight:600}.achievement-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.achievement-card{display:flex;align-items:center;gap:10px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:13px 12px;cursor:pointer;text-align:left;font-family:var(--font);color:inherit;transition:all var(--dur-fast);-webkit-tap-highlight-color:transparent;border-left:3px solid var(--accentColor, rgba(255,255,255,.08))}.achievement-card:active{background:#ffffff0f;transform:scale(.98)}.ach-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ach-ring-emoji{position:absolute;font-size:15px;line-height:1}.ach-info{flex:1;min-width:0}.ach-label{font-size:13px;font-weight:600;line-height:1.2;margin-bottom:3px}.ach-count{font-size:11px;font-weight:500}.ach-chevron{font-size:18px;color:#ffffff1f;flex-shrink:0}.badge-sheet-backdrop{position:fixed;inset:0;background:#000000a6;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:400;display:flex;align-items:flex-end;justify-content:center}.badge-sheet{position:relative;width:100%;max-width:480px;max-height:88vh;background:#121218f5;backdrop-filter:saturate(180%) blur(30px);-webkit-backdrop-filter:saturate(180%) blur(30px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid rgba(255,255,255,.08);border-bottom:none;display:flex;flex-direction:column;overflow:hidden}.badge-sheet-handle{width:36px;height:4px;background:#ffffff24;border-radius:2px;margin:12px auto 0;flex-shrink:0}.badge-sheet-close{position:absolute;top:14px;right:18px;font-size:15px;font-weight:600;color:var(--accent);cursor:pointer;background:none;border:none;font-family:var(--font)}.badge-sheet-header{display:flex;align-items:center;gap:13px;padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.badge-sheet-emoji{font-size:28px;flex-shrink:0}.badge-sheet-title{font-size:20px;font-weight:700;letter-spacing:-.3px}.badge-sheet-desc{font-size:12px;color:var(--text-3);margin-top:2px}.badge-sheet-count{margin-left:auto;font-size:16px;font-weight:800;flex-shrink:0}.badge-sheet-body{flex:1;overflow-y:auto;padding:16px 16px calc(32px + env(safe-area-inset-bottom,0px))}.badge-sheet-body::-webkit-scrollbar{display:none}.badge-sheet-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:10px}.badge-sheet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.badge-full-card{display:flex;flex-direction:column;align-items:flex-start;gap:5px;padding:13px 12px;border-radius:16px;border:1.5px solid rgba(255,255,255,.06);background:#ffffff05;cursor:pointer;font-family:var(--font);color:inherit;text-align:left;transition:all var(--dur-fast)}.badge-full-card.earned:hover{background:#ffffff0d}.badge-full-card.locked{opacity:.35;cursor:default}.badge-full-card.active{border-width:2px}.badge-full-emoji{font-size:26px;line-height:1}.badge-full-name{font-size:13px;font-weight:600;line-height:1.2}.badge-full-habits{font-size:14px}.locked-emoji{filter:grayscale(1);opacity:.5}.locked-name{color:#ffffff40}.badge-winners-inline{overflow:hidden;display:flex;flex-direction:column;gap:5px;width:100%;margin-top:4px}.badge-winner-pill{font-size:11px;font-weight:600;padding:4px 8px;border-radius:8px;border:1px solid;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-strip-wrap{margin:10px -16px 24px;position:relative}.date-strip{display:flex;gap:12px;overflow-x:auto;padding:4px 16px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.date-strip::-webkit-scrollbar{display:none}.date-pill{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:48px;padding:10px 0;border-radius:14px;background:var(--glass-bg);border:1px solid var(--glass-border);transition:all var(--dur-fast);flex-shrink:0}.date-pill.selected{background:var(--accent-soft);border-color:var(--accent-border);box-shadow:0 4px 12px var(--accent-glow)}.date-pill.today{border-color:var(--accent)}.date-pill.complete{border-color:var(--green-soft)}.date-pill-day{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text-3);letter-spacing:.05em}.date-pill.selected .date-pill-day{color:var(--accent)}.date-pill-num{font-size:18px;font-weight:800;letter-spacing:-.5px;color:var(--text-1)}.date-pill.selected .date-pill-num{color:var(--accent)}.date-pill-indicator{display:flex;gap:2px;height:4px}.date-dot{width:4px;height:4px;border-radius:50%}.date-dot.done{background:var(--green);box-shadow:0 0 4px var(--green)}.date-dot.partial{background:var(--amber)}.date-dot.missed{background:var(--red);opacity:.6}.cat-filter-row{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:4px 0 16px}.cat-filter-row::-webkit-scrollbar{display:none}.cat-filter-pill{padding:7px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:500;color:var(--text-2);background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);white-space:nowrap;flex-shrink:0;transition:all var(--dur-fast)}.cat-filter-pill:hover{border-color:#ffffff1f}.cat-filter-pill.active{background:var(--accent-soft);border-color:var(--accent-border);color:var(--accent);font-weight:600}.compact-list{display:flex;flex-direction:column;gap:6px}.compact-row{position:relative;display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px 12px 18px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);color:inherit;overflow:hidden;transition:all var(--dur-fast);-webkit-tap-highlight-color:transparent}.compact-row.done{opacity:.4;background:#ffffff04}.compact-row:active{background:#ffffff0d;transform:scale(.99)}.compact-strip{position:absolute;left:0;top:0;bottom:0;width:3px;opacity:.65;border-radius:0 2px 2px 0}.compact-check{width:22px;height:22px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s var(--ease-spring)}.compact-check.checked{box-shadow:0 0 12px var(--accent-glow)}.compact-checkmark{font-size:10px;font-weight:900;color:#fff}.compact-icon{font-size:17px;flex-shrink:0}.compact-info{display:flex;flex-direction:column;min-width:0;flex:1;gap:2px}.compact-name{font-size:14px;font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.15px}.compact-row.done .compact-name{text-decoration:line-through}.compact-cat-tag{font-size:10px;font-weight:500;opacity:.6}.compact-target{font-size:10px;font-weight:600;color:var(--text-3);background:var(--bg-inset);padding:3px 8px;border-radius:var(--radius-full);flex-shrink:0}.compact-debt{font-size:10px;font-weight:600;color:var(--amber);background:var(--amber-soft);border:1px solid rgba(255,159,10,.2);padding:2px 7px;border-radius:var(--radius-full);flex-shrink:0}.compact-flash{font-size:14px;font-weight:700;color:#30d158;flex-shrink:0;text-shadow:0 0 8px rgba(48,209,88,.5)}.compact-empty{text-align:center;padding:24px;font-size:13px;color:var(--text-3)}.profile-backdrop{position:fixed;inset:0;background:#0009;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:400;display:flex;align-items:flex-end;justify-content:center}.profile-sheet{width:100%;max-width:480px;background:#121218f5;backdrop-filter:saturate(180%) blur(30px);-webkit-backdrop-filter:saturate(180%) blur(30px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid rgba(255,255,255,.08);border-bottom:none;padding:0 0 calc(40px + env(safe-area-inset-bottom,0px));text-align:left;display:flex;flex-direction:column}.profile-scroller{flex:1;overflow-y:auto;padding:0 20px}.profile-scroller::-webkit-scrollbar{display:none}.profile-handle{width:36px;height:4px;background:#ffffff24;border-radius:2px;margin:12px auto 20px;flex-shrink:0}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.profile-avatar{width:58px;height:58px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-header-info{flex:1;min-width:0}.profile-name-row{display:flex;align-items:center;gap:8px}.profile-name-input{background:none;border:none;font-family:inherit;font-size:20px;font-weight:700;color:#fff;width:100%;padding:0;outline:none;border-bottom:1.5px dashed rgba(255,255,255,.12)}.profile-name-input:focus{border-bottom-color:var(--accent)}.profile-email{font-size:13px;color:var(--text-3);margin-top:2px}.profile-stats-grid{justify-content:center;gap:0;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;margin-bottom:20px}.profile-stat{flex:1;padding:16px 8px;border-right:1px solid var(--border)}.profile-stat:last-child{border-right:none}.profile-stat span{font-size:22px;font-weight:800;letter-spacing:-.5px;display:block;margin-bottom:3px}.profile-stat p{font-size:11px;color:var(--text-3);font-weight:500}.profile-close-btn{width:100%;padding:14px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);font-size:15px;font-weight:600;color:var(--text-2);cursor:pointer;font-family:var(--font)}@media(prefers-color-scheme:light){.summary-title{background:linear-gradient(135deg,#000,#000000bf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-ring-num{background:linear-gradient(135deg,#000,#000000b3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.badge-sheet,.profile-sheet{background:#fffffff5}}.progress-view{padding:56px 20px 24px}.progress-hero{display:flex;align-items:center;gap:20px;margin-bottom:16px;padding:18px 16px}.progress-hero-stats{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.hero-stat{display:flex;flex-direction:column;gap:2px}.hero-stat-val{font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1}.hero-stat-label{font-size:11px;color:var(--text-3);font-weight:500}.card-section-title{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.055em;margin-bottom:12px}.section-heading{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}.section-sub{font-size:13px;color:var(--text-3);margin-bottom:14px;line-height:1.45}.week-bars{display:flex;gap:6px;align-items:flex-end;height:80px;padding-top:8px}.week-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.week-bar-track{flex:1;width:100%;background:var(--bg-inset);border-radius:5px;display:flex;align-items:flex-end;overflow:hidden}.week-bar-fill{width:100%;background:var(--accent);border-radius:4px;min-height:3px}.week-bar-label{font-size:11px;color:var(--text-3);font-weight:500}.habit-cards-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.habit-progress-card{position:relative;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--dur-normal) var(--ease-out);-webkit-tap-highlight-color:transparent}.habit-progress-card:active{background:#ffffff0d;transform:scale(.99)}.hp-color-strip{position:absolute;left:0;top:0;bottom:0;width:3.5px;opacity:.75}.hp-body{padding:14px 14px 14px 18px}.hp-header{display:flex;align-items:center;gap:11px;margin-bottom:13px}.hp-icon-wrap{width:42px;height:42px;border-radius:12px;border:1.5px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp-icon{font-size:22px}.hp-title-block{flex:1;min-width:0}.hp-name{font-size:15px;font-weight:600}.hp-identity{font-size:12px;font-weight:500;margin-top:2px}.hp-sub-row{display:flex;align-items:center;gap:6px}.hp-cat-tag{font-size:12px;flex-shrink:0}.hp-debt-chip{font-size:10px;font-weight:600;color:var(--amber);background:#ff9f0a1f;border:1px solid rgba(255,159,10,.25);padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0}.hp-chevron{font-size:20px;color:#ffffff26;flex-shrink:0}.hp-stats{display:flex;margin-bottom:13px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow:hidden}.hp-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 6px;border-right:1px solid var(--border)}.hp-stat:last-child{border-right:none}.hp-stat-val{font-size:20px;font-weight:700;letter-spacing:-.5px;line-height:1}.hp-stat-label{font-size:10px;color:var(--text-3);font-weight:500;text-align:center}.heatmap{display:flex;gap:3px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.heatmap::-webkit-scrollbar{display:none}.heatmap-col{display:flex;flex-direction:column;gap:3px;flex-shrink:0}.heatmap-cell{width:11px;height:11px;border-radius:2.5px;transition:transform .15s}.heatmap-cell.off{background:var(--bg-inset)}.heatmap-cell.on{opacity:.85}.heatmap-cell:hover{transform:scale(1.3)}.heatmap-caption{margin-top:7px;font-size:11px;color:var(--text-3)}.goals-view{padding:56px 20px 20px}.card-section-title{font-size:13px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.goals-explainer{margin-bottom:16px}.explainer-steps{display:flex;gap:0;margin-bottom:12px}.explainer-step{flex:1;text-align:center;padding:8px 4px;border-right:1px solid var(--border)}.explainer-step:last-child{border-right:none}.explainer-label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.explainer-note{font-size:13px;color:var(--text-2);line-height:1.5}.explainer-note em{color:var(--text-1);font-style:normal;font-weight:500}.create-goal-btn{width:100%;padding:14px;text-align:center;font-size:15px;font-weight:500;color:var(--accent);background:var(--accent-soft);border:1px dashed var(--accent-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:24px;display:block;transition:background .18s}.create-goal-btn:hover{background:#0a84ff33}.woop-wizard{margin-bottom:24px}.wiz-dots{display:flex;gap:6px;margin-bottom:20px}.wiz-dot{flex:1;height:3px;border-radius:2px;background:var(--bg-inset);transition:all .3s ease}.wiz-dot.active{background:var(--accent)}.wiz-dot.current{box-shadow:0 0 6px var(--accent)}.wiz-step-label{margin-bottom:6px}.wiz-q{font-size:20px;font-weight:700;margin-bottom:6px;letter-spacing:-.3px}.wiz-hint{font-size:13px;color:var(--text-2);line-height:1.4;margin-bottom:14px}.wiz-textarea{width:100%;padding:12px 14px;font-size:15px;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);resize:none;line-height:1.5;outline:none;display:block;box-sizing:border-box}.wiz-textarea:focus{border-color:var(--accent)}.wiz-actions{display:flex;gap:8px;margin-top:14px}.wiz-back{flex:1;padding:13px;border-radius:var(--radius-sm);background:var(--bg-inset);border:1px solid var(--border);font-size:14px;color:var(--text-2);font-weight:500;cursor:pointer}.wiz-next{flex:2;padding:13px;border-radius:var(--radius-sm);background:var(--accent);font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:opacity .18s}.wiz-next:disabled{opacity:.3;cursor:not-allowed}.goals-list{margin-top:8px}.goal-card{margin-bottom:10px;padding:14px;overflow:hidden}.goal-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:8px}.goal-header-left{flex:1;min-width:0}.goal-wish-text{display:block;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.goal-date{display:block}.goal-header-right{display:flex;align-items:center;gap:8px}.goal-delete{font-size:20px;color:var(--text-3);line-height:1;padding:2px 6px;border-radius:6px;transition:color .15s}.goal-delete:hover{color:var(--red)}.goal-chevron{font-size:14px;color:var(--text-3)}.goal-detail{overflow:hidden;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.goal-row{margin-bottom:10px}.goal-row-label{margin-bottom:2px}.goal-row-text{font-size:14px;color:var(--text-2);line-height:1.4}.intention-box{background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:var(--radius-sm);padding:10px 12px;margin-top:4px}.intention-text{font-size:13px;color:var(--text-1);line-height:1.5}.intention-text strong{color:var(--accent)}.goals-empty{text-align:center;padding:40px 20px;color:var(--text-3);font-size:14px}.insights-view{padding:56px 20px 20px}.view-header{margin-bottom:20px}.view-header h1{font-size:28px;font-weight:700;letter-spacing:-.5px}.view-subtitle{font-size:14px;color:var(--text-2);margin-top:2px}.insights-card{margin-bottom:14px}.ins-section-label{display:block;margin-bottom:6px}.ins-card-subtitle{font-size:13px;color:var(--text-2);margin-bottom:14px;line-height:1.4}.chronotype-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.chrono-card{display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 8px;background:var(--bg-inset);border:1.5px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .18s ease}.chrono-card.active{background:var(--accent-soft);border-color:var(--accent)}.chrono-emoji{font-size:24px}.chrono-name{font-size:13px;font-weight:600}.chrono-detail{padding-top:12px;border-top:1px solid var(--border)}.chrono-detail-text{font-size:14px;color:var(--text-2);line-height:1.5;margin-bottom:14px}.chrono-windows{display:flex;flex-direction:column;gap:10px}.window-item{display:flex;align-items:flex-start;gap:10px}.window-icon{font-size:20px;flex-shrink:0}.window-label{font-size:12px;color:var(--text-2);margin-bottom:1px}.window-time{font-size:15px;font-weight:600}.energy-options-vertical{display:flex;flex-direction:column;gap:6px}.energy-row-btn{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-inset);border:1.5px solid transparent;border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:all .18s ease}.energy-row-btn.active{background:var(--accent-soft);border-color:var(--accent)}.energy-row-emoji{font-size:22px;flex-shrink:0}.energy-row-text{flex:1;display:flex;flex-direction:column;gap:1px}.energy-row-title{font-size:14px;font-weight:600}.energy-row-desc{font-size:12px;color:var(--text-2)}.energy-row-check{font-size:14px;color:var(--accent);font-weight:700;flex-shrink:0}.science-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:600;color:var(--text-1);cursor:pointer;padding:0}.science-content{overflow:hidden;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.science-row{margin-bottom:14px}.science-row:last-child{margin-bottom:0}.science-concept{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:3px}.science-desc{font-size:13px;color:var(--text-2);line-height:1.5}.insights-footer{margin-top:20px;padding:16px;text-align:center}.insights-footer p{font-size:12px;color:var(--text-3);line-height:1.5}.reminders-list{display:flex;flex-direction:column;gap:4px}.reminder-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm)}.reminder-icon{font-size:18px;flex-shrink:0}.reminder-name{flex:1;font-size:13px;font-weight:500;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reminder-time-input{padding:6px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;background:var(--bg-card);border:1px solid var(--border);color:var(--text-1);max-width:110px;font-family:var(--font)}.reminder-time-input:focus{border-color:var(--accent)}.reminder-clear{width:24px;height:24px;border-radius:50%;background:#ff453a1f;color:var(--red);font-size:10px;display:grid;place-items:center;flex-shrink:0;cursor:pointer;transition:background .15s}.reminder-clear:hover{background:#ff453a33}.reminder-empty{text-align:center;padding:14px;font-size:13px;color:var(--text-3)}.export-btns{display:flex;gap:8px}.export-btn{flex:1;padding:12px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-2);background:var(--bg-inset);border:1px solid var(--border);cursor:pointer;text-align:center;font-family:var(--font);transition:all .2s}.export-btn:hover{border-color:var(--accent-border);color:var(--accent)}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative}.view-area{flex:1;padding-bottom:88px}.tab-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:space-around;padding:6px 0 calc(6px + env(safe-area-inset-bottom,0px));background:#0c0c12b8;backdrop-filter:saturate(200%) blur(30px);-webkit-backdrop-filter:saturate(200%) blur(30px);border-top:1px solid rgba(255,255,255,.06);box-shadow:0 -1px #ffffff08,0 -12px 40px #0000004d}.tab-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 8px;min-width:56px;font-size:10px;font-weight:500;letter-spacing:.02em;transition:color var(--dur-fast) ease,transform var(--dur-fast);color:#ffffff40;position:relative}.tab-btn:active{transform:scale(.88)}.tab-btn.active{color:var(--accent);font-weight:600}.tab-btn.active:after{content:"";position:absolute;top:-3px;left:50%;transform:translate(-50%);width:5px;height:3px;border-radius:99px;background:var(--accent);box-shadow:0 0 10px var(--accent-glow);animation:tab-glow-in .3s var(--ease-spring)}@keyframes tab-glow-in{0%{width:0;opacity:0}to{width:5px;opacity:1}}.tab-btn.active svg{filter:drop-shadow(0 0 6px var(--accent-glow))}@media(prefers-color-scheme:light){.tab-bar{background:#ffffffc7;border-top-color:#0000000f;box-shadow:0 -1px #0000000a,0 -8px 30px #0000000f}.tab-btn{color:#00000047}.tab-btn.active{color:var(--accent)}}
