:root{--bg: #f5f0e8;--bg-warm: #faf6ef;--surface: #ffffff;--surface-hover: #fdfcfa;--surface-tint: #f0f9fa;--surface-cyan: #e6f6f8;--ink: #1a2332;--ink-secondary: #4a5568;--ink-muted: #8a95a3;--ink-faint: #b8c0ca;--cyan: #00b8d4;--cyan-bright: #26d9f5;--cyan-deep: #0097a7;--cyan-glow: rgba(0, 184, 212, .12);--cyan-wash: rgba(0, 184, 212, .06);--heart: #e05252;--heart-bg: #fdf0f0;--sleep: #6366f1;--sleep-bg: #eef0ff;--battery-high: #22c55e;--battery-mid: #eab308;--battery-low: #ef4444;--battery-bg: #f0faf0;--steps: #f59e0b;--steps-bg: #fef9ee;--delta-up: #16a34a;--delta-up-bg: #f0fdf4;--delta-down: #dc2626;--delta-down-bg: #fef2f2;--border: #e8e2d8;--border-light: #f0ebe3;--shadow-sm: 0 1px 2px rgba(26, 35, 50, .04);--shadow-md: 0 2px 8px rgba(26, 35, 50, .06), 0 1px 2px rgba(26, 35, 50, .04);--shadow-lg: 0 4px 16px rgba(26, 35, 50, .08), 0 2px 4px rgba(26, 35, 50, .04);--shadow-cyan: 0 4px 20px rgba(0, 184, 212, .15);--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--font-display: "Young Serif", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif;--sidebar-width: 240px;--health-panel-width: 340px;--main-max-width: 1200px;--main-padding: 32px 40px;--main-padding-mobile: 24px 20px;--sp-xs: 4px;--sp-sm: 8px;--sp-md: 16px;--sp-lg: 24px;--sp-xl: 32px;--sp-2xl: 48px;--t-fast: .15s ease;--ease-default: .15s ease;--ease-spring: .6s cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: 1s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 100;--z-overlay: 200;--touch-min: 48px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.5;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;z-index:0;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg width='400' height='400' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 200 Q100 180 200 200 Q300 220 400 200' fill='none' stroke='%231a2332' stroke-width='1'/%3E%3Cpath d='M0 160 Q80 140 160 155 Q240 170 320 150 Q400 130 400 160' fill='none' stroke='%231a2332' stroke-width='0.8'/%3E%3Cpath d='M0 240 Q120 260 200 245 Q280 230 360 250 Q400 260 400 240' fill='none' stroke='%231a2332' stroke-width='0.8'/%3E%3Cpath d='M0 120 Q60 100 140 115 Q220 130 300 108 Q380 86 400 120' fill='none' stroke='%231a2332' stroke-width='0.6'/%3E%3Cpath d='M0 280 Q100 300 180 285 Q260 270 340 290 Q400 305 400 280' fill='none' stroke='%231a2332' stroke-width='0.6'/%3E%3Cpath d='M0 80 Q50 65 120 78 Q200 92 280 70 Q360 48 400 80' fill='none' stroke='%231a2332' stroke-width='0.5'/%3E%3Cpath d='M0 320 Q80 338 170 325 Q260 312 350 332 Q400 342 400 320' fill='none' stroke='%231a2332' stroke-width='0.5'/%3E%3Cpath d='M0 40 Q100 25 200 42 Q300 58 400 40' fill='none' stroke='%231a2332' stroke-width='0.4'/%3E%3Cpath d='M0 360 Q100 375 200 358 Q300 342 400 360' fill='none' stroke='%231a2332' stroke-width='0.4'/%3E%3C/svg%3E");background-size:400px 400px}#root{min-height:100vh;position:relative;z-index:1}h1,h2,h3,h4{font-family:var(--font-display);line-height:1.2;color:var(--ink)}h1{font-size:1.8rem}h2{font-size:1.2rem}h3{font-size:1rem}a{color:var(--cyan-deep);text-decoration:none}a:hover{color:var(--cyan)}button,input{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:wait;opacity:.7}input{width:100%;border:1px solid var(--border);border-radius:var(--r-md);padding:.8rem .95rem;background:var(--surface);color:var(--ink)}input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{to{opacity:1}}@keyframes drawRoute{to{stroke-dashoffset:0}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.tabular-nums{font-variant-numeric:tabular-nums}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;position:relative;z-index:1}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:28px 20px max(28px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:32px;position:sticky;top:0;height:100vh;height:100dvh;overflow-y:auto}.logo{display:flex;align-items:center;gap:12px;padding:0 4px;text-decoration:none}.logo-mark{width:32px;height:32px;flex-shrink:0;border-radius:8px;background:linear-gradient(135deg,#0288d1,#00bcd4);box-shadow:var(--shadow-cyan)}.logo-text{font-family:var(--font-display);font-size:1.35rem;color:var(--ink);letter-spacing:-.01em}.nav{display:flex;flex-direction:column;gap:2px}.nav-section{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);padding:16px 12px 8px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);color:var(--ink-secondary);text-decoration:none;font-size:.9rem;font-weight:450;transition:all var(--ease-default);cursor:pointer;border:none;background:none;width:100%;font-family:inherit}.nav-item:hover{background:var(--bg-warm);color:var(--ink)}.nav-item.active{background:var(--cyan-glow);color:var(--cyan-deep);font-weight:550}.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}.sync-status{margin-top:auto;position:sticky;bottom:0;padding:14px;background:color-mix(in srgb,var(--surface) 78%,var(--bg-warm) 22%);border:1px solid var(--border-light);border-radius:var(--r-md);font-size:.8rem;box-shadow:var(--shadow-sm)}.sync-dot{width:7px;height:7px;border-radius:50%;background:var(--battery-high);display:inline-block;margin-right:6px;box-shadow:0 0 6px #22c55e66;animation:pulse-dot 2s ease-in-out infinite}.sync-dot--syncing{background:var(--cyan);box-shadow:0 0 6px #00b8d466}.sync-dot--error,.sync-dot--unavailable{background:var(--delta-down);box-shadow:0 0 6px #ba3b2859}.sync-dot--not_linked,.sync-dot--loading{background:var(--ink-faint);box-shadow:none}.sync-label{color:var(--ink-secondary);font-weight:500}.sync-time{color:var(--ink-muted);display:block;margin-top:2px;font-size:.75rem}.main{padding:var(--main-padding);max-width:var(--main-max-width)}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;animation:fadeUp .5s ease both}.greeting{font-family:var(--font-display);font-size:1.8rem;color:var(--ink);line-height:1.2}.greeting-sub{color:var(--ink-muted);font-size:.9rem;margin-top:4px;font-weight:400}.header-actions{display:flex;align-items:center;gap:10px}.btn-icon{width:40px;height:40px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ease-default);color:var(--ink-secondary)}.btn-icon:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:var(--shadow-cyan)}.btn-icon.syncing{color:var(--cyan);border-color:var(--cyan);pointer-events:none}.btn-icon.syncing svg{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-menu{display:none}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.85rem;letter-spacing:.02em}.sidebar-overlay{display:none}.content-grid{display:grid;grid-template-columns:1fr var(--health-panel-width);gap:24px}@media(max-width:1100px){.content-grid{grid-template-columns:1fr}}@media(max-width:860px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:-260px;z-index:var(--z-sidebar);transition:left .3s ease;box-shadow:var(--shadow-lg);gap:24px;padding-bottom:max(18px,env(safe-area-inset-bottom))}.sidebar.open{left:0}.sidebar-overlay{display:block;position:fixed;inset:0;background:#1a23324d;z-index:calc(var(--z-sidebar) - 1);animation:fadeUp .2s ease both}.main{padding:16px 14px}.btn-menu{display:flex}.header{align-items:center;margin-bottom:20px}.greeting{font-size:1.4rem}.greeting-sub{font-size:.8rem}.sync-status{bottom:max(0px,env(safe-area-inset-bottom))}}@media(max-width:480px){.main{padding:12px 10px}.header{margin-bottom:16px}.greeting{font-size:1.2rem}}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-content{animation:fadeUp .3s ease-out}.placeholder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-xl);max-width:600px}.placeholder-card h2{margin-bottom:var(--sp-sm)}.placeholder-card p{color:var(--ink-secondary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--sp-lg);background:var(--bg)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--sp-2xl);box-shadow:var(--shadow-lg);animation:fadeUp .4s ease-out}.login-header{text-align:center;margin-bottom:var(--sp-xl)}.login-logo-img{border-radius:var(--r-xl);margin-bottom:var(--sp-sm)}.login-header h1{font-family:var(--font-display);font-size:1.6rem;margin-bottom:2px}.login-sub{color:var(--ink-muted);font-size:.9rem}.login-form-section{margin-top:var(--sp-lg)}.login-form-section h2{font-family:var(--font-body);font-size:1rem;font-weight:600;margin-bottom:var(--sp-xs)}.login-form-section>p{color:var(--ink-muted);font-size:.85rem;margin-bottom:var(--sp-lg)}.login-hint{margin-top:var(--sp-md)}.login-form{display:flex;flex-direction:column;gap:var(--sp-md)}.login-form label{display:flex;flex-direction:column;gap:var(--sp-xs)}.login-form label span{font-size:.85rem;font-weight:500;color:var(--ink-secondary)}.login-form button{margin-top:var(--sp-sm);padding:.8rem;border-radius:var(--r-md);background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));color:#fff;font-weight:600;font-size:.95rem;transition:opacity var(--t-fast)}.login-form button:hover:not(:disabled){opacity:.9}.login-form-section>button{margin-top:var(--sp-sm);padding:.8rem;border-radius:var(--r-md);background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));color:#fff;font-weight:600;font-size:.95rem;transition:opacity var(--t-fast)}.login-form-section>button:hover:not(:disabled){opacity:.9}.login-secret-card{display:flex;flex-direction:column;gap:var(--sp-xs);padding:var(--sp-md);border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-warm)}.login-secret-card span{font-size:.8rem;font-weight:600;color:var(--ink-secondary)}.login-secret-card code{font-size:.95rem;line-height:1.5;word-break:break-word}.login-qr{display:flex;flex-direction:column;align-items:center;gap:var(--sp-sm);padding:var(--sp-md);border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-warm);margin-bottom:var(--sp-md)}.login-qr img{display:block;width:min(200px,100%);height:auto;border-radius:var(--r-sm);background:#f7f4ed}.login-qr p{margin:0;font-size:.8rem;color:var(--ink-muted);text-align:center}.login-qr--loading{justify-content:center;min-height:232px;color:var(--ink-muted);font-size:.9rem}.login-secondary-btn{width:100%;margin-top:var(--sp-md);padding:.8rem;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--ink);font-weight:600;font-size:.95rem;transition:border-color var(--t-fast),color var(--t-fast)}.login-secondary-btn:hover:not(:disabled){border-color:var(--cyan);color:var(--cyan-deep)}.act-filter-bar{display:flex;flex-direction:column;gap:8px;margin-bottom:var(--sp-lg)}.act-filter-group{display:flex}.act-toggle{display:flex;gap:3px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;flex-wrap:wrap}.act-toggle-btn{padding:5px 12px;font-family:var(--font-body);font-size:.78rem;font-weight:550;color:var(--ink-muted);background:none;border:none;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t-fast);white-space:nowrap}.act-toggle-btn:hover{color:var(--ink)}.act-toggle-btn.active{background:var(--surface);color:var(--cyan-deep);box-shadow:var(--shadow-sm)}.activities-count{font-size:.8rem;font-weight:500;color:var(--ink-muted)}.activities-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.featured-activity{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden;cursor:pointer;transition:all .25s ease;animation:fadeUp .5s ease both;margin-bottom:var(--sp-xl)}.featured-activity:hover{box-shadow:var(--shadow-lg);border-color:var(--cyan);transform:translateY(-2px)}.featured-elev{border-top:1px solid var(--border-light)}.featured-elev-stats{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--ink-muted);padding:10px 24px 0}.featured-elev-svg{width:100%;height:auto;display:block;padding:0 4px 12px}.featured-elev-loading{display:flex;align-items:center;justify-content:center;height:80px;border-top:1px solid var(--border-light)}.featured-info{padding:20px 24px}.featured-type{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.featured-title{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);margin:0 0 4px;font-weight:400}.featured-meta{font-size:.82rem;color:var(--ink-muted);margin-bottom:16px}.featured-header-row{display:flex;justify-content:space-between;align-items:center}.featured-header-right{display:flex;align-items:center;gap:10px}.featured-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:16px;border-top:1px solid var(--border-light)}.featured-metric{text-align:center}.featured-metric-value{font-family:var(--font-display);font-size:1.25rem;color:var(--ink);line-height:1.2}.featured-metric-label{font-size:.68rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.activities-feed-section{margin-bottom:var(--sp-xl)}.activities-feed-label{font-family:var(--font-body);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:var(--sp-md)}.activities-load-more{text-align:center;padding:var(--sp-lg) 0}.activities-load-more-btn{padding:12px 32px;font-size:.85rem;font-weight:600;color:var(--cyan-deep);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .2s}.activities-load-more-btn:hover:not(:disabled){background:var(--surface-tint);border-color:var(--cyan);box-shadow:var(--shadow-sm)}.activities-load-more-btn:disabled{opacity:.6;cursor:wait}@media(max-width:860px){.featured-metrics{grid-template-columns:repeat(3,1fr)}.featured-title{font-size:1.2rem}.featured-metric-value{font-size:1.05rem}}@media(max-width:480px){.featured-metrics{grid-template-columns:repeat(3,1fr);gap:6px;padding-top:12px}.featured-metric-value{font-size:.95rem}.featured-metric-label{font-size:.6rem}.featured-info{padding:14px 16px}.featured-title{font-size:1.1rem}.featured-type{font-size:.68rem}.featured-route{min-height:140px}.featured-route-empty{height:140px}}.banner{padding:var(--sp-sm) var(--sp-md);border-radius:var(--r-md);font-size:.85rem;margin-bottom:var(--sp-md)}.banner.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.banner.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.health-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-xl)}.health-page-title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink)}.health-days-toggle{display:flex;gap:4px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.health-days-btn{padding:6px 14px;font-family:var(--font-body);font-size:.8rem;font-weight:550;color:var(--ink-muted);background:none;border:none;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t-fast)}.health-days-btn:hover{color:var(--ink)}.health-days-btn.active{background:var(--surface);color:var(--cyan-deep);box-shadow:var(--shadow-sm)}.health-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.health-card-lg{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.health-card-lg:hover{box-shadow:var(--shadow-md)}.health-card-lg .health-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.health-card-lg .health-card-title{font-weight:600;font-size:.9rem;color:var(--ink);display:flex;align-items:center;gap:8px}.health-card-lg .health-card-title svg{width:18px;height:18px}.health-card-lg .health-card-badge{font-size:.72rem;font-weight:600;padding:3px 12px;border-radius:20px}.health-lg-row{display:grid;grid-template-columns:180px 1fr;gap:24px;align-items:center}.health-lg-row--bars{grid-template-columns:140px 1fr}.health-lg-gauge{display:flex;flex-direction:column;align-items:center;gap:14px}.health-lg-meta{display:flex;flex-direction:column;gap:6px;width:100%}.health-lg-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.health-lg-meta-label{color:var(--ink-muted);font-weight:450}.health-lg-meta-val{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}.health-lg-chart{flex:1;min-width:0}.health-area-svg{width:100%;height:80px;display:block;border-radius:var(--r-sm)}.health-chart-labels{display:flex;justify-content:space-between;font-size:.68rem;color:var(--ink-muted);margin-top:6px;padding:0 2px}.health-chart-avg{font-weight:600;color:var(--ink-secondary)}.health-chart-empty{color:var(--ink-muted);font-size:.85rem;padding:20px 0;text-align:center}.health-bars-chart{flex:1;min-width:0;overflow-x:auto}.health-bars{display:flex;gap:4px;justify-content:space-between;min-width:0}.health-bar-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-width:18px;max-width:36px}.health-bar-track{width:100%;background:#00000008;border-radius:4px;position:relative;display:flex;align-items:flex-end}.health-bar-fill{width:100%;border-radius:4px;min-height:3px;transition:height .6s cubic-bezier(.4,0,.2,1)}.health-bar-val{font-size:.58rem;font-weight:500;color:var(--ink-secondary);line-height:1;font-variant-numeric:tabular-nums}.health-bar-label{font-size:.55rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.5px;line-height:1}.hr-big-display{display:flex;align-items:baseline;gap:6px}.hr-big-display .hr-big{font-family:var(--font-display);font-size:2.8rem;color:var(--heart);line-height:1}.hr-big-display .hr-unit{font-size:.85rem;color:var(--ink-muted)}.hrv-big-display{display:flex;align-items:baseline;gap:6px}.hrv-big-display .hrv-num{font-family:var(--font-display);font-size:2.8rem;color:var(--sleep);line-height:1}.hrv-big-display .hrv-unit{font-size:.85rem;color:var(--ink-muted)}.steps-big-display{text-align:center}.steps-big-num{font-family:var(--font-display);font-size:2rem;color:var(--ink);line-height:1;display:block}.steps-big-label{font-size:.72rem;color:var(--ink-muted);margin-top:4px;display:block}.sleep-detail-col{display:flex;flex-direction:column;gap:10px;align-items:flex-start}.sleep-duration-big{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);line-height:1}.sleep-stages-legend{display:flex;flex-direction:column;gap:4px;font-size:.72rem;color:var(--ink-secondary)}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.sleep-mini-stats{display:flex;flex-wrap:wrap;gap:10px;font-size:.72rem;font-weight:600;padding-top:6px;border-top:1px solid var(--border-light)}.health-card-sm{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s;display:inline-block}.health-card-sm:hover{box-shadow:var(--shadow-md)}.health-card-sm .health-card-head{margin-bottom:12px}.health-card-sm .health-card-title{font-weight:600;font-size:.85rem;color:var(--ink);display:flex;align-items:center;gap:6px}.health-card-sm .health-card-title svg{width:16px;height:16px}.spo2-display{display:flex;align-items:baseline;gap:6px}.spo2-num{font-family:var(--font-display);font-size:2.4rem;color:var(--ink);line-height:1}.spo2-unit{font-size:.9rem;color:var(--ink-muted)}.spo2-note{font-size:.72rem;color:var(--ink-muted);margin-top:6px}.weight-tap-display{text-align:center;cursor:pointer;padding:8px 0;border-radius:var(--r-md);transition:background .15s}.weight-tap-display:hover{background:var(--bg-warm)}.weight-num-lg{font-family:var(--font-display);font-size:2.4rem;color:var(--ink);line-height:1}.weight-unit-lg{font-size:.85rem;color:var(--ink-muted);margin-left:4px}.weight-delta-sm{font-size:.78rem;font-weight:500;margin-top:6px}.weight-delta-sm.down{color:var(--delta-up)}.weight-delta-sm.up{color:var(--delta-down)}.weight-delta-sm.flat{color:var(--ink-muted)}.weight-empty-prompt-sm{font-family:var(--font-display);font-size:1.1rem;color:var(--ink-muted);cursor:pointer}.weight-edit-inline{display:flex;align-items:baseline;justify-content:center;gap:4px;padding:4px 0}.weight-input-sm{width:80px;padding:8px 10px;font-family:var(--font-display);font-size:1.6rem;color:var(--ink);text-align:center;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color .15s}.weight-input-sm:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow)}.health-card-lg{grid-column:1 / -1}@media(max-width:860px){.health-page-header{margin-bottom:var(--sp-md)}.health-lg-row{grid-template-columns:1fr;gap:12px}.health-lg-row--bars{grid-template-columns:1fr}.health-lg-gauge{flex-direction:row;gap:16px}.health-grid{grid-template-columns:1fr;gap:12px}.health-card-lg{padding:16px}.health-card-lg .health-card-head{margin-bottom:12px}.health-card-sm{padding:16px}.health-page-title{font-size:1.3rem}.battery-gauge{width:72px!important;height:72px!important}.battery-num{font-size:1.2rem}.hr-big-display .hr-big,.hrv-big-display .hrv-num{font-size:2rem}.sleep-duration-big{font-size:1.3rem}.steps-big-num{font-size:1.6rem}}@media(max-width:480px){.health-card-lg,.health-card-sm{padding:12px}.health-lg-gauge{flex-direction:column;gap:10px}.health-days-btn{padding:5px 10px;font-size:.75rem}.battery-gauge{width:64px!important;height:64px!important}.hr-big-display .hr-big,.hrv-big-display .hrv-num{font-size:1.6rem}.spo2-num,.weight-num-lg{font-size:1.8rem}}.prog-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-xl)}.prog-title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);margin:0}.prog-subtitle{font-size:.82rem;color:var(--ink-muted);margin-top:2px}.prog-range-toggle{display:flex;gap:4px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.prog-range-btn{padding:6px 14px;font-family:var(--font-body);font-size:.8rem;font-weight:550;color:var(--ink-muted);background:none;border:none;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t-fast)}.prog-range-btn:hover{color:var(--ink)}.prog-range-btn.active{background:var(--surface);color:var(--cyan-deep);box-shadow:var(--shadow-sm)}.prog-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.prog-summary{display:flex;gap:2px;margin-bottom:var(--sp-xl);background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.prog-summary-stat{flex:1;text-align:center;padding:18px 12px;position:relative}.prog-summary-stat+.prog-summary-stat:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border-light)}.prog-summary-num{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);display:block;line-height:1.1}.prog-summary-label{font-size:.7rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;display:block}.prog-section{margin-bottom:var(--sp-xl)}.prog-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-md)}.prog-section-title{font-family:var(--font-body);font-weight:600;font-size:.95rem;color:var(--ink);display:flex;align-items:center;gap:8px;margin:0}.prog-section-title--standalone{margin-bottom:var(--sp-md)}.prog-icon{width:18px;height:18px;flex-shrink:0}.prog-section-badge{font-size:.72rem;font-weight:600;padding:3px 12px;border-radius:20px;color:var(--cyan-deep);background:var(--cyan-glow)}.prog-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px 24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.prog-card:hover{box-shadow:var(--shadow-md)}.prog-card--compact{padding:16px 20px}.prog-bars{display:flex;gap:3px;justify-content:space-between;overflow-x:auto}.prog-bar-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-width:20px;max-width:48px}.prog-bar-track{width:100%;background:#00000006;border-radius:5px;position:relative;display:flex;align-items:flex-end}.prog-bar-fill{width:100%;border-radius:5px;min-height:2px;transition:height .6s cubic-bezier(.4,0,.2,1);position:absolute;bottom:0}.prog-bar-fill--secondary{border-radius:5px 5px 0 0}.prog-bar-val{font-size:.58rem;font-weight:500;color:var(--ink-secondary);line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap}.prog-bar-label{font-size:.52rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.3px;line-height:1;white-space:nowrap}.prog-area-chart{min-height:80px}.prog-area-svg{width:100%;height:80px;display:block;border-radius:var(--r-sm)}.prog-chart-footer{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding:0 2px}.prog-chart-range{font-size:.68rem;color:var(--ink-muted)}.prog-trend{font-size:.72rem;font-weight:600;padding:2px 10px;border-radius:12px}.prog-trend--up{color:var(--delta-up);background:var(--delta-up-bg)}.prog-trend--down{color:var(--delta-down);background:var(--delta-down-bg)}.prog-trend--flat{color:var(--ink-muted);background:var(--bg-warm)}.prog-chart-empty{color:var(--ink-muted);font-size:.85rem;padding:20px 0;text-align:center}.prog-legend{display:flex;gap:14px;font-size:.72rem;color:var(--ink-secondary)}.prog-legend-item{display:flex;align-items:center;gap:5px}.prog-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.prog-mini-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.prog-mini-title{font-weight:600;font-size:.85rem}.prog-mini-unit{font-size:.68rem;color:var(--ink-muted)}.prog-fitness-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.prog-bests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.prog-best-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-md);padding:16px 18px;box-shadow:var(--shadow-sm);transition:all .2s}.prog-best-card:hover{box-shadow:var(--shadow-md);border-color:var(--cyan)}.prog-best-card--longest{border-left:3px solid var(--cyan)}.prog-best-bucket{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--cyan-deep);margin-bottom:6px}.prog-best-time{font-family:var(--font-display);font-size:1.3rem;color:var(--ink);line-height:1.2}.prog-best-pace{font-size:.82rem;color:var(--ink-secondary);margin-top:2px}.prog-best-meta{font-size:.7rem;color:var(--ink-muted);margin-top:6px}.prog-consistency{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--sp-md)}.prog-consist-stat{flex:1;text-align:center;padding:16px 10px;position:relative}.prog-consist-stat+.prog-consist-stat:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border-light)}.prog-consist-num{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);display:block;line-height:1.1}.prog-consist-label{font-size:.68rem;color:var(--ink-muted);margin-top:4px;display:block}.prog-heatmap{display:flex;gap:4px;padding:12px 16px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-md);overflow-x:auto}.prog-heat-cell{width:16px;height:16px;border-radius:3px;flex-shrink:0;transition:transform .15s;cursor:default}.prog-heat-cell:hover{transform:scale(1.3)}.prog-heat-cell--0{background:var(--bg-warm);border:1px solid var(--border-light)}.prog-heat-cell--1{background:#00b8d433}.prog-heat-cell--2{background:#00b8d473}.prog-heat-cell--3{background:var(--cyan)}.prog-heatmap-legend{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:6px;font-size:.65rem;color:var(--ink-muted)}.prog-heatmap-legend .prog-heat-cell{width:12px;height:12px}.prog-heatmap-legend .prog-heat-cell:hover{transform:none}@media(max-width:860px){.prog-header,.prog-section{margin-bottom:var(--sp-md)}.prog-summary{flex-wrap:wrap;margin-bottom:var(--sp-md)}.prog-summary-stat{flex:0 0 calc(33.333% - 1px);padding:12px 8px}.prog-summary-num{font-size:1.2rem}.prog-card{padding:14px 16px}.prog-card--compact{padding:12px 14px}.prog-fitness-grid{grid-template-columns:1fr;gap:12px}.prog-title{font-size:1.3rem}.prog-consistency{margin-bottom:var(--sp-sm)}.prog-consist-stat{padding:12px 8px}.prog-consist-num{font-size:1.1rem}}@media(max-width:480px){.prog-header{flex-direction:column;gap:var(--sp-sm)}.prog-summary-stat{flex:0 0 calc(50% - 1px);padding:10px 6px}.prog-summary-num{font-size:1.1rem}.prog-range-btn{padding:5px 10px;font-size:.75rem}.prog-bests-grid{grid-template-columns:1fr 1fr;gap:8px}.prog-best-card{padding:12px 14px}.prog-best-time{font-size:1.1rem}.prog-consistency{flex-wrap:wrap}.prog-consist-stat{flex:0 0 calc(50% - 1px);padding:10px 6px}.prog-card{padding:12px}}.yir-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-lg);margin-bottom:var(--sp-xl)}.yir-title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);margin:0}.yir-subtitle{font-size:.82rem;color:var(--ink-secondary);margin-top:6px;line-height:1.5;max-width:500px}.yir-controls{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.yir-year-toggle,.yir-scope-toggle{display:flex;gap:4px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.yir-year-btn,.yir-scope-btn{padding:6px 14px;font-family:var(--font-body);font-size:.8rem;font-weight:550;color:var(--ink-muted);background:none;border:none;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t-fast)}.yir-year-btn:hover,.yir-scope-btn:hover{color:var(--ink)}.yir-year-btn.active,.yir-scope-btn.active{background:var(--surface);color:var(--cyan-deep);box-shadow:var(--shadow-sm)}.yir-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.yir-empty{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:var(--sp-xl);text-align:center;color:var(--ink-secondary)}.yir-empty code{display:block;margin-top:var(--sp-md);padding:var(--sp-md);background:var(--bg-warm);border-radius:var(--r-sm);font-size:.8rem;color:var(--ink);word-break:break-all}.yir-hero-stats{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:var(--sp-xl)}.yir-stat{flex:1;text-align:center;padding:20px 10px;position:relative}.yir-stat+.yir-stat:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border-light)}.yir-stat-value{font-family:var(--font-display);font-size:1.5rem;line-height:1.1;display:inline}.yir-stat-unit{font-size:.78rem;color:var(--ink-muted);margin-left:3px}.yir-stat-label{display:block;font-size:.68rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:6px}.yir-chart-section{margin-bottom:var(--sp-xl)}.yir-chart-title{font-family:var(--font-body);font-weight:600;font-size:.9rem;color:var(--ink);margin:0 0 var(--sp-md)}.yir-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px 24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.yir-card:hover{box-shadow:var(--shadow-md)}.yir-month-bars{display:flex;gap:6px;justify-content:space-between}.yir-month-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:0}.yir-month-bar-track{width:100%;height:120px;background:#00000006;border-radius:5px;position:relative;display:flex;align-items:flex-end}.yir-month-bar-fill{width:100%;border-radius:5px;min-height:2px;transition:height .6s cubic-bezier(.4,0,.2,1)}.yir-month-bar-val{font-size:.62rem;font-weight:500;color:var(--ink-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.yir-month-bar-label{font-size:.62rem;color:var(--ink-muted);font-weight:500}.yir-quarters{display:flex;gap:12px}.yir-quarter-card{flex:1;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-md);padding:16px;text-align:center;box-shadow:var(--shadow-sm);transition:all .2s}.yir-quarter-card:hover{box-shadow:var(--shadow-md);border-color:var(--cyan)}.yir-quarter-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--cyan-deep);display:block;margin-bottom:6px}.yir-quarter-km{font-family:var(--font-display);font-size:1.2rem;color:var(--ink);display:block}.yir-quarter-detail{font-size:.72rem;color:var(--ink-muted);margin-top:4px;display:block}.yir-tables-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.yir-table-card{padding:0;overflow:hidden}.yir-table{width:100%;border-collapse:collapse;font-size:.82rem}.yir-table thead{background:var(--bg-warm)}.yir-table th{padding:10px 14px;text-align:left;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);border-bottom:1px solid var(--border-light)}.yir-table td{padding:10px 14px;border-bottom:1px solid var(--border-light);color:var(--ink-secondary)}.yir-table tr:last-child td{border-bottom:none}.yir-table .yir-pace{font-weight:600;color:var(--cyan-deep);font-variant-numeric:tabular-nums}.yir-callout{background:linear-gradient(135deg,var(--surface-tint),var(--surface));border:1px solid var(--border-light);border-left:3px solid var(--cyan);border-radius:var(--r-md);padding:16px 20px;margin-top:var(--sp-lg)}.yir-callout-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--cyan-deep);display:block;margin-bottom:4px}.yir-callout-value{font-size:.95rem;color:var(--ink);font-weight:500}@media(max-width:860px){.yir-header{flex-direction:column;gap:var(--sp-md);margin-bottom:var(--sp-md)}.yir-controls{align-items:flex-start}.yir-hero-stats{flex-wrap:wrap;margin-bottom:var(--sp-md)}.yir-stat{flex:0 0 calc(33.333% - 1px);padding:14px 8px}.yir-stat-value{font-size:1.2rem}.yir-card{padding:14px 16px}.yir-chart-section{margin-bottom:var(--sp-md)}.yir-tables-grid{grid-template-columns:1fr;gap:12px}.yir-quarters{flex-wrap:wrap;gap:8px}.yir-quarter-card{flex:0 0 calc(50% - 4px);padding:12px}.yir-title{font-size:1.3rem}.yir-subtitle{font-size:.78rem}.yir-callout{padding:12px 16px}.yir-month-bar-track{height:90px}}@media(max-width:480px){.yir-stat{flex:0 0 calc(50% - 1px);padding:10px 6px}.yir-stat-value{font-size:1.1rem}.yir-quarters{flex-direction:column}.yir-quarter-card{flex:1}.yir-month-bar-track{height:70px}.yir-card{padding:10px 12px}.yir-table th,.yir-table td{padding:8px 10px;font-size:.78rem}}.timestrip{margin-bottom:28px;padding:18px 22px;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);animation:fadeUp .5s ease .05s both}.timestrip-header{display:flex;justify-content:flex-end;margin-bottom:12px}.timestrip-scope-toggle{display:flex;gap:2px;padding:3px;background:var(--bg-warm);border-radius:var(--r-sm)}.scope-btn{padding:5px 14px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);background:transparent;border-radius:6px;transition:all var(--ease-default)}.scope-btn:hover{color:var(--ink-secondary);background:var(--surface)}.scope-btn.active{color:var(--cyan-deep);background:var(--surface);box-shadow:var(--shadow-sm)}.timestrip-columns{display:flex;gap:8px}.timestrip-col{flex:1;text-align:center;padding:8px 0;border-radius:var(--r-md);transition:background .2s;cursor:default}.timestrip-col:hover{background:var(--bg-warm)}.timestrip-col.current{background:var(--cyan-wash)}.timestrip-col-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:6px}.timestrip-col-num{font-size:1.05rem;font-weight:600;color:var(--ink);margin-bottom:10px}.timestrip-col.current .timestrip-col-num{color:var(--cyan-deep)}.timestrip-bar-container{height:48px;display:flex;flex-direction:column;justify-content:flex-end;align-items:center}.timestrip-bar{width:24px;border-radius:4px 4px 2px 2px;background:var(--border-light);min-height:3px;transition:height .6s cubic-bezier(.34,1.56,.64,1)}.timestrip-bar.has-activity{background:linear-gradient(to top,var(--cyan-deep),var(--cyan-bright));box-shadow:0 2px 8px #00b8d433}.timestrip-col-emoji{font-size:.65rem;color:var(--ink-muted);margin-top:4px;height:14px}.timestrip-empty{text-align:center;color:var(--ink-muted);font-size:.85rem;padding:24px 0}.timestrip-columns:has(.timestrip-col:nth-child(10)) .timestrip-bar{width:18px}.timestrip-columns:not(:has(.timestrip-col:nth-child(6))) .timestrip-bar{width:32px}.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:28px}.stats-row-empty{display:contents}.stat-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .2s ease;position:relative;overflow:hidden;animation:fadeUp .5s ease both}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--cyan);opacity:0;transition:opacity .2s}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--border)}.stat-card:hover:after{opacity:1}.stat-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:8px}.stat-value{font-family:var(--font-display);font-size:1.65rem;color:var(--ink);line-height:1.1}.stat-unit{font-family:var(--font-body);font-size:.85rem;font-weight:400;color:var(--ink-muted);margin-left:2px}.stat-delta{display:inline-flex;align-items:center;gap:3px;font-size:.75rem;font-weight:500;margin-top:8px;padding:2px 8px;border-radius:20px}.stat-delta.up{color:var(--delta-up);background:var(--delta-up-bg)}.stat-delta.down{color:var(--delta-down);background:var(--delta-down-bg)}.content-grid{display:grid;grid-template-columns:1fr 340px;gap:24px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-title{font-family:var(--font-display);font-size:1.2rem;color:var(--ink)}.section-link{font-size:.8rem;font-weight:500;color:var(--cyan-deep);text-decoration:none;cursor:pointer}.section-link:hover{color:var(--cyan)}.activity-feed{display:flex;flex-direction:column;gap:12px;animation:fadeUp .5s ease .3s both}.activity-feed-empty{text-align:center;color:var(--ink-muted);font-size:.9rem;padding:32px 16px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg)}.activity-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .25s ease;cursor:pointer;position:relative;animation:fadeUp .5s ease both}.activity-card:hover{box-shadow:var(--shadow-lg);border-color:var(--cyan);transform:translateY(-1px)}.activity-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.activity-type-badge{display:flex;align-items:center;gap:8px}.activity-icon{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon svg{width:18px;height:18px}.activity-icon--running{background:var(--cyan-glow);color:var(--cyan-deep)}.activity-icon--swimming{background:var(--sleep-bg);color:var(--sleep)}.activity-icon--strength{background:var(--steps-bg);color:var(--steps)}.activity-icon--hiking{background:var(--battery-bg);color:var(--battery-high)}.activity-icon--cycling{background:#00b8d414;color:#0288d1}.activity-icon--walking{background:var(--steps-bg);color:var(--steps)}.activity-icon--default{background:var(--bg-warm);color:var(--ink-muted)}.activity-name{font-weight:600;font-size:.95rem;color:var(--ink)}.activity-date{font-size:.78rem;color:var(--ink-muted);margin-top:1px}.activity-card-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.activity-card-time{font-size:.78rem;color:var(--ink-muted);text-align:right;white-space:nowrap}.activity-hr-badge{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;color:var(--heart);font-variant-numeric:tabular-nums}.activity-hr-badge--lg{font-size:.9rem}.activity-hr-badge--lg+.activity-card-time{font-size:.9rem}.activity-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:14px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}.activity-metric{text-align:center}.activity-metric-value{font-weight:600;font-size:1.05rem;color:var(--ink)}.activity-metric-label{font-size:.68rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.activity-elevation{margin-top:14px;height:40px;position:relative}.elevation-svg{width:100%;height:100%}.elevation-fill{fill:var(--cyan-wash)}.elevation-line{fill:none;stroke:var(--cyan);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.calorie-balance-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);animation:fadeUp .5s ease .35s both}.calorie-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.calorie-icon{font-size:1.1rem}.calorie-title{font-family:var(--font-display);font-size:1.1rem;color:var(--ink);margin:0}.calorie-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border-light);margin-bottom:12px}.calorie-metric{text-align:center;display:flex;flex-direction:column;gap:2px}.calorie-metric-value{font-family:var(--font-display);font-size:1.35rem;color:var(--ink);line-height:1.1}.calorie-metric-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}.calorie-balance.positive .calorie-metric-value{color:var(--delta-up)}.calorie-balance.negative .calorie-metric-value{color:var(--delta-down)}.calorie-delta{font-size:.75rem;font-weight:500;padding:3px 10px;border-radius:20px;display:inline-flex;margin-bottom:14px}.calorie-delta.up{color:var(--delta-up);background:var(--delta-up-bg)}.calorie-delta.down{color:var(--delta-down);background:var(--delta-down-bg)}.calorie-entries{margin-bottom:14px}.calorie-entries-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:8px}.calorie-entry{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--r-sm);transition:all .15s ease}.calorie-entry:hover{background:var(--bg-warm)}.calorie-entry.deleting{opacity:.4;pointer-events:none}.calorie-entry-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.calorie-entry-label{font-size:.85rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calorie-entry-kcal{font-size:.85rem;font-weight:600;color:var(--ink-secondary);white-space:nowrap}.calorie-entry-delete{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;color:var(--ink-muted);transition:all .15s;cursor:pointer}.calorie-entry-delete:hover{background:var(--delta-down-bg);color:var(--delta-down)}.calorie-add{border-top:1px solid var(--border-light);padding-top:14px}.calorie-add-row{display:flex;gap:8px;align-items:flex-start}.calorie-input-group{flex:0 0 80px}.calorie-input-kcal{width:100%;padding:10px 12px;font-size:.9rem;font-weight:600;font-family:var(--font-body);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-warm);color:var(--ink);text-align:center;transition:border-color .15s}.calorie-input-kcal:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow)}.calorie-input-kcal::placeholder{color:var(--ink-faint);font-weight:400}.calorie-label-group{flex:1;position:relative}.calorie-input-label{width:100%;padding:10px 12px;font-size:.85rem;font-family:var(--font-body);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-warm);color:var(--ink);transition:border-color .15s}.calorie-input-label:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow)}.calorie-input-label::placeholder{color:var(--ink-faint)}.calorie-presets{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow-md);z-index:10;overflow:hidden}.calorie-preset-btn{display:block;width:100%;padding:8px 12px;font-size:.82rem;font-family:var(--font-body);color:var(--ink);text-align:left;cursor:pointer;transition:background .1s}.calorie-preset-btn:hover{background:var(--surface-tint);color:var(--cyan-deep)}.calorie-add-btn{flex-shrink:0;width:var(--touch-min);height:42px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:600;color:#fff;background:var(--cyan);border-radius:var(--r-sm);cursor:pointer;transition:all .15s}.calorie-add-btn:hover:not(:disabled){background:var(--cyan-deep);box-shadow:var(--shadow-cyan)}.calorie-add-btn:disabled{opacity:.4;cursor:not-allowed}.calorie-loading,.calorie-empty{text-align:center;color:var(--ink-muted);font-size:.85rem;padding:24px 0}.calorie-error{margin-top:10px;font-size:.78rem;color:var(--delta-down);padding:6px 10px;background:var(--delta-down-bg);border-radius:var(--r-sm)}.content-main{display:flex;flex-direction:column;gap:24px}.content-aside{min-width:0}.dashboard-error{display:flex;align-items:center;gap:8px;padding:12px 16px;margin-bottom:20px;background:var(--delta-down-bg);color:var(--delta-down);border-radius:var(--r-md);font-size:.85rem;font-weight:500;animation:fadeUp .3s ease both}.dashboard-error-icon{flex-shrink:0}.health-panel{display:flex;flex-direction:column;gap:14px;animation:fadeUp .5s ease .35s both}.health-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .2s}.health-card:hover{box-shadow:var(--shadow-md)}.health-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.health-card-title{font-weight:600;font-size:.85rem;color:var(--ink);display:flex;align-items:center;gap:6px}.health-card-title svg{width:16px;height:16px}.health-card-badge{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:20px}.health-card-empty{color:var(--ink-muted);font-size:.85rem;padding:8px 0}.body-battery{display:flex;align-items:center;gap:20px}.battery-gauge{position:relative;width:90px;height:90px;flex-shrink:0}.battery-gauge svg{width:100%;height:100%;transform:rotate(-90deg)}.battery-track{fill:none;stroke:var(--border-light);stroke-width:7}.battery-fill{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.battery-value{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.battery-num{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);line-height:1}.battery-label-sm{font-size:.65rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.battery-detail{flex:1}.battery-range{display:flex;justify-content:space-between;margin-bottom:10px}.battery-range-item{text-align:center}.battery-range-val{font-weight:600;font-size:.95rem;color:var(--ink)}.battery-range-label{font-size:.68rem;color:var(--ink-muted)}.battery-sparkline{width:100%;height:32px}.sleep-duration{font-family:var(--font-display);font-size:1.3rem;color:var(--ink)}.sleep-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.sleep-phase{text-align:center;padding:8px 4px;border-radius:var(--r-sm);background:var(--bg-warm)}.sleep-phase-dot{width:8px;height:8px;border-radius:50%;margin:0 auto 4px}.sleep-phase-value{font-weight:600;font-size:.85rem;color:var(--ink)}.sleep-phase-label{font-size:.65rem;color:var(--ink-muted)}.sleep-stages-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;margin-top:8px;gap:2px}.sleep-stage-segment{height:100%;border-radius:2px;transition:width .4s ease}.sleep-extras{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.sleep-extra-item{display:flex;align-items:baseline;gap:4px}.sleep-extra-val{font-weight:700;font-size:.9rem}.sleep-extra-label{font-size:.65rem;color:var(--ink-muted)}.hr-display{display:flex;align-items:center;gap:16px}.hr-big{font-family:var(--font-display);font-size:2.2rem;color:var(--heart);line-height:1}.hr-unit{font-family:var(--font-body);font-size:.8rem;color:var(--ink-muted);font-weight:400}.hr-stats{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:.78rem}.hr-stat-label{color:var(--ink-muted);font-weight:500}.hr-stat-val{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}.hr-sparkline{width:100%;height:32px;margin-top:10px}.steps-display{display:flex;align-items:center;gap:16px}.steps-ring{position:relative;width:64px;height:64px;flex-shrink:0}.steps-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.steps-track{fill:none;stroke:var(--border-light);stroke-width:5}.steps-fill{fill:none;stroke:var(--steps);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.steps-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.steps-icon{color:var(--steps)}.steps-info{flex:1}.steps-num{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);line-height:1}.steps-goal{font-size:.78rem;color:var(--ink-muted);margin-top:2px}.steps-bar-bg{height:4px;background:var(--border-light);border-radius:2px;margin-top:8px;overflow:hidden}.steps-bar-fill{height:100%;background:linear-gradient(90deg,var(--steps),#fbbf24);border-radius:2px;transition:width 1s cubic-bezier(.4,0,.2,1)}.hrv-display{display:flex;align-items:baseline;gap:8px}.hrv-num{font-family:var(--font-display);font-size:2rem;color:var(--sleep);line-height:1}.hrv-unit{font-size:.8rem;color:var(--ink-muted)}.hrv-bars{display:flex;gap:6px;justify-content:space-between;margin-top:12px}.hrv-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:0}.hrv-bar-track{width:100%;max-width:28px;background:#6366f10f;border-radius:4px;position:relative;display:flex;align-items:flex-end}.hrv-bar-fill{width:100%;background:var(--sleep);border-radius:4px;min-height:3px;transition:height .4s cubic-bezier(.4,0,.2,1)}.hrv-bar-val{font-size:.65rem;font-weight:500;color:var(--ink-secondary);line-height:1}.hrv-bar-label{font-size:.6rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.5px;line-height:1}@media(max-width:1100px){.content-grid{grid-template-columns:1fr}.health-panel{display:grid;grid-template-columns:repeat(2,1fr)}}@media(max-width:860px){.health-panel{grid-template-columns:1fr}.timestrip{padding:10px 12px;margin-bottom:14px}.timestrip-header{margin-bottom:8px}.timestrip-columns{gap:3px}.timestrip-col{padding:4px 0}.timestrip-col-label{font-size:.58rem;margin-bottom:3px}.timestrip-col-num{font-size:.82rem;margin-bottom:6px}.timestrip-bar-container{height:36px}.timestrip-bar{width:16px}.timestrip-col-emoji{font-size:.55rem}.scope-btn{padding:4px 8px;font-size:.62rem}.stats-row{grid-template-columns:1fr;gap:0;margin-bottom:14px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.stat-card{padding:10px 14px;display:flex;align-items:center;gap:8px;border:none;border-radius:0;box-shadow:none;border-bottom:1px solid var(--border-light);animation:none}.stat-card:last-child{border-bottom:none}.stat-card:after{display:none}.stat-card:hover{box-shadow:none}.stat-label{font-size:.75rem;margin-bottom:0;flex:1}.stat-value{font-size:1.1rem;text-align:right}.stat-delta{margin-top:0;font-size:.68rem;flex-shrink:0}.activity-card{padding:14px}.activity-card-header{margin-bottom:10px}.activity-metrics{gap:6px;padding:10px 0}.activity-metric-value{font-size:.9rem}.activity-metric-label{font-size:.6rem}.calorie-balance-card{padding:14px}.calorie-metric-value{font-size:1.15rem}.calorie-input-kcal,.calorie-input-label{padding:10px;font-size:.95rem}.calorie-input-group{flex:0 0 80px}.calorie-add-btn{width:44px;height:44px;font-size:1.3rem}.calorie-entry-delete{width:44px;height:44px}.health-card{padding:14px}.health-card-head{margin-bottom:10px}.body-battery{gap:14px}.battery-gauge{width:68px;height:68px}.battery-num{font-size:1.2rem}.hr-big{font-size:1.8rem}.hrv-num{font-size:1.6rem}.sleep-duration{font-size:1.1rem}.steps-num{font-size:1.2rem}.steps-ring{width:52px;height:52px}.section-head{margin-bottom:10px}.section-title{font-size:1rem}.content-main{gap:14px}.activity-feed{gap:8px}}.weight-widget{cursor:default}.weight-saving{font-size:.7rem;color:var(--cyan-deep);font-weight:500;animation:pulse-dot 1s ease infinite}.weight-empty{text-align:center;padding:20px 0;cursor:pointer;border-radius:var(--r-md);transition:background .15s}.weight-empty:hover{background:var(--bg-warm)}.weight-empty-prompt{font-family:var(--font-display);font-size:1.2rem;color:var(--ink-secondary);margin-bottom:4px}.weight-empty-hint{font-size:.78rem;color:var(--ink-muted)}.weight-display{text-align:center;padding:8px 0;cursor:pointer;border-radius:var(--r-md);transition:background .15s}.weight-display:hover{background:var(--bg-warm)}.weight-big{display:flex;align-items:baseline;justify-content:center;gap:6px}.weight-num{font-family:var(--font-display);font-size:2.4rem;color:var(--ink);line-height:1}.weight-unit{font-family:var(--font-body);font-size:.9rem;color:var(--ink-muted);font-weight:400}.weight-delta{font-size:.78rem;font-weight:500;margin-top:6px}.weight-delta.down{color:var(--delta-up)}.weight-delta.up{color:var(--delta-down)}.weight-delta.flat{color:var(--ink-muted)}.weight-edit{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0}.weight-stepper{width:var(--touch-min);height:var(--touch-min);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:600;color:var(--ink);background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none;touch-action:manipulation}.weight-stepper:hover{background:var(--surface-tint);border-color:var(--cyan);color:var(--cyan-deep)}.weight-stepper:active{transform:scale(.95);background:var(--cyan-wash)}.weight-input{width:90px;padding:10px 12px;font-family:var(--font-display);font-size:1.6rem;color:var(--ink);text-align:center;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color .15s}.weight-input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow)}.weight-input::placeholder{color:var(--ink-faint)}.weight-trend{padding:8px 0 4px}.weight-sparkline{width:100%;height:28px}.weight-error{margin-top:8px;font-size:.78rem;color:var(--delta-down);padding:6px 10px;background:var(--delta-down-bg);border-radius:var(--r-sm)}@media(max-width:860px){.weight-num{font-size:2.8rem}.weight-stepper{width:56px;height:56px;font-size:1.6rem}.weight-input{width:110px;font-size:1.8rem;padding:12px 14px}}.activity-detail-page{width:100%;animation:fadeUp .4s ease both}.detail-back{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;margin-bottom:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink-secondary);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--ease-default)}.detail-back:hover{color:var(--ink);border-color:var(--cyan);background:var(--surface-tint)}.detail-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.detail-error{text-align:center;padding:60px 24px;color:var(--ink-secondary)}.detail-error button{margin-top:16px;padding:10px 24px;background:var(--cyan);color:#fff;border:none;border-radius:var(--r-sm);font-family:var(--font-body);font-weight:600;cursor:pointer}.detail-hero{position:relative;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:24px}.detail-hero-empty{display:flex;align-items:center;justify-content:center;height:200px;background:linear-gradient(135deg,var(--bg-warm),var(--surface))}.detail-hero-emoji{font-size:4rem;opacity:.3}.route-path{stroke-dasharray:5000;stroke-dashoffset:5000;transition:stroke-dashoffset 2s cubic-bezier(.4,0,.2,1)}.route-path--drawn{stroke-dashoffset:0}.route-dot{opacity:0;transition:opacity .3s ease 1.8s}.route-dot--visible{opacity:1}.detail-hero-overlay{padding:24px 28px}.detail-hero-type{font-family:var(--font-body);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.detail-hero-title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);margin:0 0 4px;font-weight:400}.detail-hero-meta{font-family:var(--font-body);font-size:.85rem;color:var(--ink-muted);margin-bottom:12px}.detail-hero-distance{display:inline-flex;align-items:baseline;gap:4px}.detail-hero-distance-value{font-family:var(--font-display);font-size:2rem;color:var(--ink)}.detail-hero-distance-unit{font-family:var(--font-body);font-size:1rem;color:var(--ink-muted);font-weight:500}.detail-hero-elev{border-top:1px solid var(--border-light)}.detail-hero-elev-stats{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body);font-size:.8rem;color:var(--ink-muted);padding:12px 28px 0}.detail-hero-elev-svg{width:100%;height:auto;display:block;padding:0 4px}.detail-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px;animation:fadeUp .5s ease .15s both}.detail-stat{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-md);padding:16px 14px;text-align:center;box-shadow:var(--shadow-sm)}.detail-stat-value{font-family:var(--font-display);font-size:1.25rem;color:var(--ink);margin-bottom:4px}.detail-stat-label{font-family:var(--font-body);font-size:.72rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.detail-stat-unit{font-weight:400;opacity:.7;text-transform:none}.detail-section{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:22px 24px;margin-bottom:20px;animation:fadeUp .5s ease .25s both}.detail-section-title{font-family:var(--font-display);font-size:1.1rem;color:var(--ink);margin:0 0 16px;font-weight:400}.splits-table-wrap{overflow-x:auto}.splits-table{width:100%;border-collapse:collapse}.splits-table th{font-family:var(--font-body);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);text-align:left;padding:6px 12px;border-bottom:1px solid var(--border-light)}.splits-table th:not(:first-child){text-align:right}.splits-table td{padding:10px 12px;font-family:var(--font-body);font-size:.88rem;color:var(--ink);border-bottom:1px solid var(--border-light)}.splits-table td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.splits-table tr:last-child td{border-bottom:none}.splits-table tbody tr{transition:background var(--ease-default)}.splits-table tbody tr:hover{background:var(--bg-warm)}.split-km{font-weight:600;color:var(--ink)}.split-row--partial td,.split-row--partial .split-km{color:var(--ink-muted)}.split-pace-cell{padding:0!important}.pace-bar-cell{position:relative;padding:10px 12px;text-align:right}.pace-bar{position:absolute;left:0;top:50%;transform:translateY(-50%);height:20px;border-radius:3px;background:var(--cyan-glow, rgba(0, 184, 212, .12));transition:width .6s ease}.pace-bar.fast{background:#00b8d433}.pace-bar.slow{background:#eab3081f}.split-pace-value{position:relative;z-index:1;font-weight:600}.split-pace--fast{color:var(--delta-up)}.split-pace--slow{color:var(--delta-down)}.split-hr{font-variant-numeric:tabular-nums;color:var(--heart)}.split-elev{font-variant-numeric:tabular-nums;color:var(--ink-secondary)}.elevation-profile{position:relative}.profile-stats{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body);font-size:.8rem;color:var(--ink-muted);margin-bottom:10px}.profile-stat-item{display:inline-flex;align-items:center;gap:3px}.profile-stat-item strong{color:var(--ink);font-weight:600}.profile-stat-icon{font-weight:700;color:var(--ink-secondary)}.profile-svg{width:100%;height:auto;display:block;border-radius:var(--r-sm);background:var(--bg-warm)}.profile-axis-label{font-family:var(--font-body);font-size:9px;fill:var(--ink-muted);font-variant-numeric:tabular-nums}@media(max-width:860px){.activity-detail-page{padding:0}.detail-back{background:none;border:none;box-shadow:none;padding:4px 8px;margin-bottom:12px;font-size:.82rem}.detail-back:hover{background:none;border:none}.detail-hero{border-radius:var(--r-md);margin-bottom:16px}.detail-hero-overlay{padding:16px 18px}.detail-hero-title{font-size:1.3rem}.detail-hero-distance-value{font-size:1.6rem}.detail-hero-elev-stats{padding:10px 18px 0}.detail-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.detail-stat{padding:12px 8px}.detail-stat-value{font-size:1.1rem}.detail-section{padding:16px 18px;margin-bottom:14px}.splits-table th,.splits-table td{padding:8px;font-size:.82rem}.pace-bar-cell{padding:8px}}@media(max-width:480px){.detail-back{margin-bottom:8px}.detail-hero{border-left:none;border-right:none;border-radius:0;margin-left:-10px;margin-right:-10px}.detail-hero-overlay{padding:14px 16px}.detail-hero-title{font-size:1.15rem}.detail-hero-meta{font-size:.78rem;margin-bottom:8px}.detail-hero-distance-value{font-size:1.4rem}.detail-hero-elev-stats{padding:8px 16px 0;font-size:.72rem}.detail-stats{grid-template-columns:repeat(3,1fr);gap:6px;margin-left:-10px;margin-right:-10px;padding:0 4px}.detail-stat{padding:10px 6px;border-radius:var(--r-sm)}.detail-stat-value{font-size:1rem}.detail-stat-label{font-size:.65rem}.detail-section{margin-left:-10px;margin-right:-10px;border-left:none;border-right:none;border-radius:0;padding:14px}.splits-col-elev{display:none}.splits-table th,.splits-table td{padding:6px;font-size:.78rem}.pace-bar-cell{padding:6px}}
