*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-bg:#f4f6f9;--clr-surface:#fff;--clr-primary:#2563eb;--clr-primary-hover:#1d4ed8;--clr-accent:#f59e0b;--clr-text:#1e293b;--clr-muted:#64748b;--clr-border:#e2e8f0;--clr-row-alt:#f8fafc;--clr-highlight:#eff6ff;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--radius:12px;--radius-sm:8px;--max-w:720px;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}html{font-size:16px}body{font-family:var(--font);color:var(--clr-text);background:var(--clr-bg);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}.app{max-width:var(--max-w);margin:0 auto;padding:24px 16px 48px}.header{text-align:center;margin-bottom:24px}.header h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:800}.subtitle{color:var(--clr-muted);margin-top:4px;font-size:.95rem}.card{background:var(--clr-surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:24px}.step{display:none}.step--active{display:block}.step-title{align-items:center;gap:8px;margin-bottom:16px;font-size:1.1rem;font-weight:700;display:flex}.btn-close{cursor:pointer;color:var(--clr-muted);background:0 0;border:none;margin-left:auto;font-size:1.4rem;line-height:1}.btn-close:hover{color:var(--clr-text)}.field-group{margin-bottom:14px}.field-group label{color:var(--clr-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:.82rem;font-weight:600;display:block}.field-group select,.field-group input{border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);width:100%;color:var(--clr-text);background:var(--clr-surface);padding:10px 12px;font-size:1rem;transition:border-color .15s}.field-group select:focus,.field-group input:focus{border-color:var(--clr-primary);outline:none;box-shadow:0 0 0 3px #2563eb26}.time-row{align-items:flex-end;gap:6px;margin-bottom:14px;display:flex}.field-group--time{flex:1}.time-sep{color:var(--clr-muted);padding-bottom:10px;font-size:1.4rem;font-weight:700}.step-actions{gap:10px;margin-top:8px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:10px 20px;font-size:.95rem;font-weight:600;transition:background .15s,transform .1s}.btn:active{transform:scale(.97)}.btn--primary{background:var(--clr-primary);color:#fff;flex:1}.btn--primary:hover{background:var(--clr-primary-hover)}.btn--primary:disabled{background:var(--clr-border);color:var(--clr-muted);cursor:not-allowed}.btn--secondary{color:var(--clr-primary);border:1.5px solid var(--clr-primary);background:0 0}.btn--secondary:hover{background:var(--clr-highlight)}.btn--loading{pointer-events:none;position:relative;color:#0000!important}.btn--loading:after{content:"";border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:20px;height:20px;margin:auto;animation:.6s linear infinite spin;position:absolute;inset:0}@keyframes spin{to{transform:rotate(360deg)}}.hidden{display:none!important}.results-card{padding:0;overflow:hidden}.tabs{border-bottom:2px solid var(--clr-border);display:flex}.tab{cursor:pointer;color:var(--clr-muted);background:0 0;border:none;border-bottom:3px solid #0000;flex:1;margin-bottom:-2px;padding:14px 8px;font-size:.92rem;font-weight:600;transition:color .15s,border-color .15s}.tab:hover{color:var(--clr-text)}.tab--active{color:var(--clr-primary);border-bottom-color:var(--clr-primary)}.tab-panel{padding:20px;display:none}.tab-panel--active{display:block}.velocity-banner{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.vel-chip{background:var(--clr-highlight);border:1px solid var(--clr-border);border-radius:var(--radius-sm);text-align:center;flex:1;min-width:120px;padding:10px 14px}.vel-chip .label{text-transform:uppercase;letter-spacing:.06em;color:var(--clr-muted);margin-bottom:2px;font-size:.72rem;font-weight:700}.vel-chip .value{color:var(--clr-primary);font-size:1.05rem;font-weight:700}.table-wrap{overflow-x:auto}.results-table{border-collapse:collapse;width:100%;font-size:.9rem}.results-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--clr-muted);border-bottom:2px solid var(--clr-border);padding:10px 12px;font-size:.78rem}.results-table td{border-bottom:1px solid var(--clr-border);padding:10px 12px}.results-table tr:nth-child(2n){background:var(--clr-row-alt)}.results-table tr.highlight{background:var(--clr-highlight);font-weight:600}.results-table tr.highlight td:first-child:before{content:"★ ";color:var(--clr-accent)}.pace-group{margin-bottom:20px}.pace-group-title{text-transform:uppercase;letter-spacing:.06em;color:var(--clr-muted);border-bottom:2px solid var(--clr-border);margin-bottom:10px;padding-bottom:8px;font-size:.82rem;font-weight:700}.pace-card{border-radius:var(--radius-sm);background:var(--clr-row-alt);border:1px solid var(--clr-border);justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 14px;display:flex}.pace-card .name{font-size:.9rem;font-weight:600}.pace-card .range{color:var(--clr-primary);text-align:right;white-space:nowrap;font-size:.88rem;font-weight:600}.pace-card .range small{color:var(--clr-muted);font-size:.75rem;font-weight:500;display:block}.pace-group[data-group=endurance] .pace-card{border-left:4px solid #22c55e}.pace-group[data-group=stamina] .pace-card{border-left:4px solid #f59e0b}.pace-group[data-group=speed] .pace-card{border-left:4px solid #ef4444}.pace-group[data-group=sprint] .pace-card{border-left:4px solid #8b5cf6}.footer{text-align:center;color:var(--clr-muted);padding:24px 0 0;font-size:.8rem}@media (width<=480px){.app{padding:12px 10px 32px}.header h1{font-size:1.35rem}.card{padding:16px}.time-row{gap:4px}.field-group--time input{padding:8px 6px;font-size:.9rem}.time-sep{font-size:1.1rem}.step-actions{flex-direction:column}.btn{width:100%}.results-table{font-size:.82rem}.results-table th,.results-table td{padding:8px 6px}.tab{padding:10px 4px;font-size:.82rem}.velocity-banner{gap:6px}.vel-chip{min-width:80px;padding:8px 6px}.vel-chip .value{font-size:.92rem}}@media (width>=768px){.app{padding:40px 20px 64px}.header h1{font-size:2rem}.card{padding:32px}}
