.landing{min-height:100vh;background:#0d0d0f;display:flex;align-items:center;justify-content:center;padding:40px 24px}.landing-content{max-width:640px;width:100%;text-align:center}.landing-headline{font-family:Sora,sans-serif;font-size:clamp(36px,8vw,64px);font-weight:700;color:#fff;line-height:1.1;margin:0 0 20px}.landing-sub{font-family:Sora,sans-serif;font-size:18px;color:#888;line-height:1.6;margin:0 0 40px}.input-tabs{display:flex;gap:4px;background:#1a1a1e;border-radius:10px;padding:4px;margin-bottom:24px}.tab{flex:1;padding:12px;border:none;background:transparent;color:#888;font-family:Sora,sans-serif;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:background .15s ease,color .15s ease}.tab-active{background:#2a2a30;color:#fff}.url-input{width:100%;padding:16px 20px;background:#1a1a1e;border:1px solid #2a2a30;border-radius:10px;color:#fff;font-family:Sora,sans-serif;font-size:16px;outline:none;transition:border-color .15s ease;box-sizing:border-box}.url-input:focus{border-color:#ff6b35}.url-input::placeholder{color:#555}.drop-zone{border:2px dashed #2a2a30;border-radius:12px;padding:48px 24px;transition:border-color .15s ease,background .15s ease}.drop-zone-active,.drop-zone:hover{border-color:#ff6b35;background:#ff6b350a}.drop-text{font-family:Sora,sans-serif;color:#aaa;margin:0 0 16px}.browse-btn{display:inline-block;padding:10px 24px;background:transparent;border:1px solid #ff6b35;border-radius:8px;color:#ff6b35;font-family:Sora,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.browse-btn:hover{background:#ff6b35;color:#fff}.file-hint{font-family:Sora,sans-serif;font-size:12px;color:#555;margin:16px 0 0}.error-msg{color:#ff5252;font-family:Sora,sans-serif;font-size:14px;margin:16px 0 0}.youtube-notice{font-family:Sora,sans-serif;font-size:13px;color:#888;line-height:1.5;margin:16px 0 0;padding:12px 16px;background:#ffc10714;border:1px solid rgba(255,193,7,.25);border-radius:8px}.youtube-notice strong{color:#ffc107}.analyze-btn{margin-top:24px;width:100%;padding:16px;background:#ff6b35;border:none;border-radius:10px;color:#fff;font-family:Sora,sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:background .15s ease,opacity .15s ease;display:flex;align-items:center;justify-content:center;min-height:52px}.analyze-btn:hover:not(:disabled){background:#ff8555}.analyze-btn:disabled{opacity:.4;cursor:not-allowed}.btn-spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.progress-bar-container{margin-bottom:32px;padding:24px;background:#141416;border-radius:12px;border:1px solid #2a2a30}.progress-bar-label{font-family:Sora,sans-serif;font-size:14px;color:#aaa;margin-bottom:12px}.progress-bar-track{height:8px;background:#2a2a30;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#ff6b35,#00d4aa);border-radius:4px}.progress-bar-pct{font-family:DM Mono,monospace;font-size:12px;color:#666;margin-top:8px;text-align:right}.bpm-key-badges{display:flex;gap:20px;margin-bottom:24px}.badge{display:flex;flex-direction:column;align-items:center;padding:20px 32px;border-radius:16px;min-width:140px}.badge-bpm{background:#00d4aa;color:#0d0d0f}.badge-key{background:#ff6b35;color:#fff}.badge-value{font-family:DM Mono,monospace;font-size:36px;font-weight:500;line-height:1}.badge-label{font-family:Sora,sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:6px;opacity:.85}.key-confidence-bar{width:100%;height:4px;background:#ffffff4d;border-radius:2px;margin-top:10px;overflow:hidden}.key-confidence-fill{height:100%;background:#fff;border-radius:2px;transition:width .15s ease}.key-confidence-text{font-family:Sora,sans-serif;font-size:10px;margin-top:4px;opacity:.8}@media (max-width: 768px){.bpm-key-badges{flex-direction:column;align-items:stretch}.badge{min-width:unset}}.waveform-player{width:100%;margin-bottom:24px}.waveform-container{position:relative;background:#1a1a1e;border-radius:12px;overflow:hidden;border:1px solid #2a2a30}.chord-markers{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:2}.chord-marker{position:absolute;top:0;bottom:0;width:2px;background:#ff6b35;opacity:.7;transform:translate(-1px)}.waveform-controls{display:flex;align-items:center;gap:16px;margin-top:12px}.play-btn{width:48px;height:48px;border-radius:50%;background:#ff6b35;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease}.play-btn:hover{background:#ff8555;transform:scale(1.05)}.time-display{font-family:DM Mono,monospace;font-size:14px;color:#aaa}.youtube-player{width:100%;margin-bottom:24px;border-radius:12px;overflow:hidden;border:1px solid #2a2a30}.youtube-embed{width:100%;aspect-ratio:16 / 9;background:#1a1a1e}.youtube-embed iframe{width:100%;height:100%}.transposition-control{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:24px;padding:16px;background:#141416;border-radius:12px;border:1px solid #2a2a30}.transpose-btn{width:44px;height:44px;border-radius:50%;border:2px solid #ff6b35;background:transparent;color:#ff6b35;font-size:18px;cursor:pointer;transition:background .15s ease,color .15s ease}.transpose-btn:hover:not(:disabled){background:#ff6b35;color:#fff}.transpose-btn:disabled{opacity:.3;cursor:not-allowed}.transpose-key{font-family:DM Mono,monospace;font-size:18px;font-weight:500;color:#fff;min-width:160px;text-align:center}.section-header{display:flex;align-items:baseline;justify-content:space-between;padding:16px 0 8px;border-bottom:1px solid #2a2a30;margin-bottom:4px}.section-name{font-family:Sora,sans-serif;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#00d4aa}.section-duration{font-family:DM Mono,monospace;font-size:12px;color:#666}.confidence-bar{display:flex;align-items:center;gap:8px;width:100%}.confidence-bar-track{flex:1;height:6px;background:#2a2a30;border-radius:3px;overflow:hidden}.confidence-bar-fill{height:100%;border-radius:3px;transition:width .15s ease}.confidence-bar-label{font-family:DM Mono,monospace;font-size:11px;color:#888;min-width:36px;text-align:right}.chord-diagram-card{background:#1a1a1e;border:1px solid #2a2a30;border-radius:8px;padding:6px;display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s ease}.chord-diagram-card:hover{border-color:#ff6b35}.chord-diagram-canvas{display:block}.chord-diagram-fallback{font-family:DM Mono,monospace;font-size:14px;color:#aaa;padding:8px 12px}.chord-row{display:grid;grid-template-columns:70px 100px 1fr auto;align-items:center;gap:16px;width:100%;padding:12px 16px;background:transparent;border:none;border-left:3px solid transparent;cursor:pointer;text-align:left;transition:background-color .15s ease,border-color .15s ease;border-bottom:1px solid #1a1a1e}.chord-row:hover{background:#ff6b350d}.chord-row-active{background:#ff6b351a;border-left-color:#ff6b35}.chord-timestamp{font-family:DM Mono,monospace;font-size:13px;color:#888}.chord-name{font-family:DM Mono,monospace;font-size:22px;font-weight:700;color:#fff}.chord-confidence{min-width:120px}.chord-diagram-wrap{display:flex;justify-content:flex-end}@media (max-width: 768px){.chord-row{grid-template-columns:1fr;gap:8px;padding:16px}.chord-diagram-wrap{justify-content:flex-start}}.chord-timeline{background:#141416;border-radius:12px;border:1px solid #2a2a30;overflow:hidden;margin-bottom:24px}.chord-timeline-virtual{max-height:600px;overflow-y:auto}.chord-section{padding:0 0 8px}.chord-section .chord-row,.chord-section .section-header{padding-left:24px;padding-right:24px}.export-panel{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}.export-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#1a1a1e;border:1px solid #2a2a30;border-radius:8px;color:#fff;font-family:Sora,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:border-color .15s ease,background .15s ease}.export-btn:hover:not(:disabled){border-color:#ff6b35;background:#ff6b3514}.export-btn:disabled{opacity:.6;cursor:wait}.export-spinner{width:18px;height:18px;border:2px solid #444;border-top-color:#ff6b35;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.export-panel{flex-direction:column}.export-btn{justify-content:center}}.results-page{min-height:100vh;background:#0d0d0f;color:#fff}.results-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid #1a1a1e}.back-link{font-family:Sora,sans-serif;font-size:14px;color:#888;text-decoration:none;transition:color .15s ease}.back-link:hover{color:#ff6b35}.results-title{font-family:Sora,sans-serif;font-size:18px;font-weight:600;margin:0}.results-main{max-width:960px;margin:0 auto;padding:32px 24px 64px}.error-banner{background:#ff52521a;border:1px solid #ff5252;border-radius:8px;padding:16px;margin-bottom:24px;font-family:Sora,sans-serif;font-size:14px;color:#ff5252}.retry-link{background:none;border:none;color:#ff6b35;font-family:Sora,sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline}.controls-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:8px}.controls-row .transposition-control{flex:1;margin-bottom:0}.diagram-toggle{display:flex;gap:4px;background:#1a1a1e;border-radius:8px;padding:4px}.toggle-btn{padding:8px 16px;border:none;background:transparent;color:#888;font-family:Sora,sans-serif;font-size:13px;font-weight:600;cursor:pointer;border-radius:6px;transition:background .15s ease,color .15s ease}.toggle-active{background:#ff6b35;color:#fff}@media (max-width: 768px){.results-header{padding:16px}.controls-row{flex-direction:column;align-items:stretch}.diagram-toggle{justify-content:center}}*{box-sizing:border-box}body{margin:0;background:#0d0d0f;color:#fff;font-family:Sora,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button,input{font-family:inherit}a{color:inherit}
