.dt-root{z-index:9999;pointer-events:none;width:calc(100% - 24px);max-width:680px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.dt-bar,.dt-panel{pointer-events:all;-webkit-backdrop-filter:blur(12px);background:#0f0f1ef5;border:1px solid #ffffff1a}.dt-bar{border-radius:12px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.dt-panel{border-radius:12px;margin-top:6px;padding:14px}.dt-panel-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:12px;display:grid}.dt-badge{color:#fff;letter-spacing:.08em;text-transform:uppercase;background:#e63946;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:700}.dt-divider{background:#ffffff1f;flex-shrink:0;width:1px;height:24px}.dt-group{align-items:center;gap:6px;display:flex}.dt-label{color:#ffffff80;white-space:nowrap;font-size:11px}.dt-phase-pill{color:#afa9ec;background:#534ab759;border:1px solid #afa9ec66;border-radius:4px;padding:1px 7px;font-size:10px}.dt-btn{color:#e0f7fa;cursor:pointer;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff1f;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:11px;transition:background .15s}.dt-btn:hover{background:#ffffff21}.dt-btn-accent{color:#5dcaa5;background:#2a9d8f40;border-color:#2a9d8f80}.dt-btn-accent:hover{background:#2a9d8f61}.dt-btn-warn{color:#fac775;background:#ef9f272e;border-color:#ef9f2766}.dt-btn-warn:hover{background:#ef9f2747}.dt-btn-danger{color:#f09595;background:#e24b4a2e;border-color:#e24b4a66}.dt-btn-danger:hover{background:#e24b4a47}.dt-log-status{color:#5dcaa5;font-size:11px}.dt-section-label{color:#ffffff4d;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-size:9px}.dt-jump-row{flex-wrap:wrap;gap:4px;display:flex}.dt-jump-btn{color:#ffffff80;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:5px;padding:3px 7px;font-family:inherit;font-size:10px;transition:all .12s}.dt-jump-btn.active,.dt-jump-btn:hover{color:#5dcaa5;background:#2a9d8f47;border-color:#2a9d8f8c}.dt-radio-row{cursor:pointer;align-items:center;gap:6px;margin-bottom:5px;display:flex}.dt-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dt-dot-improving{background:#5dcaa5}.dt-dot-plateau{background:#fac775}.dt-dot-struggling{background:#f09595}.dt-radio-label{color:#fff9;font-size:11px}.dt-context{background:#ffffff0a;border-radius:8px;padding:8px 10px}.dt-ctx-row{justify-content:space-between;margin-bottom:3px;display:flex}.dt-ctx-key{color:#ffffff59;font-size:10px}.dt-ctx-val{color:#ffffffa6;font-size:10px}.dt-footer-note{text-align:center;color:#fff3;letter-spacing:.04em;margin-top:10px;font-size:9px}.dt-tabs{border-bottom:1px solid #ffffff14;gap:4px;margin-bottom:12px;padding-bottom:8px;display:flex}.dt-tab{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 12px;font-family:inherit;font-size:12px;transition:all .12s;position:relative}.dt-tab.active{color:#ffffffd9;background:#ffffff14}.dt-tab:hover:not(.active){color:#fff9}.dt-tab-alert{background:#f09595;border-radius:50%;width:6px;height:6px;position:absolute;top:4px;right:4px}.dlp-root{flex-direction:column;gap:8px;max-height:420px;display:flex}.dlp-summary{background:#ffffff0a;border-radius:8px;align-items:center;gap:12px;padding:8px 10px;display:flex}.dlp-stat{flex-direction:column;align-items:center;gap:1px;display:flex}.dlp-stat-num{font-size:18px;font-weight:600;line-height:1}.dlp-stat-label{color:#ffffff4d;text-transform:uppercase;letter-spacing:.06em;font-size:9px}.dlp-btn{cursor:pointer;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff1f;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:11px;transition:background .12s}.dlp-btn-export{color:#5dcaa5;background:#5dcaa51a;border-color:#5dcaa559}.dlp-btn-export:hover{background:#5dcaa533}.dlp-btn-clear{color:#fff6}.dlp-btn-clear:hover{background:#ffffff1f}.dlp-filters{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.dlp-filter-btn{color:#ffffff73;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff17;border-radius:5px;padding:3px 8px;font-family:inherit;font-size:10px;transition:all .12s}.dlp-filter-btn.active,.dlp-filter-btn:hover{color:#afa9ec;background:#afa9ec33;border-color:#afa9ec66}.dlp-failures-toggle{color:#ffffff59;cursor:pointer;align-items:center;gap:4px;margin-left:auto;font-size:10px;display:flex}.dlp-list{flex-direction:column;gap:3px;max-height:280px;display:flex;overflow-y:auto}.dlp-empty{color:#ffffff40;text-align:center;padding:24px 0;font-size:11px}.dlp-event{cursor:pointer;background:#ffffff0a;border-left:2px solid #0000;border-radius:6px;padding:6px 8px;transition:background .1s}.dlp-event:hover{background:#ffffff12}.dlp-event-failed{background:#f095950f;border-left-color:#f09595}.dlp-event-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.dlp-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.dlp-cat{color:#ffffff4d;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;font-size:9px}.dlp-ref{color:#afa9ec;background:#afa9ec33;border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:9px}.dlp-label{color:#ffffffb3;flex:1;min-width:0;font-size:11px}.dlp-date{color:#ffffff40;flex-shrink:0;font-size:9px}.dlp-detail{color:#ffffff8c;white-space:pre;background:#0000004d;border-radius:4px;margin:6px 0 0;padding:6px 8px;font-size:10px;line-height:1.5;overflow-x:auto}.dlp-footer{color:#fff3;text-align:center;letter-spacing:.04em;font-size:9px}:root{--primary:#2a9d8f;--primary-light:#a8dadc;--primary-dark:#1f7a6f;--accent:#e76f51;--accent-light:#fdf0ed;--success:#52b788;--success-light:#e8f5e9;--warning:#f4a261;--warning-light:#fff3e0;--danger:#e63946;--danger-light:#fcebeb;--bg:#fafaf7;--card-bg:#fff;--text-primary:#264653;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--pain-0:#52b788;--pain-1:#6bc494;--pain-2:#84d1a0;--pain-3:#a8daac;--pain-4:#d4e89c;--pain-5:#f4e285;--pain-6:#f4c261;--pain-7:#f4a261;--pain-8:#e8835a;--pain-9:#e06352;--pain-10:#e63946;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.5rem;--text-2xl:2rem;--text-3xl:2.5rem;--text-display:3rem;--text-hero:4rem;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #2646530d;--shadow-md:0 4px 12px #26465314;--shadow-lg:0 8px 24px #2646531f;--ease-out:cubic-bezier(.16, 1, .3, 1);--duration-fast:.2s;--duration-normal:.3s;--duration-slow:.4s;--duration-celebration:.8s;--stagger-delay:80ms}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-container{min-height:100dvh;padding:var(--space-lg);background:var(--bg);justify-content:center;align-items:center;display:flex}.auth-card{width:100%;max-width:420px;padding:var(--space-xl);background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:auth-slide-up .4s var(--ease-out)}@keyframes auth-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-logo{text-align:center;margin-bottom:var(--space-md);font-size:48px}.auth-title{font-size:var(--text-xl);color:var(--text-primary);text-align:center;margin:0 0 var(--space-sm);font-weight:700}.auth-subtitle{font-size:var(--text-base);color:var(--text-secondary);text-align:center;margin:0 0 var(--space-lg);line-height:1.5}.auth-badge{background:var(--success-light);color:var(--success);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center;margin-bottom:var(--space-lg);font-weight:500}.auth-actions{gap:var(--space-sm);flex-direction:column;display:flex}.auth-btn{width:100%;padding:14px var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-weight:600;font-family:var(--font-sans);border:none}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn-primary{background:var(--primary);color:#fff}.auth-btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.auth-btn-secondary{background:var(--bg);color:var(--text-primary);border:1px solid var(--border)}.auth-btn-secondary:hover:not(:disabled){background:var(--border-light)}.auth-back{color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;margin-bottom:var(--space-md);font-family:var(--font-sans);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;padding:0;display:inline-block}.auth-back:hover{color:var(--text-primary)}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-field{gap:var(--space-xs);flex-direction:column;display:flex}.auth-field label{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.auth-field input{padding:12px var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);background:var(--card-bg);transition:border-color var(--duration-fast) var(--ease-out);font-family:var(--font-sans);outline:none}.auth-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2a9d8f1a}.auth-field input::placeholder{color:var(--text-tertiary)}.auth-field-hint{font-size:var(--text-xs);color:var(--text-tertiary)}.stepper-btn:hover{background:var(--bg);border-color:var(--primary)}.stepper-btn:active{transform:scale(.95)}.auth-link{text-align:center;width:100%;color:var(--primary);font-size:var(--text-sm);cursor:pointer;padding:var(--space-sm) 0 0;font-family:var(--font-sans);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;display:block}.auth-link:hover{color:var(--primary-dark)}.auth-error{background:var(--danger-light);color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-md);animation:auth-slide-up .3s var(--ease-out)}.auth-success{background:var(--success-light);color:var(--success);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-md);animation:auth-slide-up .3s var(--ease-out)}.daily-log-form{gap:var(--space-lg);flex-direction:column;display:flex}.log-section{gap:var(--space-sm);flex-direction:column;display:flex}.log-section-label{font-size:var(--text-sm);color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.pain-slider-container{align-items:center;gap:var(--space-md);padding:var(--space-md) 0;display:flex}.pain-slider{appearance:none;border-radius:var(--radius-full);cursor:pointer;outline:none;flex:1;height:8px}.pain-slider::-webkit-slider-thumb{appearance:none;background:var(--card-bg);border:3px solid var(--primary);width:32px;height:32px;box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out);border-radius:50%}.pain-slider::-webkit-slider-thumb:active{transform:scale(1.15)}.pain-slider::-moz-range-thumb{background:var(--card-bg);border:3px solid var(--primary);width:32px;height:32px;box-shadow:var(--shadow-md);cursor:pointer;border-radius:50%}.pain-score-display{font-size:var(--text-display);color:var(--text-primary);text-align:center;min-width:60px;font-weight:700;line-height:1}.pain-labels{font-size:var(--text-xs);color:var(--text-tertiary);justify-content:space-between;display:flex}.pain-delta{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-sm);text-align:center;font-weight:500}.pain-delta-good{background:var(--success-light);color:var(--success)}.pain-delta-bad{background:var(--warning-light);color:var(--warning)}.exercise-checklist{gap:var(--space-sm);flex-direction:column;display:flex}.exercise-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex}.exercise-item:hover{border-color:var(--primary);background:#2a9d8f08}.exercise-item-checked{background:var(--success-light);border-color:var(--success)}.exercise-checkbox{width:22px;height:22px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.exercise-label{font-size:var(--text-base);color:var(--text-primary);cursor:pointer}.all-complete-badge,.perfect-day-badge{text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.all-complete-badge{background:var(--success-light);color:var(--success)}.perfect-day-badge{background:linear-gradient(135deg, var(--success-light), #e76f511a);color:var(--accent)}.stepper{align-items:center;gap:var(--space-md);display:flex}.stepper-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card-bg);width:44px;height:44px;font-size:var(--text-xl);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-family:var(--font-sans);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex}.stepper-btn:hover:not(:disabled){background:var(--bg);border-color:var(--primary)}.stepper-btn:active:not(:disabled){transform:scale(.95)}.stepper-btn:disabled{opacity:.5;cursor:not-allowed}.stepper-value{font-size:var(--text-xl);color:var(--text-primary);text-align:center;min-width:90px;font-weight:700}.new-record-badge{text-align:center;padding:var(--space-xs) var(--space-sm);background:var(--accent-light);color:var(--accent);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600}.habit-item{padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.habit-item-completed{background:var(--success-light);border-color:var(--success)}.habit-checkbox-label{align-items:center;gap:var(--space-sm);cursor:pointer;display:flex}.log-notes{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);background:var(--card-bg);font-family:var(--font-sans);resize:vertical;transition:border-color var(--duration-fast) var(--ease-out);outline:none}.log-notes:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2a9d8f1a}.log-notes::placeholder{color:var(--text-tertiary)}.log-actions{padding-top:var(--space-sm)}.log-submit-btn{width:100%}.log-existing-state{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.log-already-logged{font-size:var(--text-sm);color:var(--text-secondary);text-align:center}.milestone-tracker{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg)}.milestone-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.milestone-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:600}.milestone-progress{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.milestone-progress-bar{background:var(--border-light);border-radius:var(--radius-full);height:6px;margin-bottom:var(--space-md);overflow:hidden}.milestone-progress-fill{background:var(--primary);border-radius:var(--radius-full);height:100%}.milestone-list{gap:var(--space-sm);flex-direction:column;display:flex}.milestone-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex}.milestone-item:hover{background:var(--bg)}.milestone-item-completed{opacity:.7}.milestone-item-completed .milestone-label{color:var(--text-tertiary);text-decoration:line-through}.milestone-checkbox{width:20px;height:20px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.milestone-label{font-size:var(--text-base);color:var(--text-primary);cursor:pointer}.log-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);transition:all var(--duration-fast) var(--ease-out)}.log-card:hover{box-shadow:var(--shadow-sm)}.log-card-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.log-card-date{flex-direction:column;display:flex}.log-card-day{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.log-card-monthday{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.log-card-phase{gap:var(--space-xs);display:flex}.phase-badge{font-size:var(--text-xs);border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-dark);padding:2px 8px;font-weight:500}.week-badge{font-size:var(--text-xs);border-radius:var(--radius-full);background:var(--bg);color:var(--text-secondary);padding:2px 8px;font-weight:500}.log-card-body{gap:var(--space-lg);margin-bottom:var(--space-sm);display:flex}.log-card-metric{flex-direction:column;align-items:center;display:flex}.log-card-pain{font-size:var(--text-2xl);font-weight:700;line-height:1}.log-card-count{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700;line-height:1}.log-card-metric-label{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.log-card-notes{font-size:var(--text-sm);color:var(--text-secondary);padding-top:var(--space-sm);border-top:1px solid var(--border-light)}.log-card-delete{margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);border:1px solid var(--danger-light);border-radius:var(--radius-sm);color:var(--danger);font-size:var(--text-xs);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);background:0 0;display:block}.log-card-delete:hover{background:var(--danger-light)}.week-page{padding:var(--space-lg);max-width:600px;margin:0 auto;padding-bottom:100px}.week-header{text-align:center;margin-bottom:var(--space-xl)}.week-nav{margin-bottom:var(--space-md);justify-content:space-between;display:flex}.week-nav-btn{color:var(--primary);font-size:var(--text-sm);cursor:pointer;padding:var(--space-xs) var(--space-sm);font-weight:500;font-family:var(--font-sans);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none}.week-nav-btn:hover{color:var(--primary-dark)}.week-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:700}.week-dates{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-sm)}.week-phase-badge{padding:var(--space-xs) var(--space-md);background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;display:inline-block}.week-section{margin-bottom:var(--space-xl)}.week-section-title{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md);font-weight:600}.week-empty-state{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);padding:var(--space-lg);background:var(--card-bg);border:1px dashed var(--border);border-radius:var(--radius-md)}.week-logs-grid{gap:var(--space-xs);grid-template-columns:repeat(7,1fr);display:grid}.week-log-mini{padding:var(--space-xs);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;align-items:center;display:flex}.week-log-day{font-size:var(--text-xs);color:var(--text-tertiary)}.week-log-pain{font-size:var(--text-lg);font-weight:700}.week-videos-list{gap:var(--space-sm);flex-direction:column;display:flex}.week-video-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);display:flex}.week-video-icon{background:var(--primary-light);width:40px;height:40px;color:var(--primary);border-radius:var(--radius-md);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.week-video-title{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.week-video-desc{font-size:var(--text-sm);color:var(--text-secondary)}.week-complete-section{padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md)}.week-complete-label{align-items:center;gap:var(--space-sm);cursor:pointer;font-size:var(--text-base);color:var(--text-primary);display:flex}.week-bottom-nav{gap:var(--space-sm);margin-top:var(--space-xl);display:flex}.week-bottom-nav .auth-btn{flex:1}.logs-page{padding:var(--space-lg);max-width:600px;margin:0 auto;padding-bottom:100px}.logs-header{margin-bottom:var(--space-xl)}.logs-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:700}.logs-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.logs-empty{text-align:center;padding:var(--space-2xl);color:var(--text-secondary)}.logs-week-nav{gap:var(--space-xs);margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);display:flex;overflow-x:auto}.logs-week-btn{padding:var(--space-xs) var(--space-sm);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer;font-weight:500;font-family:var(--font-sans);white-space:nowrap;transition:all var(--duration-fast) var(--ease-out)}.logs-week-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark)}.logs-month-section{margin-bottom:var(--space-xl)}.logs-month-title{font-size:var(--text-base);color:var(--text-secondary);margin:0 0 var(--space-md);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.logs-list{gap:var(--space-sm);flex-direction:column;display:flex}.calf-raise-counter{align-items:center;gap:var(--space-md);padding:var(--space-2xl) 0 var(--space-xl);flex-direction:column;display:flex}.calf-raise-controls{align-items:center;gap:var(--space-xl);justify-content:center;width:100%;display:flex}.calf-raise-btn{background:var(--primary);color:#fff;width:56px;height:56px;font-size:1.75rem;font-family:var(--font-sans);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:transform 80ms var(--ease-out), background-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-sm);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:400;line-height:1;display:flex}.calf-raise-btn:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-md)}.calf-raise-btn:active:not(:disabled){transform:scale(.92)}.calf-raise-btn:disabled{background:var(--border);color:var(--text-tertiary);cursor:not-allowed;box-shadow:none}.calf-raise-number-wrap{justify-content:center;align-items:center;min-width:120px;height:80px;display:flex;overflow:hidden}.calf-raise-number{font-size:var(--text-hero);color:var(--text-primary);text-align:center;min-width:120px;font-weight:700;line-height:1;display:block}.calf-raise-label{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-top:calc(-1 * var(--space-sm));font-weight:500}.calf-raise-record-badge{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:var(--accent-light);color:var(--accent);border-radius:var(--radius-full);font-size:var(--text-sm);border:1px solid #e76f5140;font-weight:700;display:inline-flex;box-shadow:0 2px 8px #e76f5126}.phase2-log-form{gap:var(--space-lg);flex-direction:column;display:flex}.phase2-completed-card{background:var(--success-light);border:1px solid var(--success);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center}.phase2-completed-header{font-size:var(--text-sm);color:var(--success);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-md);font-weight:600}.phase2-completed-metrics{justify-content:center;gap:var(--space-2xl);margin-bottom:var(--space-lg);display:flex}.phase2-completed-metric{align-items:center;gap:var(--space-xs);flex-direction:column;display:flex}.phase2-completed-value{font-size:var(--text-hero);color:var(--text-primary);font-weight:700;line-height:1}.phase2-completed-metric-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.phase2-crossover-status{font-size:var(--text-xs);color:var(--text-secondary);text-align:center;padding-top:var(--space-sm);border-top:1px solid #52b7884d}.phase3-log-form{gap:var(--space-lg);flex-direction:column;display:flex}.habit-row{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);min-height:64px;transition:background-color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);display:flex}.habit-row:hover:not(.habit-row-checked){border-color:var(--primary);background:#2a9d8f08}.habit-row-checked{border-color:var(--success);background:#52b78814}.habit-row-left{align-items:center;gap:var(--space-sm);cursor:pointer;flex:1;min-width:0;display:flex}.habit-checkbox{width:22px;min-width:22px;height:22px;accent-color:var(--success);cursor:pointer;flex-shrink:0;margin:-11px;padding:11px}.habit-row-text{flex-direction:column;gap:2px;min-width:0;display:flex}.habit-row-label{font-size:var(--text-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;transition:color var(--duration-fast) var(--ease-out);font-weight:600;overflow:hidden}.habit-row-hint{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;transition:color var(--duration-fast) var(--ease-out);overflow:hidden}.habit-row-checked .habit-row-hint{color:var(--success);opacity:.85}.habit-rep-stepper{align-items:center;gap:var(--space-xs);transition:opacity var(--duration-fast) var(--ease-out);flex-shrink:0;display:flex}.habit-rep-btn{background:var(--primary);color:#fff;width:44px;height:44px;font-size:var(--text-lg);font-family:var(--font-sans);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:transform 80ms var(--ease-out), background-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-sm);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:400;line-height:1;display:flex}.habit-rep-btn:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-md)}.habit-rep-btn:active:not(:disabled){transform:scale(.92)}.habit-rep-btn:disabled{background:var(--border);color:var(--text-tertiary);cursor:not-allowed;box-shadow:none}.habit-rep-value{flex-direction:column;align-items:center;gap:0;min-width:40px;display:flex}.habit-rep-number{font-size:var(--text-xl);color:var(--text-primary);text-align:center;font-weight:700;line-height:1}.habit-rep-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:1px;line-height:1}.habit-grid-container{gap:var(--space-md);flex-direction:column;display:flex}.habit-grid{gap:var(--space-sm);flex-direction:column;display:flex}.perfect-day-banner{align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);background:var(--success);border-radius:var(--radius-lg);text-align:center;flex-direction:column;display:flex;box-shadow:0 4px 20px #52b78840}.perfect-day-icons{gap:var(--space-md);align-items:center;display:flex}.perfect-day-icon{font-size:var(--text-xl);color:#ffffffe6;display:inline-block}.perfect-day-text{font-size:var(--text-xl);color:#fff;letter-spacing:.02em;font-weight:700}.phase3-high-pain-callout{padding:var(--space-sm) var(--space-md);background:var(--warning-light);color:var(--text-secondary);border-radius:var(--radius-md);border-left:3px solid var(--warning);font-size:var(--text-sm);margin-top:var(--space-sm);line-height:1.5}.phase3-completed-card{background:var(--success-light);border:1px solid var(--success);border-radius:var(--radius-lg);padding:var(--space-xl)}.phase3-completed-header{font-size:var(--text-sm);color:var(--success);text-transform:uppercase;letter-spacing:.06em;text-align:center;margin-bottom:var(--space-lg);font-weight:700}.phase3-completed-pain-row{align-items:center;gap:var(--space-xs);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid #52b78840;flex-direction:column;display:flex}.phase3-completed-pain-value{font-size:var(--text-hero);color:var(--text-primary);font-weight:700;line-height:1}.phase3-completed-pain-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.phase3-completed-habits{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.phase3-completed-habit-row{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);opacity:.5;transition:opacity var(--duration-fast) var(--ease-out);background:#ffffff80;display:flex}.phase3-completed-habit-done{opacity:1}.phase3-completed-habit-icon{font-size:var(--text-base);color:var(--success);text-align:center;flex-shrink:0;width:20px;font-weight:700}.phase3-completed-habit-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.phase3-completed-habit-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.phase3-completed-habit-hint{font-size:var(--text-xs);color:var(--text-secondary)}.phase3-completed-habit-reps{font-size:var(--text-sm);color:var(--success);flex-shrink:0;font-weight:700}.phase3-completed-perfect-badge{text-align:center;padding:var(--space-sm) var(--space-md);background:var(--success);color:#fff;border-radius:var(--radius-md);font-size:var(--text-sm);margin-top:var(--space-sm);font-weight:700}.maintenance-header{text-align:center;margin-bottom:var(--space-xl)}.maintenance-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:700}.maintenance-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0 0 var(--space-sm)}.maintenance-phase-badge{padding:var(--space-xs) var(--space-md);background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;display:inline-block}.home-page{padding:var(--space-md);padding-bottom:calc(80px + env(safe-area-inset-bottom) + var(--space-md));gap:var(--space-md);flex-direction:column;max-width:480px;margin:0 auto;display:flex}.home-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 2px 8px #0000000f}.streak-counter-card{text-align:center}.streak-number-wrap{justify-content:center;align-items:baseline;gap:var(--space-sm);line-height:1;display:flex}.streak-day-label{font-size:var(--text-xl);color:var(--text-secondary);letter-spacing:.02em;font-weight:500}.streak-value{font-size:var(--text-hero);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:700;line-height:1}.streak-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-xs) 0 0;line-height:1.4}.streak-best{font-size:var(--text-xs);color:var(--text-tertiary);margin:var(--space-xs) 0 0}.streak-counter-zero{padding:var(--space-xl) var(--space-lg)}.streak-start-msg{font-size:var(--text-xl);color:var(--text-secondary);text-align:center;margin:0;font-weight:500}.weekly-ring-wrap{align-items:center;gap:var(--space-sm);padding:var(--space-lg);flex-direction:column;display:flex}.weekly-ring-svg{width:100%;min-width:180px;max-width:240px}.weekly-ring-label{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin:0}.today-log-card{gap:var(--space-sm);flex-direction:column;display:flex}.today-log-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-xs);flex-wrap:wrap;display:flex}.today-log-card-phase{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.today-log-card-phase-name{font-size:var(--text-xs);color:var(--text-tertiary)}.today-log-done-badge{font-size:var(--text-xs);color:var(--success);background:var(--success-light);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.today-log-card-pending .today-log-card-prompt{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.5}.today-log-btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);width:100%;height:56px;font-size:var(--text-base);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);margin-top:var(--space-xs);border:none}.today-log-btn:hover,.today-log-btn:active{background:var(--primary-dark)}.today-log-card-done{border-left:4px solid var(--success)}.today-log-pain-row{align-items:baseline;gap:var(--space-xs);display:flex}.today-log-pain-score{font-size:var(--text-hero);font-weight:700;line-height:1}.today-log-pain-label{font-size:var(--text-sm);color:var(--text-secondary)}.today-log-summary-row{flex-direction:column;gap:2px;display:flex}.today-log-summary-detail{font-size:var(--text-base);color:var(--text-secondary)}.today-log-summary-good{color:var(--success);font-weight:500}.today-log-summary-record{color:var(--accent);font-weight:600}.today-log-no-edit-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin:var(--space-xs) 0 0}.progress-snapshot{padding:var(--space-md) var(--space-lg)}.progress-snapshot-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0 0 var(--space-sm);font-weight:600}.progress-snapshot-legend{gap:var(--space-md);margin-top:var(--space-xs);display:flex}.snapshot-legend-item{font-size:var(--text-xs);align-items:center;gap:4px;display:flex}.snapshot-legend-item:before{content:"";border-radius:1px;width:12px;height:2px;display:inline-block}.snapshot-legend-pain:before{background:var(--primary)}.snapshot-legend-positive:before{background:var(--success)}.progress-snapshot-empty{justify-content:center;align-items:center;min-height:80px;display:flex}.progress-snapshot-empty-msg{font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;margin:0}.dr-schutza-card{background:#2a9d8f0f}.dr-schutza-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.dr-schutza-avatar{background:var(--primary-light);width:40px;height:40px;color:var(--primary-dark);font-size:var(--text-xs);letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.dr-schutza-heading{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.dr-schutza-message-wrap{min-height:48px;position:relative}.dr-schutza-message{font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-sm);font-style:italic;line-height:1.6}.dr-schutza-message-clamped{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.dr-schutza-expand{font-size:var(--text-sm);color:var(--primary);font-family:var(--font-sans);cursor:pointer;margin-bottom:var(--space-xs);background:0 0;border:none;padding:0;font-weight:500}.dr-schutza-video-link{font-size:var(--text-sm);color:var(--primary);font-family:var(--font-sans);cursor:pointer;transition:color var(--duration-fast) var(--ease-out);text-align:left;background:0 0;border:none;padding:0;font-weight:500}.dr-schutza-video-link:hover{color:var(--primary-dark)}.then-vs-now-card{background:#e76f510d;border:1px solid #e76f5126;overflow:hidden}.then-vs-now-header{margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.then-vs-now-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:700}.then-vs-now-dismiss{font-size:var(--text-xl);color:var(--text-tertiary);cursor:pointer;padding:var(--space-sm);min-width:44px;min-height:44px;line-height:1;font-family:var(--font-sans);transition:color var(--duration-fast) var(--ease-out);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.then-vs-now-dismiss:hover{color:var(--text-primary)}.then-vs-now-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-md)}.then-vs-now-columns{align-items:center;gap:var(--space-md);display:flex}.then-vs-now-col{gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.then-vs-now-col-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin:0;font-weight:700}.then-vs-now-metric{flex-direction:column;gap:2px;display:flex}.then-vs-now-metric-value{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700;line-height:1}.then-vs-now-metric-label{font-size:var(--text-xs);color:var(--text-tertiary)}.then-vs-now-col-date{font-size:var(--text-xs);color:var(--text-tertiary);margin:var(--space-xs) 0 0}.then-vs-now-arrow{font-size:var(--text-xl);color:var(--text-tertiary);flex-shrink:0}.home-loading{justify-content:center;align-items:center;gap:var(--space-md);min-height:200px;color:var(--text-secondary);font-size:var(--text-sm);flex-direction:column;display:flex}.home-error{padding:var(--space-md);background:var(--danger-light);color:var(--danger);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.progress-page{padding:var(--space-md);padding-bottom:calc(80px + env(safe-area-inset-bottom) + var(--space-md));gap:var(--space-md);flex-direction:column;max-width:480px;margin:0 auto;display:flex}.progress-page-title{font-size:var(--text-xl);color:var(--text-primary);margin:0;font-weight:700}.section-heading{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md);font-weight:700}.progress-loading{justify-content:center;align-items:center;gap:var(--space-md);min-height:200px;color:var(--text-secondary);font-size:var(--text-sm);flex-direction:column;display:flex}.progress-error{padding:var(--space-md);background:var(--danger-light);color:var(--danger);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.progress-section-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin:0 0 var(--space-sm);padding:0 var(--space-xs);font-weight:700}.journey-map-outer{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-md) 0;overflow:hidden;box-shadow:0 2px 8px #0000000f}.journey-scroll{scrollbar-width:none;-ms-overflow-style:none;overflow-x:auto}.journey-scroll::-webkit-scrollbar{display:none}.journey-inner{box-sizing:content-box}.journey-phase-label{font-size:var(--text-xs);color:var(--text-secondary);text-align:center;border-bottom:2px solid var(--border-light);box-sizing:border-box;justify-content:center;align-items:flex-end;height:28px;padding-bottom:4px;font-weight:600;display:flex}.journey-nodes-row{align-items:center;margin-top:12px;display:flex}.journey-slot{flex-shrink:0;align-items:center;display:flex}.journey-node-wrap{flex-shrink:0;position:relative}.journey-node{cursor:pointer;font-family:var(--font-sans);transition:box-shadow var(--duration-fast) var(--ease-out);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.journey-node:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.journey-node-num{font-size:var(--text-sm);font-weight:700;line-height:1}.journey-node-completed{background:var(--primary);color:#fff;box-shadow:0 2px 6px #2a9d8f40}.journey-node-completed:hover{box-shadow:0 3px 10px #2a9d8f59}.journey-node-current{background:var(--primary);color:#fff;box-shadow:0 2px 10px #2a9d8f59}.journey-node-future{color:var(--text-secondary);border:2px solid var(--primary-light);opacity:.5;cursor:default;background:0 0}.journey-node-checkmark{background:var(--success);color:#fff;pointer-events:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.journey-connector{border-radius:2px;flex:1;height:3px;margin:0 2px}.journey-tooltip{background:var(--text-primary);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;z-index:10;padding:4px 8px;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.journey-tooltip:after{content:"";border:4px solid #0000;border-top-color:var(--text-primary);position:absolute;top:100%;left:50%;transform:translate(-50%)}.journey-map-maintenance{align-items:center;gap:var(--space-sm);padding:var(--space-md);flex-direction:column;display:flex}.journey-node-maintenance{background:var(--success);color:#fff;width:64px;height:64px;font-size:var(--text-lg);flex-direction:column;gap:0}.journey-node-maintenance .journey-node-check{font-size:20px;line-height:1}.journey-node-maintenance .journey-node-num{font-size:var(--text-xs)}.journey-maintenance-label{font-size:var(--text-base);color:var(--success);font-weight:600}.ring-row-scroll{scrollbar-width:none;-ms-overflow-style:none;background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-md);overflow-x:auto;box-shadow:0 2px 8px #0000000f}.ring-row-scroll::-webkit-scrollbar{display:none}.ring-row-inner{align-items:flex-start;gap:12px;width:max-content;display:flex}.ring-row-item{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out);background:0 0;border:none;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;padding:4px;display:flex}.ring-row-item:hover{background:var(--border-light)}.ring-row-label{color:var(--text-secondary);font-size:11px;font-weight:500}.ring-row-empty{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:var(--text-sm)}.phase-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 2px 8px #0000000f}.phase-card-complete{border-left:4px solid var(--success)}.phase-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.phase-card-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:700}.phase-card-dates{font-size:var(--text-sm);color:var(--text-secondary);margin:2px 0 0}.phase-card-badge{font-size:var(--text-xs);color:var(--success);background:var(--success-light);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;padding:2px 8px;font-weight:700}.phase-card-empty{font-size:var(--text-sm);color:var(--text-tertiary);margin:0;font-style:italic}.phase-chart-wrap{margin:0 -4px var(--space-sm)}.phase-chart-legend{gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.phase-legend-item{font-size:var(--text-xs);color:var(--text-secondary);align-items:center;gap:4px;display:flex}.phase-legend-item:before{content:"";border-radius:1px;width:16px;height:2px;display:inline-block}.phase-legend-pain:before{background:linear-gradient(to right, var(--danger), var(--success))}.phase-legend-calf:before{background:var(--primary)}.phase-stats-row{gap:var(--space-sm);margin-top:var(--space-md);border-top:1px solid var(--border-light);padding-top:var(--space-md);display:flex}.phase-stat-tile{text-align:center;flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.phase-stat-value{font-size:var(--text-xl);color:var(--text-primary);font-weight:700;line-height:1}.phase-stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;line-height:1.2}.phase3-streak-highlight{padding:var(--space-md) 0;border-top:1px solid var(--border-light);margin-top:var(--space-sm);flex-direction:column;align-items:center;gap:2px;display:flex}.phase3-streak-number{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1}.phase3-streak-label{font-size:var(--text-base);color:var(--text-secondary)}.phase3-streak-best{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:2px}.records-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.record-tile{background:var(--bg);padding:var(--space-md);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:80px;display:flex;position:relative}.record-value{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700;line-height:1}.record-label{font-size:var(--text-xs);color:var(--text-tertiary);line-height:1.3}.record-new-badge{background:var(--accent);color:#fff;letter-spacing:.04em;text-transform:uppercase;pointer-events:none;border-radius:20px;padding:3px 6px;font-size:9px;font-weight:700;line-height:1;position:absolute;top:6px;right:6px}.weekly-table-card{overflow:hidden}.weekly-table-scroll{margin:0 calc(-1 * var(--space-lg));padding:0 var(--space-lg);overflow-x:auto}.weekly-table{border-collapse:collapse;width:100%;min-width:420px;font-size:var(--text-sm)}.weekly-th{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:var(--space-xs) var(--space-sm);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--card-bg);font-weight:700}.weekly-th-sticky,.weekly-td-sticky{background:inherit;z-index:1;position:sticky;left:0}.weekly-td{padding:var(--space-xs) var(--space-sm);color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:middle;white-space:nowrap}.weekly-td-week{background:inherit;align-items:center;gap:4px;display:flex}.weekly-week-num{font-weight:600}.weekly-current-tag{font-size:var(--text-xs);color:var(--primary);font-weight:500}.weekly-tr{background:var(--card-bg);transition:background var(--duration-fast) var(--ease-out)}.weekly-tr-current,.weekly-tr-current .weekly-td-sticky{background:#2a9d8f0f}.weekly-tr-future{opacity:.4}.weekly-tr-clickable{cursor:pointer}.weekly-tr-clickable:hover,.weekly-tr-clickable:hover .weekly-td-sticky{background:var(--border-light)}.videos-page{padding:var(--space-lg);background:var(--bg);min-height:100vh;padding-bottom:80px}.videos-page-title{font-size:var(--text-xl);color:var(--text-primary);margin:0 0 var(--space-lg) 0;font-weight:700}.videos-section{margin-bottom:var(--space-xl)}.videos-section-header{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md) 0;font-weight:600}.video-card{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-fast) var(--ease-out);margin-bottom:var(--space-sm);overflow:hidden}.video-card:hover{box-shadow:var(--shadow-md)}.video-card--locked{opacity:.5}.video-card--locked .video-card-body{pointer-events:none}.video-thumbnail{aspect-ratio:16/9;background:#e5e7eb;position:relative;overflow:hidden}.video-thumbnail-placeholder{background:linear-gradient(135deg,#cbd5e1,#e2e8f0);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.video-play-icon{color:var(--primary);opacity:.8;font-size:2rem}.video-lock-icon{opacity:.6;font-size:1.5rem}.video-watched-badge{top:var(--space-sm);right:var(--space-sm);border-radius:var(--radius-full);background:#ffffffe6;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;box-shadow:0 1px 3px #00000026}.video-card-body{padding:var(--space-sm) var(--space-md) var(--space-md)}.video-card-title{font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-xs) 0;font-weight:500;line-height:1.3}.video-card-duration{font-size:var(--text-xs);color:var(--text-secondary);margin:0}.video-reason{font-size:var(--text-xs);color:var(--text-secondary);margin:var(--space-xs) 0 0 0;font-style:italic;line-height:1.4}.video-list-item{position:relative}.video-continue-highlight .video-card{border-left:3px solid var(--primary)}.video-continue-label{top:var(--space-xs);left:var(--space-sm);z-index:2;font-size:var(--text-xs);color:var(--primary);border-radius:var(--radius-sm);background:#ffffffeb;padding:2px 8px;font-weight:600;position:absolute;box-shadow:0 1px 2px #0000001a}.video-recommendations-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.phase-completion-banner{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--success-light);color:var(--success);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-md);font-weight:500;display:flex}.phase-completion-icon{font-size:var(--text-base);font-weight:700}.phase-accordion{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-sm);overflow:hidden}.phase-accordion-header{width:100%;padding:var(--space-md);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;gap:var(--space-sm);background:0 0;border:none;display:flex}.phase-accordion-header:hover{background:var(--border-light)}.phase-accordion-left{align-items:center;gap:var(--space-sm);flex:1;min-width:0;display:flex}.phase-lock-icon{font-size:var(--text-sm)}.phase-accordion-name{font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.phase-accordion-right{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.phase-unlock-label,.phase-accordion-progress{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.phase-accordion-chevron{font-size:var(--text-sm);color:var(--text-tertiary);transition:transform var(--duration-fast) var(--ease-out)}.phase-accordion-chevron.expanded{transform:rotate(90deg)}.phase-accordion-content{padding:0 var(--space-sm) var(--space-sm)}.video-player-backdrop{z-index:200;background:#00000080;position:fixed;inset:0}.video-player-modal{background:var(--card-bg);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:201;max-height:90vh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.video-player-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.video-player-title{font-size:var(--text-base);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;font-weight:600;overflow:hidden}.video-player-close{font-size:var(--text-lg);color:var(--text-secondary);cursor:pointer;padding:var(--space-sm);min-width:44px;min-height:44px;margin-left:var(--space-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:flex}.video-player-iframe-wrapper{padding:0}.video-post-prompt{padding:var(--space-md) var(--space-lg);padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom));background:var(--bg);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.video-post-prompt-text{font-size:var(--text-sm);color:var(--text-primary);margin:0;font-weight:500}.video-post-prompt-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;transition:background var(--duration-fast) var(--ease-out);border:none;font-weight:600}.video-post-prompt-btn:hover{background:var(--primary-dark)}.video-skeleton-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.video-skeleton-card{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.video-skeleton-thumbnail{aspect-ratio:16/9;background:#e5e7eb}.video-skeleton-body{padding:var(--space-sm) var(--space-md) var(--space-md)}.video-skeleton-title{width:70%;height:16px;margin-bottom:var(--space-xs);background:#e5e7eb;border-radius:4px}.video-skeleton-duration{background:#e5e7eb;border-radius:4px;width:30%;height:12px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%) 0 0/200% 100%;animation:1.5s linear infinite shimmer}.videos-offline-banner{background:var(--warning-light);color:var(--warning);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-lg);text-align:center;font-weight:500}.videos-error-inline{background:var(--danger-light);color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-lg)}.notification-permission-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.notification-permission-card--granted{background:linear-gradient(135deg, var(--success-light), #52b7880d);border-color:#52b7884d}.notification-permission-card--denied{border-color:var(--border);background:var(--bg)}.notification-permission-icon{flex-shrink:0;margin-top:2px;font-size:24px}.notification-permission-content{flex:1}.notification-permission-title{font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:600}.notification-permission-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-sm);line-height:1.4}.notification-permission-btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;font-weight:600;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);border:none;display:inline-flex}.notification-permission-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.notification-permission-link{color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;font-family:var(--font-sans);padding:var(--space-xs) 0;text-underline-offset:2px;background:0 0;border:none;text-decoration:underline}.notification-permission-link:hover{color:var(--danger)}.ios-note{font-size:var(--text-xs);color:var(--warning);margin-top:var(--space-xs);line-height:1.4}.notification-time-row{padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.notification-time-label{font-size:var(--text-sm);color:var(--text-secondary)}.notification-time-input{font-size:var(--text-base);font-family:var(--font-sans);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);background:var(--bg);cursor:pointer}.notification-time-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2a9d8f1a}.sound-toggle-row{padding:var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.sound-toggle-label{font-size:var(--text-sm);color:var(--text-secondary)}.toggle-switch{background:var(--border);cursor:pointer;width:48px;height:28px;transition:background var(--duration-fast) var(--ease-out);border:none;border-radius:14px;flex-shrink:0;padding:0;position:relative}.toggle-switch--active{background:var(--primary)}.toggle-switch-knob{width:22px;height:22px;transition:transform var(--duration-fast) var(--ease-out);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle-switch--active .toggle-switch-knob{transform:translate(20px)}.messages-section{margin-top:var(--space-md)}.messages-section-title{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md);font-weight:600}.messages-empty{text-align:center;padding:var(--space-xl);color:var(--text-tertiary);font-size:var(--text-sm)}.message-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm)}.message-card--unread{background:#2a9d8f0a;border-color:#2a9d8f33}.message-card-header{margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.message-card-sender{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.message-card-time{font-size:var(--text-xs);color:var(--text-tertiary)}.message-card-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.nav-badge{background:var(--danger);color:#fff;text-align:center;pointer-events:none;border-radius:9px;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;line-height:18px;position:absolute;top:2px;right:4px}.share-timeline-overlay{z-index:200;background:#0009;align-items:flex-end;display:flex;position:fixed;inset:0}.share-timeline-sheet{background:var(--card-bg);padding:24px 24px calc(24px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;width:100%;max-height:90vh;overflow-y:auto}.share-timeline-preview{object-fit:contain;border-radius:12px;width:100%;max-height:60vh;margin-bottom:20px;display:block}.share-timeline-actions{flex-direction:column;gap:12px;display:flex}.share-btn-primary{background:var(--primary);color:#fff;cursor:pointer;width:100%;font-size:17px;font-weight:600;font-family:var(--font-sans);border:none;border-radius:12px;padding:16px}.share-btn-secondary{width:100%;color:var(--primary);border:2px solid var(--primary);cursor:pointer;font-size:17px;font-weight:600;font-family:var(--font-sans);background:0 0;border-radius:12px;padding:16px}.share-ios-hint{color:var(--text-secondary);text-align:center;margin-top:10px;font-size:13px}.share-timeline-loading{height:200px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:15px;display:flex}.dpm-overlay{z-index:10000;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.dpm-modal{text-align:center;background:#1a1a2e;border:1px solid #ffffff1a;border-radius:20px;width:100%;max-width:300px;padding:28px 24px 20px}.dpm-title{color:#ffffffe6;margin-bottom:4px;font-size:16px;font-weight:600}.dpm-subtitle{color:#fff6;margin-bottom:24px;font-size:12px}.dpm-dots{justify-content:center;gap:14px;margin-bottom:28px;display:flex}.dpm-dot{border:2px solid #fff3;border-radius:50%;width:12px;height:12px;transition:all .15s}.dpm-dot-filled,.dpm-dot-success{background:#5dcaa5;border-color:#5dcaa5}.dpm-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.dpm-key{color:#ffffffd9;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff12;border:1px solid #ffffff1a;border-radius:12px;height:56px;font-size:20px;font-weight:500;transition:background .12s,transform 80ms}.dpm-key:active{background:#ffffff26;transform:scale(.94)}.dpm-key-empty{cursor:default;pointer-events:none;background:0 0;border-color:#0000}.dpm-key-delete{color:#ffffff80;font-size:16px}.dpm-cancel{color:#ffffff4d;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:8px 16px;font-size:13px}.dpm-cancel:active{color:#fff9}@keyframes dpm-shake-anim{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.dpm-shake{animation:.5s dpm-shake-anim}@keyframes dpm-success-pulse{0%,to{opacity:1}50%{opacity:.6}}.dpm-success{animation:.4s infinite dpm-success-pulse}.profile-page{padding:var(--space-lg);max-width:600px;margin:0 auto;padding-bottom:100px}.profile-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-lg);font-weight:700}.profile-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.profile-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.profile-card-title{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md);font-weight:600}.profile-card-header .profile-card-title{margin-bottom:0}.profile-edit-btn{border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-md);font-size:var(--text-sm);color:var(--primary);cursor:pointer;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);background:0 0;font-weight:500}.profile-edit-btn:hover{background:var(--primary-light);border-color:var(--primary)}.profile-info-list{gap:var(--space-sm);flex-direction:column;display:flex}.profile-info-row{padding:var(--space-sm) 0;border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.profile-info-row:last-child{border-bottom:none}.profile-info-label{font-size:var(--text-sm);color:var(--text-secondary)}.profile-info-value{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.profile-edit-form{gap:var(--space-md);flex-direction:column;display:flex}.profile-edit-actions{gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.profile-edit-actions .auth-btn{flex:1}.profile-streak-card{background:linear-gradient(135deg, var(--primary-light), #2a9d8f14);border-color:#2a9d8f33}.profile-streak-row{justify-content:center;align-items:center;gap:var(--space-xl);display:flex}.profile-streak-stat{flex-direction:column;align-items:center;display:flex}.profile-streak-number{font-size:var(--text-hero);color:var(--primary);font-weight:700;line-height:1}.profile-streak-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.profile-streak-divider{background:#2a9d8f33;width:1px;height:48px}.profile-analytics-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.profile-stat{padding:var(--space-md);background:var(--bg);border-radius:var(--radius-md);flex-direction:column;align-items:center;display:flex}.profile-stat:last-child:nth-child(odd){grid-column:1/-1}.profile-stat-number{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700;line-height:1}.profile-stat-label{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-xs);text-align:center}.profile-settings-list{flex-direction:column;display:flex}.profile-setting-btn{padding:var(--space-md);border:none;border-bottom:1px solid var(--border-light);font-size:var(--text-base);color:var(--text-primary);cursor:pointer;font-family:var(--font-sans);transition:background var(--duration-fast) var(--ease-out);text-align:left;background:0 0;justify-content:space-between;align-items:center;width:100%;display:flex}.profile-setting-btn:last-child{border-bottom:none}.profile-setting-btn:hover{background:var(--bg)}.profile-setting-arrow{color:var(--text-tertiary);font-size:var(--text-lg)}.profile-danger-card{border-color:var(--danger-light)}.profile-delete-btn{width:100%;padding:var(--space-md);border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);font-size:var(--text-base);cursor:pointer;font-weight:500;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);background:0 0}.profile-delete-btn:hover{background:var(--danger-light)}.profile-delete-confirm{gap:var(--space-md);flex-direction:column;display:flex}.profile-delete-warning{font-size:var(--text-sm);color:var(--danger);margin:0;line-height:1.5}.profile-version{text-align:center;font-size:var(--text-xs);color:var(--text-tertiary);padding:var(--space-lg) 0}.sync-status-row{border-top:1px solid var(--border-light);color:var(--text-secondary);align-items:center;gap:8px;padding:12px 0;font-size:14px;display:flex}.sync-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sync-dot.synced{background:var(--success)}.sync-dot.pending{background:var(--warning)}.sync-dot.offline{background:var(--text-secondary)}.celebration-overlay{z-index:1000;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#26465380;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.celebration-modal{background:var(--card-bg);border-radius:var(--radius-xl);padding:var(--space-2xl) var(--space-xl);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.celebration-small{padding:var(--space-xl) var(--space-lg)}.celebration-large{max-width:420px}.celebration-emoji{margin-bottom:var(--space-md);font-size:56px;line-height:1;display:block}.celebration-small .celebration-emoji{font-size:40px}.celebration-title{font-size:var(--text-xl);color:var(--text-primary);margin:0 0 var(--space-sm);font-weight:700}.celebration-small .celebration-title{font-size:var(--text-lg)}.celebration-message{font-size:var(--text-base);color:var(--text-secondary);margin:0 0 var(--space-lg);line-height:1.5}.celebration-dismiss{padding:var(--space-sm) var(--space-xl);background:var(--primary);color:#fff;border-radius:var(--radius-full);min-height:44px;font-size:var(--text-sm);cursor:pointer;font-weight:600;font-family:var(--font-sans);transition:all var(--duration-fast) var(--ease-out);border:none;display:inline-block}.celebration-dismiss:hover{background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.celebration-particles{pointer-events:none;width:0;height:0;position:absolute;top:50%;left:50%}.celebration-particle{border-radius:50%;width:10px;height:10px;position:absolute}.recap-page{padding:var(--space-lg);max-width:600px;margin:0 auto;padding-bottom:100px}.recap-header{text-align:center;margin-bottom:var(--space-xl)}.recap-nav{margin-bottom:var(--space-md);justify-content:space-between;display:flex}.recap-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:700}.recap-dates{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-sm)}.recap-stats-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.recap-stat{padding:var(--space-lg) var(--space-md);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;display:flex}.recap-stat-number{font-size:var(--text-3xl);color:var(--text-primary);font-weight:700;line-height:1}.recap-stat-label{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-xs);text-align:center}.recap-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.recap-card-title{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-md);font-weight:600}.recap-empty{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;padding:var(--space-md)}.recap-days-grid{gap:var(--space-xs);grid-template-columns:repeat(7,1fr);display:grid}.recap-day-card{padding:var(--space-sm) var(--space-xs);background:var(--bg);border-radius:var(--radius-sm);flex-direction:column;align-items:center;display:flex}.recap-day-name{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.recap-day-pain{font-size:var(--text-xl);font-weight:700;line-height:1.2}.recap-day-pain-label{color:var(--text-tertiary);font-size:10px}.recap-review-text{font-size:var(--text-base);color:var(--text-primary);margin:0;line-height:1.6}.recap-goals{text-align:center}.recap-goal-text{font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-sm)}.recap-goal-hint{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5}.recap-bottom-nav{gap:var(--space-sm);margin-top:var(--space-xl);display:flex}.recap-bottom-nav .auth-btn{flex:1}.insights-page{padding:var(--space-lg);max-width:600px;margin:0 auto;padding-bottom:100px}.insights-title{font-size:var(--text-3xl);color:var(--text-primary);margin:0 0 var(--space-lg);font-weight:700}.insights-empty{text-align:center;padding:var(--space-2xl);color:var(--text-secondary)}.insights-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.insights-card-title{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-xs);font-weight:600}.insights-card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-md)}.insights-chart-container{width:100%;overflow:hidden}.insights-pie-container{position:relative}.insights-pie-center{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.insights-pie-pct{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700}
