.tool-title{text-transform:uppercase}.vault-layout{display:flex;flex-direction:column;gap:24px;width:100%;margin-top:16px;animation:fadeIn .4s ease;align-items:center}.tool-intro{font-family:Manrope,sans-serif;font-size:.9rem;color:#aaa;line-height:1.6;max-width:600px;margin:0 auto 12px;text-align:center}.history-card{background:#0006;border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:clamp(20px,4vh,32px);backdrop-filter:blur(10px);width:100%;max-width:640px;margin:0 auto}.sport-tabs{display:flex;gap:8px;margin-bottom:32px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:16px}.tab-btn{flex:1;background:transparent;border:1px solid rgba(255,255,255,.1);color:#888;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:800;padding:12px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.tab-btn:hover{background:#ffffff0d;color:#fff}.tab-btn.is-active.swim{border-color:var(--swim, #00d2ff);color:var(--swim, #00d2ff);background:#00d2ff0d}.tab-btn.is-active.bike{border-color:var(--bike, #00ffc3);color:var(--bike, #00ffc3);background:#00ffc30d}.tab-btn.is-active.run{border-color:var(--run, #FF5900);color:var(--run, #FF5900);background:#ff59000d}.action-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;background:#ffffff05;padding:16px;border-radius:12px;border-left:2px solid var(--active-color, #555);transition:border-color .3s ease}.action-text{font-size:.75rem;color:#aaa;font-family:Manrope,sans-serif;line-height:1.5;max-width:60%}.launch-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:#fff;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:800;padding:12px 24px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;flex-shrink:0}.launch-btn:hover{background:var(--active-color, #fff);color:#000;border-color:var(--active-color, #fff);transform:translateY(-2px);box-shadow:0 5px 15px color-mix(in srgb,var(--active-color) 20%,transparent)}.ghost-action-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,.15);color:#fff;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:800;letter-spacing:2px;padding:16px 24px;border-radius:8px;cursor:pointer;transition:all .2s ease;text-transform:uppercase}.ghost-action-btn:hover{border-color:var(--active-color);color:var(--active-color);background:#ffffff05}.input-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}@media(max-width:600px){.input-grid{grid-template-columns:1fr}.action-row{flex-direction:column;gap:16px;text-align:center}.action-text{max-width:100%}.launch-btn{width:100%;justify-content:center}}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}.lab-input-wrap{background:#0009;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px 16px;display:flex;flex-direction:column;align-items:center;transition:all .3s ease;box-shadow:inset 0 2px 10px #00000080}.lab-input-wrap:focus-within{border-color:var(--active-color, #fff);box-shadow:inset 0 2px 10px #00000080,0 0 20px color-mix(in srgb,var(--active-color) 20%,transparent)}.input-label{font-size:.65rem;color:#888;font-family:JetBrains Mono,monospace;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px;text-align:center;transition:color .3s ease}.lab-input-wrap:focus-within .input-label{color:var(--active-color, #fff)}.custom-stepper{display:flex;align-items:center;justify-content:center;width:100%;gap:8px}.step-btn{background:transparent;border:none;color:#555;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s,transform .1s;outline:none}.step-btn:hover{color:var(--active-color, #fff);transform:scale(1.2)}.step-btn:active{transform:scale(.9)}.step-btn .material-symbols-outlined{font-size:36px}.massive-input{width:140px;background:transparent;border:none;color:#fff;font-size:clamp(2.5rem,5vw,4rem);font-weight:900;font-family:JetBrains Mono,monospace;text-align:center;outline:none;padding:0;line-height:1}.massive-input::placeholder{color:#ffffff1a}.input-group{display:flex;flex-direction:column;align-items:center;gap:12px}.time-dial-wrap{display:flex;align-items:center;justify-content:center;gap:12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px 16px;height:80px;transition:all .3s ease;box-shadow:inset 0 2px 10px #00000080}.time-dial-wrap:focus-within,.time-dial-wrap:hover{border-color:var(--active-color);background:color-mix(in srgb,var(--active-color) 5%,rgba(0,0,0,.3));box-shadow:inset 0 2px 10px #00000080,0 0 15px color-mix(in srgb,var(--active-color) 15%,transparent)}.time-dial-wrap:focus-within+.input-label,.time-dial-wrap:hover+.input-label{color:var(--active-color)}.time-segment{display:flex;flex-direction:column;align-items:center;position:relative}.time-arrow{background:transparent;border:none;color:#555;height:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:color .2s,transform .1s;padding:0 12px;user-select:none;-webkit-user-select:none;outline:none}.time-arrow:hover{color:var(--active-color);transform:scale(1.2)}.time-arrow:active{transform:scale(.9)}.time-input{background:transparent;border:none;color:#fff;font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:900;width:55px;text-align:center;padding:0;margin:0;outline:none;transition:color .2s}.time-input::-webkit-outer-spin-button,.time-input::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}.time-input:focus{color:var(--active-color)}.time-colon{color:#666;font-weight:800;font-family:JetBrains Mono,monospace;font-size:1.5rem;margin:0 -4px;transition:color .3s}.time-dial-wrap:focus-within .time-colon,.time-dial-wrap:hover .time-colon{color:var(--active-color)}.time-input.watts-input{width:80px}.live-telemetry-box{text-align:center;padding:24px;background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 100%);border-top:1px solid rgba(255,255,255,.08);margin-bottom:24px;border-radius:0 0 16px 16px;opacity:0;transform:translateY(-10px);transition:all .4s cubic-bezier(.2,.8,.2,1);height:0;overflow:hidden}.live-telemetry-box.is-active{opacity:1;transform:translateY(0);height:auto;overflow:visible}.telemetry-label{font-size:.65rem;color:#888;font-family:JetBrains Mono,monospace;font-weight:800;letter-spacing:2px;text-transform:uppercase;display:block;margin-bottom:8px}.telemetry-value{font-size:2.5rem;font-weight:900;font-family:JetBrains Mono,monospace;color:var(--active-color, #fff);line-height:1;text-shadow:0 0 20px color-mix(in srgb,var(--active-color) 30%,transparent)}.filter-bar{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:16px;flex-wrap:wrap}.filter-btn{background:transparent;border:1px solid rgba(255,255,255,.1);color:#888;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:800;padding:6px 16px;border-radius:4px;cursor:pointer;transition:all .2s;letter-spacing:1px}.filter-btn:hover{border-color:#ffffff4d;color:#fff}.filter-btn.is-active{background:#ffffff1a;color:#fff;border-color:#fff}.history-feed{display:flex;flex-direction:column;margin-top:8px}.log-item-tight{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:background .2s;position:relative}.log-item-tight:last-child{border-bottom:none}.log-item-tight:hover{background:#ffffff05}.log-date{font-family:JetBrains Mono,monospace;font-size:.75rem;color:#666;width:90px}.log-sport-badge{font-size:.55rem;font-family:JetBrains Mono,monospace;font-weight:900;letter-spacing:1px;padding:2px 6px;border-radius:4px;border:1px solid currentColor;margin-right:12px;width:44px;text-align:center;flex-shrink:0}.log-sport-badge.swim{color:var(--swim, #00d2ff);background:#00d2ff0d}.log-sport-badge.bike{color:var(--bike, #00ffc3);background:#00ffc30d}.log-sport-badge.run{color:var(--run, #FF5900);background:#ff59000d}.log-metric{font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:800;color:#fff;width:100px;text-align:left}.log-insight{font-family:Manrope,sans-serif;font-size:.8rem;color:#aaa;flex:1;padding:0 16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-delta{font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:800;width:70px;text-align:right}.delta-pos{color:#10b981}.delta-neg{color:#f43f5e}.delta-neu{color:#888}.delete-log-btn{background:transparent;border:none;color:#444;cursor:pointer;opacity:0;transition:all .2s;padding:4px;margin-left:8px;display:flex;align-items:center;justify-content:center;outline:none}.log-item-tight:hover .delete-log-btn{opacity:1}.delete-log-btn:hover{color:#f43f5e;transform:scale(1.1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.scroll-indicator{display:flex;align-items:center;justify-content:center;margin:16px 0 8px;cursor:pointer;opacity:.8;color:#fff;transition:all .3s ease;text-shadow:0 0 8px rgba(255,255,255,.2)}.scroll-indicator:hover{opacity:1;color:var(--active-color, #fff);text-shadow:0 0 12px var(--active-color)}.scroll-indicator .material-symbols-outlined{font-size:24px;animation:glowingBounce 2s infinite cubic-bezier(.25,.46,.45,.94)}@keyframes glowingBounce{0%,20%,50%,80%,to{transform:translateY(0);filter:drop-shadow(0 0 2px rgba(255,255,255,.2));color:#fff}40%{transform:translateY(6px);filter:drop-shadow(0 0 12px var(--active-color));color:var(--active-color)}60%{transform:translateY(3px);filter:drop-shadow(0 0 8px var(--active-color));color:var(--active-color)}}@media(max-width:600px){.log-item-tight{flex-direction:row;flex-wrap:wrap;gap:8px;padding:16px 8px}.log-date{width:auto}.log-insight{flex-basis:100%;padding:8px 0 0;white-space:normal}.delete-log-btn{opacity:1;position:absolute;top:12px;right:8px}}html:has(main.test-doc-scroll),body:has(main.test-doc-scroll){height:auto;min-height:100dvh;overflow-x:hidden;overflow-y:auto}html:has(main.test-doc-scroll) .slot-wrapper{overflow:visible;height:auto;flex:1 0 auto;min-height:0}html:has(main.test-doc-scroll) main.test-doc-scroll{flex:none;min-height:0;height:auto;overflow-x:hidden;overflow-y:visible}
