*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--bg: #0b0c0e;--surface: #15171b;--surface2: #1d2026;--surface3: #262a31;--border: rgba(255, 255, 255, .07);--border2: rgba(255, 255, 255, .14);--text: #f2f3f5;--text2: #9aa0aa;--text3: #5d6370;--green: #34d399;--red: #fb7185;--radius: 14px;--radius-sm: 10px}html{color-scheme:dark}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overscroll-behavior-y:none}button{font-family:inherit}.app{max-width:640px;margin:0 auto;padding:0 0 calc(92px + env(safe-area-inset-bottom));display:flex;flex-direction:column;min-height:100dvh}.header{padding:calc(14px + env(safe-area-inset-top)) 18px 12px;display:flex;align-items:flex-end;justify-content:space-between;position:sticky;top:0;z-index:10;background:var(--bg)}.header:after{content:"";position:absolute;left:0;right:0;top:100%;height:16px;pointer-events:none;background:linear-gradient(var(--bg),transparent)}.header h1{font-size:22px;font-weight:700;letter-spacing:-.4px}.header .sub{font-size:13px;color:var(--text2);margin-top:2px}.section{padding:6px 16px 24px}.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.card-title{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.tile{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 6px 11px;cursor:pointer;min-height:96px;color:var(--text)}.tile:active{background:var(--surface2)}.tile-label{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}.tile-value{font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1.1;margin-top:4px}.tile-sub{font-size:10px;color:var(--text3);font-weight:600}.tile-ring{position:relative;width:48px;height:48px;margin:2px 0}.tile-ring svg{width:48px;height:48px;transform:rotate(-90deg)}.tile-ring .ring-bg{fill:none;stroke:var(--surface3);stroke-width:4}.tile-ring .ring-fg{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .4s ease}.tile-ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.tile-ring-num{font-size:15px;font-weight:800}.tile-ring-den{font-size:10px;color:var(--text3);font-weight:600}.water-presets{display:flex;gap:8px}.water-btn{flex:1;padding:16px 0;border-radius:var(--radius-sm);border:.5px solid color-mix(in srgb,#38bdf8 40%,transparent);background:color-mix(in srgb,#38bdf8 12%,var(--surface));color:#7dd3fc;font-size:20px;font-weight:800;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px}.water-btn span{font-size:11px;font-weight:600;color:var(--text3)}.water-btn:active{background:color-mix(in srgb,#38bdf8 22%,var(--surface))}.water-btn.tracker{background:var(--surface);border-color:var(--border2);color:var(--text)}.water-btn.tracker.active{border-color:#38bdf8}.water-btn.tracker:active{background:var(--surface2)}.section.home{flex:1;display:flex;flex-direction:column;min-height:0;padding-bottom:12px}.week-list{flex:1;display:flex;flex-direction:column;gap:7px;min-height:0}.day-row{flex:1;min-height:46px;max-height:76px;display:flex;align-items:center;gap:10px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:6px 12px 6px 14px;cursor:pointer;transition:transform .1s ease,border-color .15s}.day-row:active{transform:scale(.985)}.day-row.today{border-color:color-mix(in srgb,var(--accent) 45%,transparent);background:color-mix(in srgb,var(--accent) 6%,var(--surface))}.dr-day{display:flex;flex-direction:column;gap:1px;width:58px;flex-shrink:0;font-size:14px;font-weight:700}.dr-date{font-size:10.5px;color:var(--text3);font-weight:500}.dr-pills{flex:1;display:flex;gap:6px;justify-content:flex-end;align-items:center;flex-wrap:wrap;min-width:0}.pill{font-size:11px;font-weight:700;padding:4.5px 10px;border-radius:999px;background:color-mix(in srgb,var(--pill) 14%,transparent);color:var(--pill);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pill.done{background:var(--surface3);color:var(--text3)}.type-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:20px;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);white-space:nowrap}.circuit{margin-bottom:18px}.circuit-label{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;padding-bottom:7px;border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.circuit-focus{font-size:10.5px;color:var(--accent);font-weight:700}.exercise-row{display:flex;align-items:center;gap:10px;padding:13px 12px;border-radius:var(--radius-sm);border:.5px solid var(--border);margin-bottom:6px;cursor:pointer;user-select:none;-webkit-user-select:none;transition:background .15s,border-color .15s;background:var(--surface)}.exercise-row.complete{background:color-mix(in srgb,var(--green) 9%,var(--surface));border-color:color-mix(in srgb,var(--green) 30%,transparent)}.exercise-row.complete .ex-name{color:var(--green)}.ex-tap{flex:1;min-width:0;display:flex;align-items:baseline;gap:8px;cursor:pointer}.ex-name{flex:1;font-size:15px;font-weight:500;min-width:0}.ex-edit{flex-shrink:0;width:34px;height:34px;padding:0;border:.5px solid var(--border2);border-radius:9px;background:var(--surface3);color:var(--text2);font-size:14px;cursor:pointer}.ex-edit:active{background:var(--surface2)}.ex-prep-check{color:var(--green);font-weight:700;font-size:16px;flex-shrink:0}.exercise-row .ex-thumb{cursor:pointer}.ex-name .ex-edited{font-size:10.5px;color:var(--accent, var(--green));font-weight:700;margin-left:6px}.ex-rx{font-size:13.5px;color:var(--text2);font-weight:600;white-space:nowrap}.set-pips{display:flex;gap:4px}.set-pip{width:8px;height:8px;border-radius:50%;background:var(--surface3);border:1px solid var(--border2)}.set-pip.filled{background:var(--green);border-color:var(--green)}.stretch-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media(max-width:380px){.stretch-grid{grid-template-columns:1fr}}.stretch-item{padding:13px 14px;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface);cursor:pointer;user-select:none;-webkit-user-select:none;transition:background .15s}.stretch-item.done{background:color-mix(in srgb,var(--green) 10%,var(--surface));border-color:color-mix(in srgb,var(--green) 32%,transparent)}.stretch-item.done .s-name{color:var(--green)}.s-name{font-size:14px;font-weight:500}.s-meta{font-size:11.5px;color:var(--text2);margin-top:3px}.s-why{font-size:10.5px;color:var(--text3);margin-top:4px}.btn{display:block;width:100%;padding:14px;border:none;border-radius:var(--radius-sm);background:var(--green);color:#06281c;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .15s}.btn:disabled{opacity:.4}.btn.secondary{background:var(--surface3);color:var(--text)}.btn.ghost{background:transparent;border:.5px solid var(--border2);color:var(--text2)}.btn.danger{background:color-mix(in srgb,var(--red) 18%,transparent);color:var(--red)}.btn.sm{width:auto;padding:9px 16px;font-size:13px;display:inline-block}.input,select.input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);border:.5px solid var(--border2);background:var(--surface2);color:var(--text);font-size:15px;font-family:inherit;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus{border-color:var(--green)}.input-label{font-size:12px;font-weight:600;color:var(--text2);margin:14px 0 6px;display:block}.row{display:flex;gap:10px;align-items:center}.spacer{flex:1}.stepper{display:flex;align-items:center;gap:0;border:.5px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden}.stepper button{width:46px;height:46px;border:none;background:var(--surface3);color:var(--text);font-size:22px;font-weight:600;cursor:pointer}.stepper .stepper-val{min-width:74px;text-align:center;font-size:17px;font-weight:700;background:var(--surface2);align-self:stretch;display:flex;align-items:center;justify-content:center}.stepper-label{font-size:11px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:40;animation:fade .18s ease}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:50;max-width:640px;margin:0 auto;background:var(--surface2);border-radius:20px 20px 0 0;border:.5px solid var(--border2);border-bottom:none;padding:10px 18px calc(24px + env(safe-area-inset-bottom));max-height:86vh;overflow-y:auto;animation:slideUp .22s cubic-bezier(.3,1,.4,1)}.sheet-handle{width:38px;height:4px;border-radius:2px;background:var(--border2);margin:4px auto 14px}.sheet h3{font-size:17px;font-weight:700;margin-bottom:4px}.sheet .sheet-sub{font-size:13px;color:var(--text2);margin-bottom:14px}@keyframes slideUp{0%{transform:translateY(40%);opacity:.5}to{transform:none;opacity:1}}@keyframes fade{0%{opacity:0}to{opacity:1}}.option-row{display:flex;align-items:center;gap:12px;padding:14px 12px;border-radius:var(--radius-sm);border:.5px solid var(--border);margin-bottom:7px;cursor:pointer;background:var(--surface);font-size:14.5px;font-weight:500}.option-row:active{background:var(--surface3)}.option-row .opt-meta{margin-left:auto;font-size:12px;color:var(--text3)}.chat-wrap{display:flex;flex-direction:column;height:calc(100dvh - 230px);min-height:340px}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 0 10px}.msg{max-width:88%;padding:11px 15px;border-radius:18px;font-size:14.5px;line-height:1.55;white-space:pre-wrap;word-break:break-word}.msg.user{background:var(--green);color:#06281c;align-self:flex-end;border-bottom-right-radius:5px;font-weight:500}.msg.ai{background:var(--surface2);border:.5px solid var(--border);align-self:flex-start;border-bottom-left-radius:5px}.msg.loading{color:var(--text2);font-style:italic}.msg .msg-action{display:block;margin-top:6px;font-size:11.5px;font-weight:700;color:var(--green)}.quick-asks{display:flex;gap:7px;overflow-x:auto;padding:2px 0 10px;scrollbar-width:none}.quick-asks::-webkit-scrollbar{display:none}.quick-ask{flex-shrink:0;padding:8px 14px;border:.5px solid var(--border2);border-radius:18px;font-size:12.5px;background:var(--surface);color:var(--text2);cursor:pointer}.chat-input-row{display:flex;gap:8px;padding-top:10px;align-items:flex-end}.chat-input{flex:1;padding:12px 16px;border-radius:22px;border:.5px solid var(--border2);background:var(--surface2);font-size:15px;color:var(--text);font-family:inherit;outline:none;resize:none;overflow-y:auto;max-height:132px;line-height:1.45}.chat-input:focus{border-color:var(--green)}.chat-send{padding:13px 20px;background:var(--green);color:#06281c;border:none;border-radius:24px;font-size:14px;font-weight:700;cursor:pointer}.chat-send:disabled{opacity:.4}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:30;background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:.5px solid var(--border);display:flex;justify-content:space-around;padding:6px 8px calc(6px + env(safe-area-inset-bottom))}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 2px 5px;border:none;background:none;color:var(--text3);font-size:10px;font-weight:600;cursor:pointer}.nav-btn svg{width:23px;height:23px}.nav-btn.active{color:var(--green)}.run-card{text-align:center;padding:22px 16px 18px}.run-miles{font-size:38px;font-weight:800;letter-spacing:-1px;line-height:1}.run-miles span{font-size:14px;font-weight:700;color:var(--text2);letter-spacing:0}.run-descriptor{font-size:13.5px;color:var(--text2);margin:10px 0 0;line-height:1.5}.run-segments{display:flex;justify-content:center;gap:6px;margin-top:14px;flex-wrap:wrap}.run-seg{font-size:12px;font-weight:700;padding:5px 12px;border-radius:999px;background:var(--surface3);color:var(--text2)}.run-seg.rp{background:color-mix(in srgb,var(--accent, #fb923c) 18%,transparent);color:var(--accent, #fb923c)}.run-paces{display:flex;justify-content:center;gap:18px;margin-top:12px;font-size:12.5px;color:var(--text3);font-weight:600}.run-paces b{color:var(--text);font-weight:700}.run-stretch{display:flex;align-items:baseline;justify-content:space-between;padding:9px 2px;border-bottom:.5px solid var(--border)}.run-stretch:last-child{border-bottom:none}.run-stretch .s-name{font-size:14px;font-weight:500}.run-stretch .s-meta{font-size:12px;color:var(--text2)}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-month{font-size:17px;font-weight:700}.cal-arrow{width:38px;height:38px;border-radius:var(--radius-sm);border:.5px solid var(--border2);background:var(--surface);color:var(--text);font-size:22px;line-height:1;cursor:pointer}.cal-arrow:disabled{opacity:.3}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.cal-dow{margin-bottom:6px;text-align:center;font-size:10.5px;font-weight:700;color:var(--text3)}.cal-dow div{padding:2px 0}.cal-day{aspect-ratio:1 / 1.05;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface);color:var(--text);font-size:13.5px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.cal-day:active{background:var(--surface2)}.cal-day.today{border-color:var(--green);color:var(--green)}.cal-day.done{opacity:.55}.cal-day.opening{background:var(--surface3)}.cal-dot{width:6px;height:6px;border-radius:50%}.empty{text-align:center;color:var(--text3);font-size:14px;padding:40px 20px;line-height:1.6}.tag{display:inline-block;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:9px;background:var(--surface3);color:var(--text2);margin-right:5px}.tag.warn{background:color-mix(in srgb,var(--red) 16%,transparent);color:var(--red)}.divider{height:.5px;background:var(--border);margin:14px 0}.weight-row{display:flex;align-items:baseline;justify-content:space-between;padding:11px 4px;border-bottom:.5px solid var(--border);font-size:14.5px}.weight-row .w-date{color:var(--text2);font-size:13px}.weight-row .w-delta{font-size:12px;font-weight:600}.big-num{font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1}.toast{position:fixed;bottom:calc(96px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);background:var(--surface3);border:.5px solid var(--border2);padding:11px 20px;border-radius:24px;font-size:13.5px;font-weight:600;z-index:60;animation:fade .2s ease;white-space:nowrap}.toggle{position:relative;width:50px;height:30px;border-radius:15px;background:var(--surface3);border:.5px solid var(--border2);cursor:pointer;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--green);border-color:var(--green)}.toggle:after{content:"";position:absolute;top:2.5px;left:3px;width:23px;height:23px;border-radius:50%;background:#fff;transition:transform .2s}.toggle.on:after{transform:translate(19px)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 2px;border-bottom:.5px solid var(--border);gap:12px}.settings-row .sr-label{font-size:15px;font-weight:500}.settings-row .sr-sub{font-size:12px;color:var(--text2);margin-top:2px}.settings-row input[type=time]{background:var(--surface2);border:.5px solid var(--border2);border-radius:8px;color:var(--text);padding:7px 10px;font-size:15px;font-family:inherit}.auth-wrap{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:32px 28px;max-width:420px;margin:0 auto}.auth-wrap h1{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}.auth-wrap .sub{color:var(--text2);font-size:14.5px;margin-bottom:28px}.spinner{width:22px;height:22px;border:2.5px solid var(--surface3);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;margin:30px auto}@keyframes spin{to{transform:rotate(360deg)}}.ex-photos{display:flex;gap:8px;margin:4px 0 16px}.ex-photos img,.ex-thumb{filter:grayscale(1)}.ex-photos img{flex:1;width:0;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--surface2)}.ex-photos.single img{max-width:60%;flex:0 1 auto}.ex-thumb{width:52px;height:52px;border-radius:8px;object-fit:cover;border:.5px solid var(--border);background:var(--surface2);flex-shrink:0}.lib-row{display:flex;align-items:center;gap:12px;padding:9px 4px;border-bottom:.5px solid var(--border);cursor:pointer}.lib-row:active{background:var(--surface3)}.lib-row .lib-name{font-size:14.5px;font-weight:500}.lib-row .lib-meta{font-size:12px;color:var(--text3);margin-top:2px}.lib-row .lib-spacer{flex:1}.lib-row .lib-chev{color:var(--text3);font-size:18px}.photo-ph{display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:12px}
