@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";@import"https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@3.0.0/dist/tabler-icons.min.css";:root{--bg-0: #0D1117;--bg-1: #161B22;--bg-2: #1C2128;--bg-3: #21262D;--border: rgba(255,255,255,.08);--text-1: #E6EDF3;--text-2: #8B949E;--text-3: #484F58;--blue: #58A6FF;--blue-bg: rgba(88,166,255,.1);--green: #3FB950;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;background:var(--bg-0)}body{font-family:Inter,sans-serif;color:var(--text-1);overscroll-behavior:none}.app{max-width:430px;margin:0 auto;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-0);position:relative}.topbar{padding:52px 20px 12px;background:var(--bg-1);border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.app-title{font-size:16px;font-weight:600;color:var(--text-1);letter-spacing:-.3px}.week-label{font-size:11px;color:var(--text-3)}.content{flex:1;overflow-y:auto;padding:14px 16px 100px}.section-label{font-size:10px;font-weight:600;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;margin:0 0 10px}.week-card{background:var(--bg-1);border-radius:var(--radius-lg);border:.5px solid var(--border);padding:14px 16px;margin-bottom:16px}.week-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.week-title{font-size:14px;font-weight:500;color:var(--text-1)}.week-phase{font-size:11px;color:var(--blue);background:var(--blue-bg);padding:3px 10px;border-radius:20px}.day-row{border-top:.5px solid var(--border)}.day-row:first-of-type{border-top:none}.day-main{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.day-label{font-size:12px;color:var(--text-2);width:24px;flex-shrink:0}.day-detail{font-size:12px;color:var(--text-2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expand-icon{font-size:14px;color:var(--text-3);transition:transform .2s;flex-shrink:0}.expand-icon.open{transform:rotate(180deg)}.pill{font-size:10px;font-weight:600;padding:3px 9px;border-radius:20px;flex-shrink:0;letter-spacing:.02em}.pill-run{background:#63992226;color:#7bc63b}.pill-bike{background:#378add26;color:#58a6ff}.pill-swim{background:#1d9e7526;color:#3fb950}.pill-strength{background:#ba751726;color:#d29922}.pill-rest{background:var(--bg-3);color:var(--text-3)}.workout-done{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.workout-done.checked{background:#1d9e75;border-color:#1d9e75}.workout-done.checked:after{content:"";display:block;width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg) translateY(-1px)}.workout-expand{padding:0 0 12px 34px}.expand-section{margin-bottom:10px}.expand-section-title{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}.expand-block{background:var(--bg-2);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:4px}.expand-block-name{font-size:12px;font-weight:500;color:var(--text-1);margin-bottom:3px}.expand-block-detail{font-size:11px;color:var(--text-2);line-height:1.5}.tag{display:inline-block;font-size:10px;padding:1px 7px;border-radius:10px;margin:3px 3px 0 0}.tag-Z1{background:#1d9e7526;color:#3fb950}.tag-Z2{background:#63992226;color:#7bc63b}.tag-Z3{background:#ba751726;color:#d29922}.tag-Z4{background:#d85a3026;color:#f0883e}.period-toggle{display:flex;gap:6px;margin-bottom:12px}.period-btn{flex:1;padding:7px 0;font-size:12px;font-weight:500;border-radius:var(--radius-sm);border:.5px solid var(--border);background:transparent;color:var(--text-2);cursor:pointer;font-family:inherit;transition:all .15s}.period-btn.active{background:var(--blue-bg);color:var(--blue);border-color:transparent}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.metric-card{background:var(--bg-1);border-radius:var(--radius-md);border:.5px solid var(--border);padding:12px 14px}.metric-label{font-size:11px;color:var(--text-2);margin-bottom:6px;display:flex;align-items:center;gap:5px}.metric-value{font-size:20px;font-weight:500;color:var(--text-1);line-height:1.1}.metric-unit{font-size:12px;color:var(--text-2);font-weight:400}.metric-delta{font-size:11px;margin-top:4px}.delta-up{color:#3fb950}.delta-down{color:#f0883e}.bar-wrap{margin-top:7px;height:3px;background:var(--bg-3);border-radius:2px;overflow:hidden}.bar-fill{height:100%;border-radius:2px}.zones-card{background:var(--bg-1);border-radius:var(--radius-lg);border:.5px solid var(--border);padding:14px 16px;margin-bottom:16px}.zones-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.zones-title{font-size:14px;font-weight:500;color:var(--text-1)}.zones-sub{font-size:11px;color:var(--text-3)}.zone-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.zone-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;width:28px;text-align:center;flex-shrink:0}.z1-badge{background:#1d9e7526;color:#3fb950}.z2-badge{background:#63992226;color:#7bc63b}.z3-badge{background:#ba751726;color:#d29922}.z4-badge{background:#d85a3026;color:#f0883e}.zone-range{font-size:11px;color:var(--text-3);width:70px;flex-shrink:0}.zone-bar-wrap{flex:1;height:5px;background:var(--bg-3);border-radius:3px;overflow:hidden}.zone-bar{height:100%;border-radius:3px;transition:width .4s ease}.zone-time{font-size:12px;font-weight:500;color:var(--text-1);width:38px;text-align:right;flex-shrink:0}.zone-delta{font-size:10px;width:38px;text-align:right;flex-shrink:0}.claude-btn{width:100%;background:var(--bg-1);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .15s;margin-bottom:16px;font-family:inherit}.claude-btn:active{background:var(--bg-2)}.race-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.race-card{background:var(--bg-1);border-radius:var(--radius-lg);border:.5px solid var(--border);padding:10px 14px;display:flex;align-items:center;gap:12px}.race-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.race-run{background:#63992226}.race-bike{background:#378add26}.race-triathlon{background:#d85a3026}.race-swim{background:#1d9e7526}.race-info{flex:1;min-width:0}.race-name{font-size:13px;font-weight:500;color:var(--text-1)}.race-meta{font-size:11px;color:var(--text-2);margin-top:2px}.countdown-badge{text-align:right;flex-shrink:0}.countdown-num{font-size:22px;font-weight:500;color:var(--text-1);line-height:1}.countdown-label{font-size:10px;color:var(--text-3);margin-top:2px}.bottomnav{background:var(--bg-1);border-top:.5px solid var(--border);display:flex;padding:10px 0 28px;position:fixed;bottom:0;left:0;right:0;max-width:430px;margin:0 auto;z-index:10}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;color:var(--text-3)}.nav-item.active{color:var(--blue)}.nav-item i{font-size:22px}.nav-item span{font-size:10px;font-weight:500}.metric-sub{font-size:10px;color:var(--text-3);margin-top:2px}.claude-panel{background:var(--bg-1);border:.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;overflow:hidden}.claude-panel-header{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:.5px solid var(--border);font-size:13px;font-weight:500;color:var(--text-1)}.claude-close{margin-left:auto;background:none;border:none;color:var(--text-3);cursor:pointer;font-size:14px;padding:0;font-family:inherit}.claude-messages{min-height:120px;max-height:320px;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.claude-empty{font-size:12px;color:var(--text-3);line-height:1.6}.claude-msg{display:flex}.claude-msg.user{justify-content:flex-end}.claude-msg.assistant{justify-content:flex-start}.claude-msg-content{max-width:85%;font-size:13px;line-height:1.55;padding:8px 12px;border-radius:12px;white-space:pre-wrap}.claude-msg.user .claude-msg-content{background:var(--blue-bg);color:var(--text-1);border-bottom-right-radius:4px}.claude-msg.assistant .claude-msg-content{background:var(--bg-3);color:var(--text-1);border-bottom-left-radius:4px}.claude-typing{display:flex;gap:4px;align-items:center;padding:10px 12px}.claude-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-3);animation:typing 1.2s infinite}.claude-typing span:nth-child(2){animation-delay:.2s}.claude-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.claude-input-row{display:flex;gap:8px;padding:10px 14px;border-top:.5px solid var(--border)}.claude-input{flex:1;background:var(--bg-2);border:.5px solid var(--border);border-radius:20px;padding:8px 14px;font-size:13px;color:var(--text-1);font-family:inherit;outline:none}.claude-input::placeholder{color:var(--text-3)}.claude-input:focus{border-color:var(--blue)}.claude-send{background:var(--blue-bg);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--blue);font-size:16px;flex-shrink:0}.claude-send:disabled{opacity:.4;cursor:not-allowed}
