:root{--bg: #0a0a0a;--bg-elevated: #141414;--bg-card: #1a1a1a;--border: #2a2a2a;--border-strong: #3a3a3a;--text: #f5f1e8;--text-muted: #8a8478;--text-dim: #5a5448;--accent: #d4ff3a;--accent-dim: #8aa824;--warm: #ff7849;--cool: #4a9eff;--danger: #ff4a4a;--font-display: "Fraunces", Georgia, serif;--font-mono: "DM Mono", "SF Mono", Menlo, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-mono);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.app{min-height:100vh;max-width:480px;margin:0 auto;padding:24px 20px 48px;display:flex;flex-direction:column;gap:24px}.header{display:flex;flex-direction:column;gap:4px;padding-bottom:16px;border-bottom:1px solid var(--border)}.header__eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.header__title{font-family:var(--font-display);font-weight:900;font-size:38px;line-height:1;letter-spacing:-.02em;color:var(--text)}.header__title em{font-style:italic;font-weight:400;color:var(--accent)}.header__sub{font-size:12px;color:var(--text-muted);margin-top:6px}.section{display:flex;flex-direction:column;gap:12px}.section__label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:16px;display:flex;flex-direction:column;gap:12px}.card--accent{border-color:var(--accent-dim);background:linear-gradient(180deg,rgba(212,255,58,.03),transparent)}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.row__label{font-size:12px;color:var(--text-muted)}.row__value{font-family:var(--font-mono);font-size:13px;color:var(--text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:2px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:transform .1s ease,opacity .2s ease;border:1px solid transparent}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--accent);color:#0a0a0a;font-weight:600}.btn--secondary{background:var(--bg-elevated);color:var(--text);border-color:var(--border)}.btn--ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn--danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn--block{width:100%}.auth{display:flex;flex-direction:column;gap:32px;margin-top:24px}.auth__hero{display:flex;flex-direction:column;gap:16px}.auth__big{font-family:var(--font-display);font-weight:900;font-size:56px;line-height:.9;letter-spacing:-.03em}.auth__big em{font-style:italic;font-weight:400;color:var(--accent)}.auth__lead{font-size:13px;color:var(--text-muted);max-width:320px;line-height:1.6}.auth__input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:12px 14px;font-family:var(--font-mono);font-size:14px;color:var(--text);outline:none;transition:border-color .15s}.auth__input:focus{border-color:var(--accent-dim)}.auth__input-group{display:flex;flex-direction:column;gap:6px}.auth__input-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}.auth__input-help{font-size:11px;color:var(--text-dim);margin-top:2px}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.status-cell{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:14px;display:flex;flex-direction:column;gap:6px}.status-cell__label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.status-cell__value{font-family:var(--font-display);font-weight:700;font-size:28px;line-height:1;color:var(--text)}.status-cell__value--accent{color:var(--accent)}.status-cell__sub{font-size:11px;color:var(--text-muted)}.progress{display:flex;flex-direction:column;gap:8px}.progress__bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress__fill{height:100%;background:var(--accent);transition:width .3s ease}.progress__meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.coverage{padding:20px;border:1px solid var(--border);border-radius:4px;display:flex;flex-direction:column;gap:16px}.coverage--ok{border-color:var(--accent-dim);background:linear-gradient(180deg,rgba(212,255,58,.06),transparent)}.coverage--warn{border-color:var(--warm);background:linear-gradient(180deg,rgba(255,120,73,.06),transparent)}.coverage--bad{border-color:var(--danger);background:linear-gradient(180deg,rgba(255,74,74,.06),transparent)}.coverage__rate{font-family:var(--font-display);font-weight:900;font-size:64px;line-height:1;letter-spacing:-.04em}.coverage__verdict{font-family:var(--font-display);font-style:italic;font-size:18px;font-weight:600}.coverage__detail{font-size:12px;color:var(--text-muted);line-height:1.6}.track-list{display:flex;flex-direction:column;gap:1px;max-height:320px;overflow-y:auto;background:var(--border);border-radius:4px}.track-row{background:var(--bg-card);padding:12px 14px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.track-row__main{min-width:0}.track-row__title{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row__artist{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row__bpm{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--accent);font-feature-settings:"tnum"}.track-row__bpm--missing{color:var(--text-dim);font-size:11px;font-family:var(--font-mono);font-weight:400;text-transform:uppercase;letter-spacing:.1em}.bpm-selector{display:flex;flex-direction:column;gap:12px}.bpm-display{font-family:var(--font-display);font-weight:900;font-size:96px;line-height:1;letter-spacing:-.04em;color:var(--accent);font-feature-settings:"tnum";text-align:center}.bpm-display__unit{font-family:var(--font-mono);font-size:14px;color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;display:block;margin-top:4px}.bpm-controls{display:flex;gap:8px;align-items:center;justify-content:center}.bpm-controls input[type=range]{flex:1;-webkit-appearance:none;height:2px;background:var(--border-strong);outline:none}.bpm-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer}.now-playing{padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;display:flex;flex-direction:column;gap:16px}.now-playing__bpm{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--accent);letter-spacing:.1em}.now-playing__title{font-family:var(--font-display);font-size:22px;font-weight:600;line-height:1.2}.now-playing__artist{font-size:13px;color:var(--text-muted)}.now-playing__controls{display:flex;gap:8px;margin-top:8px}.error-banner{background:#ff4a4a1a;border:1px solid var(--danger);border-radius:4px;padding:12px 14px;font-size:12px;color:var(--danger)}.muted{color:var(--text-muted)}.dim{color:var(--text-dim)}.spin{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.beat-pulse{width:10px;height:10px;background:var(--accent);border-radius:50%;display:inline-block;animation:beat .5s ease-in-out infinite}@keyframes beat{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}.tabs{display:flex;gap:4px;background:var(--bg-card);padding:4px;border-radius:4px;border:1px solid var(--border)}.tabs__item{flex:1;padding:10px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;text-align:center;border-radius:2px;color:var(--text-muted);transition:all .15s}.tabs__item--active{background:var(--bg-elevated);color:var(--text)}.setup-range{width:100%;-webkit-appearance:none;height:2px;background:var(--border-strong);outline:none;border-radius:1px}.setup-range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;background:var(--thumb-color, var(--accent));border-radius:50%;cursor:pointer}.range-ticks{display:flex;justify-content:space-between;font-size:10px;color:var(--text-dim);letter-spacing:.1em}.workout{display:flex;flex-direction:column;align-items:center;gap:20px;padding-top:8px;-webkit-user-select:none;user-select:none;touch-action:pan-y}.workout__phase-row{display:flex;align-items:center;justify-content:space-between;width:100%}.phase-badge{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#0a0a0a;padding:4px 12px;border-radius:2px}.workout__set-info{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.workout__rings{display:flex;align-items:center;justify-content:center}.workout__track{text-align:center;display:flex;flex-direction:column;gap:6px;min-height:60px;align-items:center;justify-content:center}.workout__track-bpm{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase}.workout__track-name{font-family:var(--font-display);font-size:20px;font-weight:600;line-height:1.2;max-width:280px}.workout__track-artist{font-size:12px;color:var(--text-muted)}.workout__hint{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}
