:root{--bg: #0B0A09;--surface: rgba(255, 255, 255, .022);--surface-2: rgba(255, 255, 255, .045);--surface-3: rgba(255, 255, 255, .075);--surface-solid: #17130F;--primary: #FF6B3C;--primary-dark: #F0481B;--primary-light: rgba(255, 107, 60, .14);--primary-mid: rgba(255, 107, 60, .24);--primary-soft: rgba(255, 128, 84, .9);--primary-gradient: linear-gradient(180deg, #FF7E4A 0%, #F0481B 100%);--chart-grad-from: #FF9A6B;--chart-grad-to: #FF5C28;--blue: #3B9EFF;--blue-light: rgba(59, 158, 255, .13);--green: #6FE3A0;--green-light: rgba(86, 216, 139, .13);--amber: #FFD60A;--amber-light: rgba(255, 214, 10, .13);--red: #FF453A;--text: #F7F4F1;--text-2: rgba(247, 244, 241, .55);--text-3: rgba(247, 244, 241, .34);--border: rgba(255, 255, 255, .08);--border-2: rgba(255, 255, 255, .13);--glass-edge: inset 0 1px 1px rgba(255,255,255,.17), inset 0 -1px 1px rgba(255,255,255,.08);--glass-border: .5px solid rgba(255, 255, 255, .11);--glass-blur: blur(20px) saturate(185%);--shadow-xs: 0 4px 16px rgba(0,0,0,.2);--shadow-sm: 0 8px 24px rgba(0,0,0,.22);--shadow-md: 0 12px 32px rgba(0,0,0,.24);--shadow-lg: 0 20px 50px rgba(0,0,0,.34);--glow-primary: 0 10px 26px rgba(255, 80, 30, .2);--radius-sm: 12px;--radius: 20px;--radius-lg: 26px;--radius-xl: 32px;--ease: cubic-bezier(.25,.46,.45,.94);--font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-text-size-adjust:100%}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}body:before,body:after{content:"";position:fixed;border-radius:50%;pointer-events:none;z-index:0}body:before{top:-140px;right:-120px;width:420px;height:420px;background:#ff5c282b;filter:blur(100px)}body:after{bottom:-200px;left:-100px;width:460px;height:460px;background:#8c2d0a33;filter:blur(120px)}.app:before{content:"";position:fixed;top:280px;left:-160px;width:320px;height:320px;border-radius:50%;background:#ff965a0f;filter:blur(110px);pointer-events:none;z-index:0}.glass{position:relative;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);isolation:isolate}.glass:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.glass:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}@keyframes cgRise{0%{opacity:0;transform:translateY(16px);filter:blur(7px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes cgDraw{to{stroke-dashoffset:0}}@keyframes cgRing{to{stroke-dashoffset:var(--off, 0)}}@keyframes cgFade{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: no-preference){.cg-in{animation:cgRise .8s var(--ease) both;animation-delay:var(--d, 0s)}.cg-draw{stroke-dasharray:1;stroke-dashoffset:1;animation:cgDraw 1.6s cubic-bezier(.45,0,.2,1) forwards;animation-delay:var(--d, .35s)}.cg-ring{animation:cgRing 1.2s cubic-bezier(.3,.8,.3,1) forwards;animation-delay:.4s}.page>*{animation:cgRise .7s var(--ease) both}.page>:nth-child(1){animation-delay:.02s}.page>:nth-child(2){animation-delay:.07s}.page>:nth-child(3){animation-delay:.12s}.page>:nth-child(4){animation-delay:.17s}.page>:nth-child(5){animation-delay:.22s}.page>:nth-child(6){animation-delay:.27s}.page>:nth-child(7){animation-delay:.32s}.page>:nth-child(n+8){animation-delay:.36s}.grid-4>*,.grid-3>*,.grid-2>*{animation:cgRise .7s var(--ease) both}.grid-4>:nth-child(2),.grid-3>:nth-child(2),.grid-2>:nth-child(2){animation-delay:.06s}.grid-4>:nth-child(3),.grid-3>:nth-child(3){animation-delay:.12s}.grid-4>:nth-child(4){animation-delay:.18s}}.app{display:flex;min-height:100vh;position:relative;z-index:1}.main{position:relative;z-index:1}.mobile-avatar-btn{display:none;position:absolute;top:24px;right:18px;width:42px;height:42px;border-radius:50%;overflow:hidden;z-index:120;padding:0;background:var(--surface-3);box-shadow:var(--shadow-sm),var(--glass-edge);border:var(--glass-border);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);align-items:center;justify-content:center;color:var(--primary);font-weight:700;font-size:14px;transition:transform .12s}.mobile-avatar-btn:active{transform:scale(.94)}.mobile-avatar-btn img{width:100%;height:100%;object-fit:cover;border-radius:inherit}@media (prefers-reduced-motion: no-preference){.mobile-avatar-btn{animation:cgRise .7s var(--ease) both;animation-delay:.05s}}body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);background:var(--bg)}.sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;position:fixed;inset:14px auto 14px 14px;z-index:100;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);isolation:isolate;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.sidebar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.sidebar-brand{padding:24px 18px 18px;display:flex;align-items:center;gap:10px}.sidebar-brand-icon{width:36px;height:36px;background:var(--primary-gradient);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:var(--glow-primary),var(--glass-edge)}.sidebar-brand-name{font-size:15px;font-weight:700;letter-spacing:-.2px}.sidebar-brand-sub{font-size:11px;color:var(--text-3);letter-spacing:.2px}.sidebar-nav{flex:1;padding:8px 12px;display:flex;flex-direction:column;gap:2px;list-style:none}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text-2);transition:background .15s var(--ease),color .15s var(--ease);cursor:pointer}.sidebar-nav-item:hover{background:var(--surface-2);color:var(--text)}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600;box-shadow:inset 0 0 0 .5px #ff6b3c40,0 4px 14px #ff501e1f}.sidebar-nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:15px;opacity:.75}.sidebar-nav-item.active .sidebar-nav-icon{opacity:1}.sidebar-section-label{padding:14px 12px 4px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-3)}.sidebar-footer{padding:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.sidebar-sync-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 12px;border-radius:999px;font-size:13px;font-weight:600;color:var(--text);background:var(--surface-2);box-shadow:var(--glass-edge);border:var(--glass-border);transition:background .15s,transform .12s;cursor:pointer;width:100%}.sidebar-sync-btn:hover{background:var(--surface-3)}.sidebar-sync-btn:active{transform:scale(.96)}.sidebar-sync-btn.syncing{color:var(--primary)}.sidebar-user{display:flex;align-items:center;gap:9px;padding:8px 12px}.sidebar-avatar-btn{cursor:pointer;border:1px solid transparent;transition:border-color .15s,transform .1s;overflow:hidden;padding:0}.sidebar-avatar-btn:hover{border-color:var(--primary);transform:scale(1.05)}.sidebar-avatar-btn img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.sidebar-avatar{width:30px;height:30px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--primary);font-weight:700;flex-shrink:0}.sidebar-user-name{font-size:13px;font-weight:500;flex:1}.sidebar-user-logout{font-size:14px;color:var(--text-3);padding:4px 7px;border-radius:7px;transition:background .15s}.sidebar-user-logout:hover{background:var(--surface-3);color:var(--text-2)}.demo-banner{background:#ff5c281f;border-bottom:1px solid rgba(255,92,40,.18);padding:8px 20px;font-size:12px;color:var(--primary);font-weight:500;text-align:center}.main{margin-left:268px;flex:1;min-height:100vh;display:flex;flex-direction:column}.page{padding:40px 44px;flex:1;max-width:1100px}.page-header{margin-bottom:32px}.page-eyebrow{font-size:12.5px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--primary-soft);margin-bottom:6px}.page-title{font-size:32px;font-weight:700;letter-spacing:-.9px;line-height:1.15}.page-sub{font-size:15px;color:var(--text-2);margin-top:8px}.card{position:relative;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px;isolation:isolate;transition:box-shadow .2s var(--ease),transform .2s var(--ease)}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.card:hover{box-shadow:var(--shadow-lg)}.card--flat{box-shadow:none}.card--interactive{cursor:pointer}.card--interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-title{font-size:12.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--primary-soft);margin-bottom:16px}.metric-card,.activity-card,.chart-card,.insight-card{position:relative;isolation:isolate;box-shadow:var(--shadow-md)}.metric-card:before,.activity-card:before,.chart-card:before,.insight-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.metric-card:after,.activity-card:after,.chart-card:after,.insight-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.metric-card{border-radius:var(--radius-lg);padding:22px 24px 20px;display:flex;flex-direction:column;gap:4px;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.metric-icon{font-size:20px;margin-bottom:8px;display:block}.metric-value{display:flex;align-items:baseline;gap:5px;line-height:1}.metric-number{font-size:34px;font-weight:700;letter-spacing:-1px;color:var(--text)}.metric-unit{font-size:16px;font-weight:500;color:var(--text-2)}.metric-label{font-size:13px;color:var(--primary-soft);margin-top:2px}.metric-trend{display:inline-flex;align-items:center;gap:3px;font-size:12.5px;font-weight:600;padding:4px 10px;border-radius:999px;margin-top:9px;width:fit-content}.metric-trend.up{background:var(--green-light);color:var(--green);box-shadow:inset 0 0 0 .5px #6fe3a047}.metric-trend.down{background:#ff453a21;color:var(--red)}.metric-trend.neutral{background:var(--surface-2);color:var(--text-2)}.activity-card{border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.activity-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.activity-type-badge{width:44px;height:44px;border-radius:12px;background:var(--primary-light);box-shadow:var(--glass-edge);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.activity-info{flex:1;min-width:0}.activity-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-date{font-size:12px;color:var(--primary-soft);margin-top:2px}.activity-stats{display:flex;gap:20px;flex-shrink:0}.activity-stat{text-align:right}.activity-stat-value{font-size:15px;font-weight:600}.activity-stat-label{font-size:11px;color:var(--primary-soft);margin-bottom:1px}.insight-card{border-radius:var(--radius-lg);padding:24px}.insight-card:before{background:linear-gradient(150deg,#ff6b3c1c,#ffffff09 55%)}.insight-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.insight-avatar{width:36px;height:36px;background:var(--primary-gradient);border-radius:11px;box-shadow:var(--glow-primary),var(--glass-edge);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.insight-title{font-size:14px;font-weight:700}.insight-sub{font-size:11px;color:var(--primary-soft);margin-top:2px}.insight-body{font-size:14px;line-height:1.7;color:var(--text-2)}.insight-body strong{color:var(--text);font-weight:600}.insight-actions{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}.chart-card{border-radius:var(--radius-lg);padding:24px}.chart-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px;gap:12px;flex-wrap:wrap}.chart-header-left{display:flex;align-items:flex-start;gap:10px;min-width:0;flex:1 1 auto}.chart-nav{display:flex;gap:4px;flex-shrink:0}.chart-nav-btn{width:32px;height:32px;border-radius:50%;background:var(--surface-2);color:var(--text);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);transition:background .15s,color .15s,border-color .15s,opacity .15s;cursor:pointer;line-height:1;padding:0;flex-shrink:0}.chart-nav-btn svg{display:block}@media (max-width: 480px){.chart-nav-btn{width:38px;height:38px}.chart-nav-btn svg{width:16px;height:16px}}.chart-nav-btn:hover:not(:disabled){background:var(--primary-light);color:var(--primary);border-color:#ff5c284d}.chart-nav-btn:disabled{opacity:.35;cursor:not-allowed}.chart-title{font-size:18px;font-weight:700;letter-spacing:-.4px}.chart-sub{font-size:12px;color:var(--primary-soft);margin-top:4px}.chart-legend{display:flex;gap:14px;flex-wrap:wrap}.chart-legend-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-2)}.chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-body{margin-top:16px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:transform .12s var(--ease),box-shadow .2s var(--ease),background .15s;line-height:1;white-space:nowrap;overflow:hidden}.btn:active{transform:scale(.96)}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:var(--glow-primary),inset 0 1px #ffffff40,inset 0 -1px #0000001f}.btn-primary:hover{box-shadow:0 12px 30px #ff501e4d,inset 0 1px #ffffff40}.btn-secondary{background:var(--surface-2);color:var(--text);box-shadow:var(--glass-edge);border:var(--glass-border);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.btn-secondary:hover{background:var(--surface-3)}.btn-ghost{background:transparent;color:var(--primary);padding:9px 14px;font-size:13px}.btn-ghost:hover{background:var(--primary-light)}.btn-sm{padding:9px 16px;font-size:13px}.btn-lg{padding:15px 28px;font-size:15px}.btn-icon{padding:8px;border-radius:9px}.btn:disabled{opacity:.4;cursor:default}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:20px}.grid-1-2{display:grid;grid-template-columns:1fr 2fr;gap:20px}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.col-span-4{grid-column:span 4}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-28{margin-bottom:28px}.mb-32{margin-bottom:32px}.mb-40{margin-bottom:40px}.text-muted{color:var(--text-2)}.text-faint{color:var(--text-3)}.text-primary{color:var(--primary)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:17px}.font-semibold{font-weight:600}.font-bold{font-weight:700}.section-title{font-size:17px;font-weight:700;letter-spacing:-.2px}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.1px;gap:4px}.badge-orange{background:var(--primary-light);color:var(--primary)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-green{background:var(--green-light);color:var(--green)}.badge-amber{background:var(--amber-light);color:var(--amber)}.badge-gray{background:var(--surface-2);color:var(--text-2)}.stack{display:flex;flex-direction:column;gap:10px}.stack-sm{display:flex;flex-direction:column;gap:6px}.stack-lg{display:flex;flex-direction:column;gap:16px}.divider{height:1px;background:var(--border);margin:20px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;text-align:center}.empty-state-icon{font-size:44px;opacity:.25}.empty-state-title{font-size:17px;font-weight:700}.empty-state-sub{font-size:14px;color:var(--text-2);max-width:280px;line-height:1.5}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid var(--border-2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:32px;height:32px;border-width:3px}.spinner-xl{width:44px;height:44px;border-width:3px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--text-2)}.form-hint{font-size:11px;color:var(--text-3)}.form-input{padding:10px 14px;border-radius:10px;border:1.5px solid var(--border-2);background:var(--surface-2);font-size:14px;color:var(--text);transition:border-color .15s,background .15s}.form-input:focus{outline:none;border-color:var(--primary);background:var(--surface-3)}.form-input::placeholder{color:var(--text-3)}.form-textarea{resize:vertical;min-height:84px}.tag{display:inline-flex;align-items:center;gap:5px;background:var(--surface-2);border-radius:8px;padding:7px 12px;font-size:13px;color:var(--text-2);font-weight:500;border:1px solid var(--border)}.tag-label{font-size:11px;color:var(--text-3)}.welcome-hero{position:relative;isolation:isolate;padding:30px 36px;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px}.welcome-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:linear-gradient(150deg,#ff6b3c21,#ffffff09 55%);z-index:-1}.welcome-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.welcome-greeting{font-size:28px;font-weight:800;letter-spacing:-.6px;line-height:1.15}.welcome-sub{font-size:14px;color:var(--primary-soft);margin-top:7px;line-height:1.5}.welcome-cta{flex-shrink:0}.plan-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:8px}.plan-day{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px 12px;display:flex;flex-direction:column;gap:8px;min-height:170px}.plan-day.rest{background:transparent;border-style:dashed}.plan-day-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3)}.plan-day-date{font-size:11px;color:var(--text-3);margin-top:-4px}.plan-day-workout{font-size:13px;font-weight:700;color:var(--text);line-height:1.3}.plan-day-detail{font-size:12px;color:var(--text-2);line-height:1.5;flex:1}.plan-day-duration{font-size:12px;font-weight:600;color:var(--primary);margin-top:auto}.zone-row{display:flex;align-items:center;gap:12px;padding:5px 0}.zone-label{font-size:13px;color:var(--text-2);width:168px;flex-shrink:0}.zone-bar-track{flex:1;height:7px;background:var(--surface-3);border-radius:4px;overflow:hidden}.zone-bar-fill{height:100%;border-radius:4px;transition:width .7s var(--ease)}.zone-pct{font-size:13px;font-weight:600;width:36px;text-align:right;flex-shrink:0}.quick-query-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;gap:10px;margin-bottom:20px}.quick-query-btn{display:flex;flex-direction:column;height:100%}.quick-query-btn{position:relative;isolation:isolate;border-radius:var(--radius);padding:16px 18px;text-align:left;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .15s var(--ease),box-shadow .2s var(--ease)}.quick-query-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.quick-query-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.quick-query-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.quick-query-btn-icon{font-size:20px;display:block;margin-bottom:8px}.quick-query-btn-label{font-size:13.5px;font-weight:600;color:var(--text)}.quick-query-btn-sub{font-size:11px;color:var(--primary-soft);margin-top:3px}.coach-input-wrap{position:relative;isolation:isolate;border-radius:var(--radius-lg);padding:5px 5px 5px 18px;display:flex;align-items:flex-end;gap:8px;box-shadow:var(--shadow-sm)}.coach-input-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.coach-input-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border);transition:box-shadow .15s}.coach-input-wrap:focus-within:after{box-shadow:var(--glass-edge),inset 0 0 0 1px #ff6b3c59}.coach-textarea{flex:1;border:none;background:none;resize:none;font-size:14px;color:var(--text);padding:11px 0;line-height:1.5;min-height:44px;max-height:130px}.coach-textarea:focus{outline:none}.coach-textarea::placeholder{color:var(--text-3)}.coach-send-btn{width:42px;height:42px;border-radius:50%;background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;border:none;box-shadow:var(--glow-primary),inset 0 1px #ffffff40;transition:transform .12s,box-shadow .2s;flex-shrink:0;margin-bottom:1px}.coach-send-btn:hover{box-shadow:0 12px 30px #ff501e52,inset 0 1px #ffffff40}.coach-send-btn:active{transform:scale(.94)}.coach-send-btn:disabled{background:var(--surface-3);box-shadow:none;cursor:default}.composer-plus-wrap{position:relative;flex-shrink:0;margin-bottom:1px}.composer-plus-btn{width:42px;height:42px;border-radius:50%;background:var(--surface-2);color:var(--text);border:var(--glass-border);cursor:pointer;font-size:24px;font-weight:300;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .12s}.composer-plus-btn:hover:not(:disabled){background:var(--surface-3);color:var(--primary)}.composer-plus-btn:active:not(:disabled){transform:scale(.94)}.composer-plus-btn:disabled{opacity:.5;cursor:default}.composer-menu{position:absolute;bottom:calc(100% + 8px);left:0;min-width:190px;z-index:200;border-radius:var(--radius);padding:6px;background:#211a14;border:.5px solid rgba(255,255,255,.14);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:2px}.composer-menu-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:none;border:none;cursor:pointer;color:var(--text);font-size:14px;text-align:left;width:100%;transition:background .12s}.composer-menu-item:hover{background:var(--surface-2)}.composer-menu-icon{font-size:16px}.attachment-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.attachment-chip{display:flex;align-items:center;gap:8px;padding:6px 8px 6px 6px;border-radius:10px;background:var(--surface-2);border:var(--glass-border);max-width:220px}.attachment-chip-thumb{width:28px;height:28px;border-radius:6px;object-fit:cover;flex-shrink:0}.attachment-chip-icon{font-size:18px;flex-shrink:0}.attachment-chip-name{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-chip-remove{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:12px;padding:2px 4px;flex-shrink:0;border-radius:6px;transition:color .12s,background .12s}.attachment-chip-remove:hover{color:var(--primary);background:var(--surface-3)}.chat-attachment-note{font-size:12px;color:var(--text-3);margin-top:6px}.composer-image-hint{font-size:12px;line-height:1.5;color:var(--text-2, var(--text));background:#ff6b3c1a;border:1px solid rgba(255,107,60,.3);border-radius:10px;padding:8px 12px;margin-bottom:8px}.coach-response{position:relative;isolation:isolate;border-radius:var(--radius-lg);padding:28px 32px;margin-top:24px;box-shadow:var(--shadow-md)}.coach-response:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.coach-response:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.coach-response-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.coach-response-avatar{width:36px;height:36px;background:var(--primary-gradient);border-radius:11px;box-shadow:var(--glow-primary),var(--glass-edge);display:flex;align-items:center;justify-content:center;font-size:17px}.coach-response-body{font-size:15px;line-height:1.8;color:var(--text-2);white-space:pre-wrap}.coach-response-body strong{color:var(--text);font-weight:600}.coach-disclaimer{margin-top:20px;font-size:12px;color:var(--text-3);padding:10px 14px;background:var(--surface-2);border-radius:8px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1A0D05 0%,var(--bg) 60%)}.login-card{position:relative;isolation:isolate;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:52px 52px 48px;max-width:460px;width:90%;text-align:center}.login-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface-2);z-index:-1}.login-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.login-logo{width:64px;height:64px;background:var(--primary-gradient);border-radius:20px;box-shadow:var(--glow-primary),var(--glass-edge);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 26px}.login-title{font-size:28px;font-weight:800;letter-spacing:-.6px;margin-bottom:10px}.login-sub{font-size:15px;color:var(--text-2);line-height:1.6;margin-bottom:36px}.login-features{text-align:left;margin-bottom:36px;display:flex;flex-direction:column;gap:14px}.login-feature{display:flex;gap:14px;align-items:flex-start}.login-feature-icon{width:36px;height:36px;border-radius:11px;box-shadow:var(--glass-edge);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.login-feature .name{font-size:14px;font-weight:600}.login-feature .desc{font-size:13px;color:var(--primary-soft);line-height:1.4;margin-top:2px}.login-strava-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:var(--primary-gradient);color:#fff;border-radius:999px;font-size:16px;font-weight:700;cursor:pointer;border:none;box-shadow:var(--glow-primary),inset 0 1px #ffffff40;transition:box-shadow .2s,transform .12s}.login-strava-btn:hover{box-shadow:0 12px 30px #ff501e52,inset 0 1px #ffffff40}.login-strava-btn:active{transform:scale(.98)}.login-disclaimer{font-size:11px;color:var(--text-3);margin-top:14px;line-height:1.5}.stat-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.stat-detail-card{position:relative;isolation:isolate;border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}.stat-detail-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.stat-detail-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.stat-detail-label{font-size:12px;color:var(--primary-soft);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.stat-detail-value{font-size:28px;font-weight:700;letter-spacing:-.5px;color:var(--text);line-height:1}.stat-detail-unit{font-size:14px;font-weight:500;color:var(--text-2);margin-left:4px}.recharts-cartesian-grid-horizontal line{stroke:#ffffff0d}.recharts-cartesian-grid-vertical line{stroke:transparent}.recharts-tooltip-wrapper{filter:drop-shadow(0 6px 20px rgba(0,0,0,.5))}.recharts-default-tooltip{background:#1c1c1ef5!important;border:1px solid var(--border-2)!important;border-radius:10px!important;padding:10px 12px!important;color:var(--text)!important}.recharts-tooltip-label{color:var(--text)!important;font-weight:600!important;margin-bottom:6px!important}.recharts-tooltip-item,.recharts-tooltip-item-name,.recharts-tooltip-item-separator,.recharts-tooltip-item-value,.recharts-tooltip-item-unit{color:var(--text)!important}.chat-list{display:flex;flex-direction:column;gap:8px}.chat-new-btn{width:100%;justify-content:center}.chat-list-items{list-style:none;display:flex;flex-direction:column;gap:6px;margin-top:12px}.chat-list-item{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;align-items:center;gap:10px;transition:border-color .15s,background .15s}.chat-list-item:hover{border-color:var(--border-2);background:var(--surface-2)}.chat-list-item.active{border-color:var(--primary)}.chat-list-item-content{flex:1;min-width:0}.chat-list-item-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-item-preview{font-size:12px;color:var(--primary-soft);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-item-time{font-size:11px;color:var(--primary-soft);margin-top:4px}.chat-list-item-delete{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:14px;transition:background .15s,color .15s}.chat-list-item-delete:hover{background:var(--surface-3);color:var(--red)}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.chat-header-title{flex:1;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.chat-messages{display:flex;flex-direction:column;gap:14px;padding:8px 0 12px;min-height:50vh}.chat-bubble{display:flex;gap:10px;max-width:92%}.chat-bubble-user{align-self:flex-end;flex-direction:row-reverse}.chat-bubble-assistant{align-self:flex-start}.chat-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.chat-bubble-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:14px;line-height:1.6;color:var(--text);min-width:0;overflow-wrap:anywhere;word-break:break-word}.chat-bubble-body p+p{margin-top:8px}.chat-bubble-user .chat-bubble-body{background:var(--primary-light);border-color:#ff5c2840}.chat-quick-presets{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0}.chat-quick-presets button{font-size:12px;padding:6px 10px;white-space:nowrap}.chat-input-form{position:sticky;bottom:0;background:var(--bg);padding-top:8px}.admin-user-row{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);padding:12px 14px;border-radius:var(--radius);flex-wrap:wrap}.tl-kpi{position:relative;isolation:isolate;border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}.tl-kpi:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.tl-kpi:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.tl-kpi-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--primary-soft);margin-bottom:6px}.tl-kpi-value{font-size:30px;font-weight:800;line-height:1;letter-spacing:-.8px}.tl-kpi-status{font-size:11px;margin-top:8px;font-weight:600}.compare-label{color:var(--primary-soft);font-weight:600;font-size:12px}.compare-diff{color:var(--text-3);font-size:12px;font-weight:600}.weather-line{font-size:13px;color:var(--text-2);margin-top:6px;display:inline-flex;flex-wrap:wrap;gap:2px}.bike-card{position:relative;isolation:isolate;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md);max-width:100%;box-sizing:border-box;overflow:hidden}.bike-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:var(--surface);z-index:-1}.bike-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:var(--glass-edge);border:var(--glass-border)}.bike-card *{min-width:0}.bike-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.bike-card-title h3{font-size:18px;font-weight:800;letter-spacing:-.3px}.bike-card-sub{font-size:12px;color:var(--primary-soft);margin-top:4px}.bike-card-stats{text-align:right}.bike-card-km{font-size:22px;font-weight:800;color:var(--primary);line-height:1}.bike-card-km-label{font-size:11px;color:var(--primary-soft);letter-spacing:.3px;margin-top:3px}.garmin-status-card{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.garmin-status-info{flex:1;min-width:0}.garmin-status-actions{display:flex;gap:8px;flex-shrink:0}@media (max-width: 600px){.garmin-status-card{flex-direction:column;align-items:stretch}.garmin-status-actions{width:100%}.garmin-status-actions .btn{flex:1;justify-content:center}}.bike-baseline-box{background:var(--surface-2);border:1px dashed var(--border-2);border-radius:var(--radius);padding:12px;margin-top:4px}.bike-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.bike-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--primary);margin-bottom:12px}.bike-tabs-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.bike-tabs{display:inline-flex;background:#00000038;border-radius:999px;padding:4px;gap:2px;box-shadow:inset 0 1px 2px #0000004d}.bike-tab{padding:9px 18px;font-size:13px;font-weight:600;color:var(--text-2);border-radius:999px;background:transparent;white-space:nowrap;transition:background .15s,color .15s,box-shadow .15s}.bike-tab:hover{color:var(--text)}.bike-tab.active{background:var(--surface-3);color:var(--text);box-shadow:var(--glass-edge),0 2px 8px #00000040}.bike-add-btn{background:transparent;border:none;color:var(--primary);font-size:28px;font-weight:400;line-height:1;padding:4px 8px;cursor:pointer;flex-shrink:0;transition:opacity .15s,transform .12s}.bike-add-btn:hover{opacity:.75;transform:scale(1.1)}.bike-add-btn:active{transform:scale(.95)}.schedule-item{padding:14px 0;border-bottom:1px solid var(--border)}.schedule-item:last-child{border-bottom:none}.schedule-item-clickable{cursor:pointer;margin:0 -8px;padding-left:8px;padding-right:8px;border-radius:8px;transition:background .15s}.schedule-item-clickable:hover{background:var(--surface-2)}.schedule-item-clickable:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.schedule-row-head{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}.schedule-action{font-size:15px;font-weight:700;color:var(--text)}.schedule-interval{font-size:12px;color:var(--primary-soft);margin-top:2px}.schedule-bar{height:5px;background:var(--surface-3);border-radius:3px;overflow:hidden;margin-bottom:8px}.schedule-bar-fill{height:100%;transition:width .3s}.schedule-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2)}.schedule-status-dot{width:8px;height:8px;border-radius:50%}.dot-ok{background:var(--green)}.dot-warn{background:var(--amber)}.dot-critical{background:var(--red)}.history-list{display:flex;flex-direction:column;gap:0}.history-row{padding:14px 0;border-bottom:1px solid var(--border)}.history-row:last-child{border-bottom:none}.history-row-clickable{cursor:pointer;margin:0 -8px;padding-left:8px;padding-right:8px;border-radius:8px;transition:background .15s}.history-row-clickable:hover{background:var(--surface-2)}.history-row-clickable:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.history-meta{font-size:12px;color:var(--primary-soft);margin-bottom:4px}.history-action-row{display:flex;align-items:center;gap:8px}.history-action{font-size:15px;font-weight:600;flex:1;min-width:0}.history-edit-hint{font-size:14px;color:var(--text-3);flex-shrink:0;padding:4px 6px;transition:color .15s}.history-row-clickable:hover .history-edit-hint{color:var(--primary)}.history-notes{font-size:13px;color:var(--text-2);margin-top:6px;line-height:1.5}.reminder-row-card{display:flex;gap:12px;align-items:center;background:var(--surface-2);border-radius:var(--radius);padding:12px 14px;border:1px solid var(--border)}.reminder-row-card.status-warn{border-color:#ffd60a73}.reminder-row-card.status-critical{border-color:#ff453a8c;background:#ff453a12}.reminder-info{flex:1;min-width:0}.reminder-label{font-size:14px;font-weight:600}.reminder-meta{font-size:12px;color:var(--primary-soft);margin-top:2px}.reminder-bar{height:5px;background:var(--surface-3);border-radius:3px;overflow:hidden;margin-top:6px}.reminder-bar-fill{height:100%;transition:width .3s}.bar-ok{background:var(--green)}.bar-warn{background:var(--amber)}.bar-critical{background:var(--red)}.reminder-status{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:4px 10px;border-radius:12px;flex-shrink:0}.status-text-ok{background:var(--green-light);color:var(--green)}.status-text-warn{background:var(--amber-light);color:var(--amber)}.status-text-critical{background:#ff453a26;color:var(--red)}.component-group{margin-bottom:16px}.component-group-title{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--primary);margin-bottom:8px;padding-top:8px}.component-row{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;transition:border-color .15s,background .15s}.component-row.is-active{border-color:#30d15859}.component-row-head{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer}.component-row-head:hover{background:#ffffff05}.component-row-head:focus-visible{outline:2px solid var(--primary);outline-offset:-2px;border-radius:var(--radius)}.component-status-dot{width:10px;height:10px;border-radius:50%;background:var(--text-3);flex-shrink:0}.component-status-dot.dot-ok{background:var(--green)}.component-name{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.component-active-badge{font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;background:var(--green-light);color:var(--green);padding:2px 8px;border-radius:6px}.component-sub{font-size:12px;color:var(--primary-soft);margin-top:2px}.component-stats{font-size:13px;color:var(--text-2);margin-top:4px;line-height:1.5}.component-stats strong{color:var(--text);font-weight:700}.component-stats .cs-label{color:var(--text-3)}@media (max-width: 480px){.component-stats .cs-label,.component-stats .cs-value{display:block}.component-stats .cs-label{font-size:11px;margin-top:6px}.component-stats .cs-label:first-child{margin-top:0}.component-stats .cs-sep{display:none}}.component-expand{font-size:16px;color:var(--text-3);flex-shrink:0;padding:4px 8px}.component-row-body{padding:14px;border-top:1px solid var(--border);margin-top:4px}.component-usage-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.component-usage-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-3);margin-bottom:8px}.component-usage-row{display:flex;align-items:flex-start;gap:10px;padding:6px 0;border-bottom:1px solid var(--border)}.component-usage-row:last-child{border-bottom:none}.component-usage-dot{width:8px;height:8px;border-radius:50%;background:var(--text-3);margin-top:6px;flex-shrink:0}.component-usage-dot.dot-ok{background:var(--green)}.component-usage-meta{font-size:13px;color:var(--text)}.component-usage-stats{font-size:12px;color:var(--text-2);margin-top:2px}.component-usage-range{font-size:12px;margin-top:2px}.component-notes{font-size:13px;color:var(--text-2);margin-top:12px;line-height:1.5;padding:8px 12px;background:var(--surface);border-radius:var(--radius-sm)}.log-row{display:flex;gap:12px;align-items:flex-start;background:var(--surface-2);border-radius:var(--radius);padding:12px 14px;border:1px solid var(--border)}.log-action{font-size:14px;font-weight:600}.log-meta{font-size:12px;color:var(--primary-soft);margin-top:2px}.log-notes{font-size:13px;color:var(--text-2);margin-top:6px;line-height:1.5}.log-remind{font-size:11px;color:var(--text-3);margin-top:6px}.maintenance-form{background:var(--surface-2);border:1px dashed var(--border-2);border-radius:var(--radius);padding:16px;margin-top:16px;margin-bottom:12px;max-width:100%;overflow:hidden;box-sizing:border-box}.maintenance-form input,.maintenance-form select,.maintenance-form textarea{max-width:100%;box-sizing:border-box}.maintenance-form button{white-space:normal;text-align:left;max-width:100%}.maintenance-form .flex{flex-wrap:wrap}.maintenance-form>p{word-wrap:break-word;overflow-wrap:anywhere}.reminder-row{display:flex;gap:16px;flex-wrap:wrap}.reminder-row .export-toggle{padding:4px 0}.reminder-row input[type=number]{padding:6px 10px;font-size:13px}.override-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:8px;padding:12px;background:var(--surface);border-radius:var(--radius);border:1px dashed var(--border-2);align-items:start}.override-grid>div{display:flex;flex-direction:column;gap:4px;min-width:0}.override-grid .form-label{display:block;margin-bottom:0;white-space:normal;line-height:1.3;min-height:2.6em}.override-grid input{width:100%;box-sizing:border-box;font-size:13px;padding:8px 10px}@media (max-width: 480px){.override-grid{grid-template-columns:1fr}.override-grid .form-label{min-height:auto}}.comparison-table{width:100%;border-collapse:collapse;font-size:13px}.comparison-table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--primary);border-bottom:1px solid var(--border)}.comparison-table td{padding:10px 12px;border-bottom:1px solid var(--border)}.comparison-table tr:last-child td{border-bottom:none}@media (max-width: 600px){.comparison-table thead{display:none}.comparison-table,.comparison-table tbody,.comparison-table tr,.comparison-table td{display:block;width:100%}.comparison-table tr{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 14px;margin-bottom:12px}.comparison-table tr:last-child{margin-bottom:0}.comparison-table td{padding:8px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:14px}.comparison-table td:last-child{border-bottom:none}.comparison-table td:before{content:attr(data-label);color:var(--primary-soft);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.comparison-table td:first-child{font-size:16px;padding:10px 0;border-bottom:1px solid var(--border-2);margin-bottom:4px;justify-content:flex-start}.comparison-table td:first-child:before{display:none}.comparison-table td:first-child strong{color:var(--primary)}}@media (max-width: 480px){.bike-card{padding:16px}.bike-card-head{flex-direction:column;align-items:flex-start}.bike-card-stats{text-align:left}.maintenance-form{padding:12px}.bike-tabs-row{gap:8px}.bike-tabs{display:flex;flex:1;min-width:0;padding:3px;gap:4px}.bike-tab{flex:1;padding:7px 4px;font-size:11.5px;line-height:1.2;text-align:center;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bike-add-btn{font-size:26px}.maintenance-form .btn-ghost,.maintenance-form .btn-sm{white-space:normal;text-align:left;line-height:1.4}.reminder-row{flex-direction:column;gap:8px}.reminder-row .export-toggle{width:100%}.reminder-row input[type=number]{width:100%!important;max-width:none}}.export-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.export-modal{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:920px;width:100%;max-height:95vh;display:flex;flex-direction:column}.export-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.export-header h3{font-size:18px;font-weight:700}.export-body{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:20px 24px;overflow-y:auto}.export-preview{display:flex;flex-direction:column;align-items:center}.export-canvas-wrap{background:linear-gradient(45deg,#2a2a2c 25%,transparent 25%),linear-gradient(-45deg,#2a2a2c 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2a2c 75%),linear-gradient(-45deg,transparent 75%,#2a2a2c 75%);background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0;background-color:#1c1c1e;border:1px solid var(--border-2);border-radius:var(--radius);padding:8px;width:100%;max-width:320px;aspect-ratio:9 / 16;display:flex;align-items:center;justify-content:center}.export-canvas{width:100%;height:100%;object-fit:contain}.export-settings{display:flex;flex-direction:column;gap:18px}.export-setting-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--primary);margin-bottom:8px}.color-picker{display:flex;gap:10px}.color-swatch{width:36px;height:36px;border-radius:50%;cursor:pointer;transition:transform .12s,box-shadow .12s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{box-shadow:0 0 0 3px var(--primary)}.export-toggle{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;padding:6px 0}.export-toggle input{width:16px;height:16px;accent-color:var(--primary)}.export-fields{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}.export-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}@media (max-width: 768px){.export-body{grid-template-columns:1fr}.export-canvas-wrap{max-width:240px}.export-fields{grid-template-columns:1fr}}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.onboarding-modal{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:520px;width:100%;padding:32px}.onboarding-header{text-align:center;margin-bottom:24px}.onboarding-header h2{font-size:22px;font-weight:800;letter-spacing:-.4px}.onboarding-step{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--primary);margin-bottom:8px}.onboarding-intro{font-size:14px;line-height:1.6;color:var(--text-2);margin-bottom:20px}.onboarding-nav{display:flex;justify-content:space-between;align-items:center;margin-top:16px}@media (max-width: 480px){.onboarding-modal{padding:20px}.onboarding-header h2{font-size:18px}}.audit-row{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--surface-2);border-radius:var(--radius);font-size:12px;flex-wrap:wrap}.audit-action{font-weight:600}.audit-target{color:var(--text-2)}.filter-pill{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--primary-light);border:1px solid rgba(255,92,40,.25);border-radius:var(--radius);padding:10px 16px;font-size:13px;color:var(--text)}.filter-pill strong{color:var(--primary);font-weight:700}.period-selector{display:inline-flex;background:#00000038;border-radius:999px;padding:4px;gap:2px;margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:inset 0 1px 2px #0000004d}.period-selector-btn{padding:9px 18px;font-size:13px;font-weight:600;color:var(--text-2);border-radius:999px;background:transparent;white-space:nowrap;transition:background .15s,color .15s,box-shadow .15s}.period-selector-btn .short{display:none}.period-selector-btn .long{display:inline}@media (max-width: 480px){.period-selector{display:flex;width:100%;overflow:hidden}.chart-header .period-selector{flex-basis:100%;order:2;margin-top:8px;margin-bottom:0}.chart-header .chart-header-left{flex-basis:100%}.period-selector-btn{flex:1;padding:8px 6px;font-size:12px;text-align:center}.period-selector-btn .short{display:inline}.period-selector-btn .long{display:none}}.period-selector-btn:hover{color:var(--text)}.period-selector-btn.active{background:var(--surface-3);color:var(--text);box-shadow:var(--glass-edge),0 2px 8px #00000040}.rich{display:flex;flex-direction:column;gap:10px;font-size:14px;line-height:1.6;color:var(--text)}.rich p{margin:0}.rich-heading{font-size:14px;font-weight:700;color:var(--primary);letter-spacing:-.1px;margin-top:4px}.rich .hl{color:var(--primary);font-weight:600}.rich-list{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:6px}.rich-list li{position:relative;padding-left:18px;font-size:14px;line-height:1.55;color:var(--text-2)}.rich-list li:before{content:"";position:absolute;left:4px;top:9px;width:5px;height:5px;background:var(--primary);border-radius:50%}.rich-list-numbered{counter-reset:rl}.rich-list-numbered li{padding-left:26px}.rich-list-numbered li:before{content:counter(rl);counter-increment:rl;position:absolute;left:0;top:0;width:20px;height:20px;background:transparent;border:1px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--primary)}.profile-avatar-lg{width:72px;height:72px;flex-shrink:0;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--primary);font-weight:800;border:2px solid rgba(255,92,40,.2);overflow:hidden}.profile-avatar-lg img{width:100%;height:100%;object-fit:cover;border-radius:50%}@media (max-width: 768px){.mobile-avatar-btn{display:flex}.sidebar{width:auto;inset:auto 0 0 0;flex-direction:row;margin:0 auto;left:50%;right:auto;transform:translate(-50%);bottom:calc(12px + env(safe-area-inset-bottom));border-radius:999px;padding:6px;box-shadow:var(--shadow-lg)}.sidebar-brand,.sidebar-footer,.sidebar-section-label{display:none}.sidebar-nav{flex:0 0 auto;flex-direction:row;padding:0;gap:2px}.sidebar-nav-item{justify-content:center;align-items:center;gap:0;width:52px;height:50px;padding:0;border-radius:999px;font-size:0;color:transparent}.sidebar-nav-item svg{color:var(--text-2)}.sidebar-nav-item.active{box-shadow:none}.sidebar-nav-item.active svg{color:var(--primary)}.sidebar-nav-icon{width:100%;display:flex;justify-content:center;align-items:center}.main{margin-left:0;min-width:0;max-width:100vw}.page{padding:24px 18px;padding-bottom:calc(96px + env(safe-area-inset-bottom));max-width:100%}.page{padding-top:20px}.page-header{padding-right:54px}.chat-input-form{position:static;background:transparent;padding-top:12px}.chat-messages{min-height:auto}.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-2-1,.grid-1-2{grid-template-columns:1fr}.col-span-2,.col-span-3,.col-span-4{grid-column:span 1}.grid-4>*,.grid-3>*,.grid-2>*,.grid-2-1>*,.grid-1-2>*{min-width:0}.activity-card{flex-wrap:wrap;gap:14px;padding:16px}.activity-info{flex:1 1 calc(100% - 60px)}.activity-name{font-size:15px}.activity-date{font-size:12px}.activity-stats{flex:1 1 100%;justify-content:flex-start;gap:28px;padding-left:0;margin-top:4px;border-top:1px solid var(--border);padding-top:14px}.activity-stat{text-align:left}.activity-stat-value{font-size:16px;font-weight:700}.activity-stat-label{font-size:11px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.activity-type-badge{width:44px;height:44px;font-size:20px}.stack-lg{gap:20px!important}.welcome-hero{flex-direction:column;align-items:stretch;padding:22px 20px;gap:14px}.welcome-cta{display:flex;gap:8px;width:100%;flex-direction:column}.welcome-cta button{flex:1 1 100%;min-width:0;justify-content:center;white-space:normal}.welcome-greeting{font-size:22px}.metric-card{padding:16px 14px 14px}.metric-number{font-size:26px;letter-spacing:-.5px}.metric-unit{font-size:13px}.metric-label{font-size:12px}.metric-trend{font-size:11px;padding:2px 6px}.stat-detail-grid{grid-template-columns:1fr 1fr}.quick-query-grid{grid-template-columns:1fr;grid-auto-rows:auto;gap:8px}.quick-query-btn{flex-direction:row;gap:14px;padding:14px 16px;height:auto;display:grid;grid-template-columns:28px 1fr;grid-template-rows:auto auto;column-gap:14px;row-gap:2px;align-items:center}.quick-query-btn-icon{grid-row:1 / 3;margin-bottom:0;font-size:22px;flex-shrink:0;align-self:center}.quick-query-btn-label{grid-column:2;grid-row:1;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-query-btn-sub{grid-column:2;grid-row:2;margin-top:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-avatar-lg{width:56px;height:56px;font-size:22px}.card{padding:18px!important}.page>.card .flex.items-center,.page>.card .flex.items-start{gap:12px;flex-wrap:wrap}.page>.card .flex.items-center>.btn,.page>.card .flex.items-start>.btn{margin-left:0!important;flex:1 1 100%;text-align:center;justify-content:center}.page>.flex.gap-12,.page>.flex.gap-8{flex-wrap:wrap}.page>.flex.gap-12>.btn,.page>.flex.gap-8>.btn{flex:1 1 100%;justify-content:center}}@media (max-width: 480px){.grid-4{grid-template-columns:1fr 1fr}.view-header h1{font-size:22px}.hero-greeting{font-size:24px}.page{padding:20px 14px;padding-bottom:calc(100px + env(safe-area-inset-bottom))}.page-header{padding-right:54px}.mobile-avatar-btn{top:20px}.welcome-hero{flex-direction:column;align-items:flex-start;padding:20px 18px;gap:14px}.welcome-cta{width:100%}.welcome-cta button{flex:1}.welcome-greeting{font-size:20px}.welcome-sub{font-size:13px}.login-card{padding:32px 24px 28px;width:94%}.login-title{font-size:22px}.login-sub{font-size:13px;margin-bottom:24px}input,textarea,select{font-size:16px}.activity-card{padding:14px}.stat-detail-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-detail-card{padding:14px}.stat-detail-value{font-size:22px}.coach-textarea{font-size:16px}.section-title{font-size:18px}}
