:root{--bg:#070b14;--bg-card:#0d1321;--bg-elevated:#151d2e;--border:#1b2b45;--border-light:#243b5c;--accent:#00d9a5;--accent-dim:#00d9a51f;--accent-glow:#00d9a54d;--danger:#ff5a5a;--danger-dim:#ff5a5a1f;--warning:#ffb830;--warning-dim:#ffb8301f;--text:#eff3fb;--text-sec:#7b8ba8;--text-dim:#3e4e6a;--radius:14px;--radius-sm:8px;--font:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", "SF Mono", ui-monospace, monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}.app-root{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;padding:0 16px 20px;display:flex}.header{flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 0;display:flex}.header-left{align-items:center;gap:8px;display:flex}.logo{color:var(--accent);font-size:22px;font-weight:700}.app-name{letter-spacing:-.3px;font-size:17px;font-weight:700}.badge{letter-spacing:1.2px;font-size:9px;font-weight:700;font-family:var(--mono);text-transform:uppercase;border-radius:4px;padding:3px 7px}.badge-warning{background:var(--warning-dim);color:var(--warning)}.badge-info{background:var(--accent-dim);color:var(--accent)}.icon-btn{width:40px;height:40px;color:var(--text-sec);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;transition:background .2s;display:flex}.icon-btn:hover{background:var(--bg-elevated)}.video-container{aspect-ratio:16/9;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);flex-shrink:0;width:100%;transition:box-shadow .8s;position:relative;overflow:hidden}.display-canvas{object-fit:cover;width:100%;height:100%;display:block}.overlay{-webkit-backdrop-filter:blur(8px);background:#070b14d9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.overlay-content{flex-direction:column;align-items:center;display:flex}.overlay-title{color:var(--text);margin-top:10px;font-size:14px;font-weight:500}.overlay-sub{color:var(--text-sec);margin-top:4px;font-size:12px}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.status-chip{font-size:11px;font-weight:600;font-family:var(--mono);-webkit-backdrop-filter:blur(6px);border-radius:6px;align-items:center;gap:5px;padding:4px 10px;display:flex;position:absolute;top:12px;left:12px}.chip-warning{background:var(--warning-dim);color:var(--warning)}.chip-accent{background:var(--accent-dim);color:var(--accent)}.bpm-badge{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);background:#070b14cc;border-radius:10px;flex-direction:column;padding:8px 14px;display:flex;position:absolute;bottom:12px;left:12px}.bpm-label{color:var(--accent);letter-spacing:1.5px;font-size:10px;font-weight:600;font-family:var(--mono);text-transform:uppercase}.bpm-value{font-size:32px;font-weight:700;line-height:1;font-family:var(--mono);letter-spacing:-1px}.waveform-container{border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);margin-top:12px;padding:8px 0;overflow:hidden}.waveform-empty{height:56px;color:var(--text-dim);font-size:12px;font-family:var(--mono);justify-content:center;align-items:center;display:flex}.metrics-row{border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);gap:16px;margin-top:10px;padding:10px 12px;display:flex}.metric{flex-direction:column;flex:1;gap:4px;display:flex}.metric-label{color:var(--text-sec);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:600;font-family:var(--mono)}.metric-number{font-size:13px;font-family:var(--mono);color:var(--text-sec);font-weight:500}.metric-bar-track{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.metric-bar-fill{border-radius:2px;height:100%;transition:width .3s}.mode-row{gap:6px;margin-top:10px;display:flex}.mode-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-sec);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:3px;min-height:44px;padding:10px 6px;transition:all .2s;display:flex}.mode-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.mode-icon{font-size:16px}.mode-label{font-size:12px;font-weight:600}.preset-tip{color:var(--text-sec);padding:6px 12px;font-size:11px;font-style:italic;line-height:1.4}.category-row{gap:6px;margin-top:10px;display:flex}.category-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-sec);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:2px;min-height:44px;padding:10px 6px 8px;transition:all .2s;display:flex}.category-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.category-badge{letter-spacing:1px;opacity:.6;font-size:8px;font-weight:700;font-family:var(--mono);text-transform:uppercase}.variant-row{gap:6px;margin-top:6px;animation:.2s fadeIn;display:flex}.variant-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-sec);cursor:pointer;font-family:var(--font);text-align:left;flex-direction:column;flex:1;align-items:flex-start;gap:2px;padding:8px 10px;transition:all .2s;display:flex}.variant-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.variant-name{font-size:12px;font-weight:600}.variant-use{color:var(--text-dim);font-size:10px;line-height:1.3}.variant-btn.active .variant-use{color:var(--accent);opacity:.7}.confidence-badge{-webkit-backdrop-filter:blur(6px);font-size:10px;font-weight:600;font-family:var(--mono);background:#070b14bf;border-radius:6px;align-items:center;gap:5px;padding:4px 10px;display:flex;position:absolute;bottom:12px;right:12px}.confidence-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.confidence-dot.locked{background:var(--accent)}.confidence-dot.usable{background:var(--warning)}.confidence-dot.weak{background:var(--danger);opacity:.7}.confidence-dot.frozen{background:var(--danger)}.confidence-dot.warming{background:var(--text-dim);animation:1.5s infinite pulse}.confidence-text{color:var(--text-sec)}.confidence-locked .confidence-text{color:var(--accent)}.recording-indicator{color:#fff;font-size:10px;font-weight:700;font-family:var(--mono);letter-spacing:1px;z-index:4;background:#ff2828d9;border-radius:4px;padding:3px 8px;animation:1s infinite pulse;position:absolute;top:12px;right:12px}.heatmap-canvas{pointer-events:none;z-index:3;width:100%;height:100%;position:absolute;inset:0}.slider-group{border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);margin-top:10px;padding:10px 14px}.slider-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.slider-label{color:var(--text-sec);font-size:12px;font-weight:500}.slider-value{color:var(--text);font-size:13px;font-family:var(--mono);font-weight:500}input[type=range]{appearance:none;background:0 0;width:100%;margin:0}input[type=range]::-webkit-slider-track{background:var(--border);border-radius:2px;height:4px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);width:22px;height:22px;box-shadow:0 0 8px var(--accent-glow);border-radius:50%;margin-top:-9px}input[type=range]:focus{outline:none}input[type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 0 3px var(--accent-dim), 0 0 12px var(--accent-glow)}input[type=range]::-moz-range-track{background:var(--border);border:none;border-radius:2px;height:4px}input[type=range]::-moz-range-thumb{background:var(--accent);width:22px;height:22px;box-shadow:0 0 8px var(--accent-glow);border:none;border-radius:50%}.advanced-panel{animation:.3s fadeIn}.action-bar{gap:8px;margin-top:10px;display:flex}.action-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-sec);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:3px;min-height:44px;padding:10px 8px;font-size:16px;transition:all .2s;display:flex}.action-btn.active{background:var(--accent-dim);color:var(--accent)}.action-btn.accent{color:var(--accent)}.action-label{font-size:11px;font-weight:600}.welcome{justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.welcome-inner{text-align:center;max-width:340px;animation:.6s fadeIn}.welcome-mark{margin-bottom:28px}.welcome-icon-ring{background:var(--accent-dim);width:60px;height:60px;box-shadow:0 0 40px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.welcome-icon{color:var(--accent);font-size:28px}.welcome-title{letter-spacing:-.5px;margin:0;font-size:28px;font-weight:700}.welcome-subtitle{color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;font-size:13px;font-weight:500;font-family:var(--mono);margin:6px 0 0}.welcome-desc{color:var(--text-sec);margin-bottom:28px;font-size:14px;line-height:1.7}.welcome-steps{text-align:left;flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.step-row{align-items:flex-start;gap:12px;display:flex}.step-num{background:var(--accent-dim);width:24px;height:24px;color:var(--accent);font-size:11px;font-weight:700;font-family:var(--mono);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.step-text{color:var(--text-sec);font-size:13px;line-height:1.5}.caps-info{color:var(--text-dim);font-size:11px;font-family:var(--mono);margin-bottom:20px}.welcome-actions{flex-direction:column;gap:10px;display:flex}.btn-primary{background:var(--accent);width:100%;color:var(--bg);cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font);box-shadow:0 4px 20px var(--accent-glow);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:14px 24px;transition:transform .15s,box-shadow .15s;display:flex}.btn-primary:active{transform:scale(.97)}.btn-secondary{width:100%;color:var(--text-sec);border:1px solid var(--border);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);background:0 0;border-radius:10px;padding:12px 24px}.error-text{color:var(--danger);margin-top:16px;font-size:12px}.disclaimer{color:var(--text-dim);text-align:center;margin-top:16px;font-size:10px;line-height:1.5}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.upload-dropzone{border:2px dashed var(--border-light);border-radius:var(--radius);background:var(--bg-card);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;margin-top:16px;padding:48px 24px;display:flex}.upload-prompt{color:var(--text-sec);font-size:14px}.upload-input{font-family:var(--font);color:var(--text);font-size:14px}.upload-progress-bar{background:var(--border);height:4px;position:absolute;bottom:0;left:0;right:0}.upload-progress-fill{background:var(--accent);height:100%;transition:width .3s}.eco-badge{color:var(--warning);letter-spacing:.5px;margin-left:4px;font-size:9px;font-weight:700}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
