*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:#1e1e1e;color:#d4d4d4;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;transition:all .2s ease}input{font-family:inherit}.app-container{display:flex;flex-direction:column;width:100%;height:100%;background-color:#1e1e1e}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background-color:#252526;border-bottom:1px solid #3e3e42;height:60px;flex-shrink:0;z-index:100}.top-bar-left{flex:1}.app-title{font-size:20px;font-weight:600;color:#e0e0e0;margin:0;letter-spacing:.5px}.top-bar-right{display:flex;gap:12px;align-items:center}.mb-search-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#ba478f;color:#fff;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap}.mb-search-button:hover{background-color:#d455a8}.mb-search-button:active{background-color:#9a3a75}.upload-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#0e639c;color:#fff;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.upload-button:hover:not(:disabled){background-color:#17b}.upload-button:active:not(:disabled){background-color:#0a4e7f}.upload-button:disabled{opacity:.6;cursor:not-allowed}.play-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#13a10e;color:#fff;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.play-button:hover:not(:disabled){background-color:#16c61d}.play-button:active:not(:disabled){background-color:#0d8b09}.play-button:disabled{opacity:.5;cursor:not-allowed}.download-json-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#0e639c;color:#fff;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;border:none}.download-json-button:hover:not(:disabled){background-color:#17b}.download-json-button:active:not(:disabled){background-color:#0a4f7d}.download-json-button:disabled{opacity:.5;cursor:not-allowed}.tab-buttons{display:flex;border-bottom:1px solid #3e3e42;background-color:#252526;height:40px;flex-shrink:0}.tab-button{padding:10px 20px;background:none;color:#858585;font-size:13px;font-weight:500;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s ease}.tab-button:hover{color:#d4d4d4;background-color:#2d2d30}.tab-button.active{color:#d4d4d4;border-bottom-color:#4a9eff}.main-content{display:flex;flex:1;overflow:hidden;gap:1px;background-color:#3e3e42}.left-panel{flex:0 0 35%;width:35%;display:flex;flex-direction:column;background-color:#1e1e1e;border-right:1px solid #3e3e42;overflow:hidden}.right-panel{flex:1;display:flex;flex-direction:column;background-color:#1e1e1e;overflow:hidden}.tab-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;min-height:0}.json-editor-container{flex:1;width:100%;display:flex;flex-direction:column;background-color:#1e1e1e;min-height:0}.editor-empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:#6a9955;font-size:14px}.editor-empty-state p{text-align:center;max-width:300px}.placeholder-text{color:#6a9955;font-style:italic}.track-info{margin-top:32px;text-align:left;background-color:#252526;padding:20px;border-radius:6px;border:1px solid #3e3e42}.track-info h3{font-size:14px;font-weight:600;color:#d4d4d4;margin-bottom:16px}.tracks-list{display:flex;flex-direction:column;gap:12px}.track-item{background-color:#1e1e1e;padding:12px;border-radius:4px;border-left:3px solid #007acc}.track-name{font-size:13px;font-weight:500;color:#d4d4d4;margin-bottom:6px}.track-details{display:flex;gap:16px;font-size:12px;color:#858585}.track-instrument,.track-notes{display:flex;flex-direction:column}.chat-container{display:flex;flex-direction:column;height:100%;background-color:#1e1e1e}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:#6a9955;font-size:13px;text-align:center;padding:32px;max-width:100%}.chat-empty-state p{max-width:200px}.chat-message{display:flex;margin-bottom:8px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.message-content{max-width:85%;padding:10px 14px;border-radius:6px;font-size:13px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.chat-message.user .message-content{background-color:#007acc;color:#fff}.chat-message.assistant .message-content{background-color:#252526;color:#d4d4d4;border:1px solid #3e3e42}.message-content.loading{display:flex;align-items:center;gap:6px;padding:10px 14px}.loading-dot{width:6px;height:6px;border-radius:50%;background-color:#858585;animation:bounce 1.4s infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.6;transform:translateY(0)}40%{opacity:1;transform:translateY(-8px)}}.chat-input-container{display:flex;gap:8px;padding:12px;border-top:1px solid #3e3e42;background-color:#252526;flex-shrink:0}.chat-input{flex:1;padding:8px 12px;background-color:#3e3e42;border:1px solid #555555;border-radius:4px;color:#d4d4d4;font-size:13px;transition:border-color .2s ease}.chat-input:focus{outline:none;border-color:#007acc;background-color:#464647}.chat-input:disabled{opacity:.6;cursor:not-allowed}.chat-send-button{padding:8px 16px;background-color:#007acc;color:#fff;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .2s ease}.chat-send-button:hover:not(:disabled){background-color:#17b}.chat-send-button:active:not(:disabled){background-color:#0a4e7f}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}.musicbrainz-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.musicbrainz-modal{background-color:#252526;border:1px solid #3e3e42;border-radius:8px;box-shadow:0 8px 32px #00000080;max-width:500px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #3e3e42;flex-shrink:0}.modal-header h2{font-size:16px;font-weight:600;color:#e0e0e0;margin:0}.modal-close{background:none;color:#858585;font-size:24px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s ease}.modal-close:hover{color:#d4d4d4}.musicbrainz-form{padding:20px;flex-shrink:0;border-bottom:1px solid #3e3e42}.form-group{margin-bottom:16px}.form-group:last-of-type{margin-bottom:20px}.form-group label{display:block;font-size:12px;font-weight:600;color:#d4d4d4;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input{width:100%;padding:8px 12px;background-color:#3e3e42;border:1px solid #555555;border-radius:4px;color:#d4d4d4;font-size:13px;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#007acc;background-color:#464647}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-actions{display:flex;gap:10px}.btn-search,.btn-skip{flex:1;padding:10px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-search{background-color:#007acc;color:#fff}.btn-search:hover:not(:disabled){background-color:#17b}.btn-search:active:not(:disabled){background-color:#0a4e7f}.btn-search:disabled{opacity:.5;cursor:not-allowed}.btn-skip{background-color:#3e3e42;color:#d4d4d4;border:1px solid #555555}.btn-skip:hover{background-color:#464647;border-color:#6a9955}.search-results{padding:20px;flex:1;overflow-y:auto;display:flex;flex-direction:column}.no-results{color:#858585;font-size:13px;text-align:center;padding:20px;margin:auto}.results-list{display:flex;flex-direction:column;gap:0}.results-label{font-size:12px;font-weight:600;color:#d4d4d4;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.result-item{padding:12px;background-color:#1e1e1e;border:1px solid #3e3e42;border-radius:4px;margin-bottom:8px;text-align:left;transition:all .2s ease;cursor:pointer}.result-item:hover{background-color:#2d2d30;border-color:#007acc;box-shadow:inset 0 0 0 1px #007acc}.result-item:active{background-color:#252526}.result-title{font-size:13px;font-weight:500;color:#d4d4d4;margin-bottom:4px}.result-artist{font-size:12px;color:#858585;margin-bottom:4px}.result-date{font-size:11px;color:#6a9955}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background-color:transparent}::-webkit-scrollbar-thumb{background-color:#464647;border-radius:5px;border:2px solid #1e1e1e}::-webkit-scrollbar-thumb:hover{background-color:#555}@media (max-width: 1200px){.left-panel{flex:0 0 40%;width:40%}.right-panel{flex:1}}@media (max-width: 768px){.main-content{flex-direction:column}.left-panel{flex:0 0 50%;width:100%;border-right:none;border-bottom:1px solid #3e3e42}.right-panel{flex:1}.message-content{max-width:90%}.musicbrainz-modal{max-width:95%}.top-bar{flex-wrap:wrap;height:auto;gap:12px}.top-bar-left,.top-bar-right{flex:1 1 100%}.top-bar-right{justify-content:flex-end}}@media (max-width: 480px){.app-title{font-size:16px}.chat-input{font-size:12px}.modal-header h2{font-size:14px}.form-actions{flex-direction:column}.btn-search,.btn-skip{width:100%}}.json-view-toggle{display:flex;border-bottom:1px solid #3e3e42;background-color:#2d2d30;flex-shrink:0;height:34px}.json-view-btn{padding:6px 16px;background:none;color:#858585;font-size:12px;font-weight:500;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s ease}.json-view-btn:hover{color:#d4d4d4;background-color:#353535}.json-view-btn.active{color:#d4d4d4;border-bottom-color:#007acc}.json-editor-source{flex:1;overflow:hidden;position:relative;min-height:0}.json-editor-source>div{position:absolute;top:0;left:0;right:0;bottom:0}.tree-container{width:100%;height:100%;display:flex;flex-direction:column;background-color:#1e1e1e;overflow:hidden}.tree-toolbar{display:flex;gap:8px;padding:6px 12px;background-color:#252526;border-bottom:1px solid #3e3e42;flex-shrink:0}.tree-btn{padding:3px 10px;background-color:#3e3e42;color:#d4d4d4;border:1px solid #555555;border-radius:3px;font-size:11px;cursor:pointer;transition:all .15s ease}.tree-btn:hover{background-color:#464647;border-color:#007acc}.tree-content{flex:1;overflow-y:auto;padding:8px 12px;font-family:Cascadia Code,Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1.6}.tree-root-bracket{color:#858585;padding-left:4px}.tree-node{-webkit-user-select:none;user-select:none}.tree-branch{cursor:pointer;display:flex;align-items:center;gap:4px;padding:1px 0;border-radius:3px}.tree-branch:hover{background-color:#2a2d2e}.tree-leaf{display:flex;align-items:center;gap:0;padding:1px 0}.tree-toggle{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;color:#858585;font-size:12px;font-weight:700;flex-shrink:0}.tree-key{color:#9cdcfe}.tree-colon{color:#858585}.tree-value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-preview{color:#858585;font-style:italic;font-size:12px}.midi-player{flex-shrink:0;border-top:1px solid #3e3e42;background-color:#252526;overflow:hidden;max-height:160px}.midi-player-controls{display:flex;align-items:center;gap:8px;padding:6px 12px}.midi-player-label{flex:1;font-size:12px;color:#858585}.midi-player-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:#3e3e42;color:#d4d4d4;border:1px solid #555555;border-radius:4px;font-size:14px;cursor:pointer;transition:all .15s ease;text-decoration:none}.midi-player-btn:hover{background-color:#464647;border-color:#007acc}.midi-player-btn:disabled{opacity:.5;cursor:not-allowed}.midi-player-embed{padding:0 12px 8px}.midi-player-embed midi-player{display:block;width:100%;margin-bottom:4px}.midi-player-embed midi-player::part(control-panel){background:#1e1e1e;border:1px solid #3e3e42;border-radius:4px}.midi-player-embed midi-visualizer{display:block;width:100%;height:80px;overflow-x:auto;overflow-y:hidden}.midi-player-embed midi-visualizer svg{height:80px}.midi-player-fallback{padding:4px 0}.midi-player-note{font-size:10px;color:#6a6a6a;font-style:italic}@media print{.top-bar,.chat-input-container,.chat-send-button{display:none}.app-container{background-color:#fff;color:#000}.left-panel,.right-panel{break-inside:avoid}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.validate-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#c27604;color:#fff;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.validate-button:hover:not(:disabled){background-color:#e09005}.validate-button:active:not(:disabled){background-color:#a06203}.validate-button:disabled{opacity:.5;cursor:not-allowed}.validation-modal{background-color:#2d2d30;border-radius:8px;border:1px solid #3e3e42;width:600px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 16px 48px #00000080}.validation-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #3e3e42;flex-shrink:0}.validation-header h2{font-size:16px;font-weight:600;color:#e0e0e0;margin:0}.validation-loading{padding:40px 20px;text-align:center;color:#858585;font-size:14px}.validation-content{overflow-y:auto;padding:0}.validation-status{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #3e3e42}.validation-status-pass{background-color:#13a10e1f}.validation-status-warn{background-color:#c276041f}.validation-status-fail{background-color:#d433331f}.validation-icon{font-size:24px;line-height:1}.validation-status-pass .validation-icon{color:#13a10e}.validation-status-warn .validation-icon{color:#c27604}.validation-status-fail .validation-icon{color:#d43333}.validation-status-text{font-size:16px;font-weight:700;letter-spacing:1px}.validation-status-pass .validation-status-text{color:#13a10e}.validation-status-warn .validation-status-text{color:#c27604}.validation-status-fail .validation-status-text{color:#d43333}.validation-status-desc{font-size:13px;color:#a0a0a0}.validation-summary{padding:16px 20px;border-bottom:1px solid #3e3e42}.validation-summary h3,.validation-tracks h3,.validation-issues h3{font-size:12px;font-weight:600;color:#858585;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.validation-stats{display:flex;flex-direction:column;gap:6px}.stat-row{display:flex;justify-content:space-between;font-size:13px;color:#d4d4d4;padding:4px 0}.stat-pass{color:#13a10e}.stat-fail{color:#d43333}.validation-tracks{padding:16px 20px;border-bottom:1px solid #3e3e42}.track-list{display:flex;flex-direction:column;gap:4px}.track-row{padding:8px 12px;border-radius:4px;background-color:#252526}.track-pass{border-left:3px solid #13a10e}.track-warn{border-left:3px solid #c27604}.track-fail{border-left:3px solid #d43333}.track-header-row{display:flex;align-items:center;gap:8px;font-size:13px}.track-icon{font-size:14px}.track-pass .track-icon{color:#13a10e}.track-warn .track-icon{color:#c27604}.track-fail .track-icon{color:#d43333}.track-label{font-weight:600;color:#d4d4d4}.track-stats{color:#858585;margin-left:auto}.track-issues{margin-top:6px;padding-left:22px}.track-issue{font-size:12px;color:#c27604;padding:2px 0}.validation-issues{padding:16px 20px}.issues-list{display:flex;flex-direction:column;gap:4px}.issue-row{font-size:12px;color:#d4a040;padding:2px 0}.comparison-section{border-bottom:1px solid #3e3e42}.comparison-section:last-child{border-bottom:none}.validation-divider{height:0}.validation-status-info{display:flex;flex-direction:column;gap:2px}.song-structure{display:flex;flex-direction:column;height:100%;background:#1a1a2e;color:#d4d4d4;overflow:hidden}.song-structure-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-style:italic}.ss-summary{padding:16px 20px;background:linear-gradient(135deg,#16213e,#1a1a2e);border-bottom:1px solid #2a2a4a;flex-shrink:0}.ss-summary-grid{display:flex;gap:24px;flex-wrap:wrap}.ss-stat{display:flex;flex-direction:column;gap:2px}.ss-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#666}.ss-stat-value{font-size:18px;font-weight:600;color:#e0e0e0}.ss-song-info{margin-top:10px;display:flex;gap:12px;align-items:baseline}.ss-song-title{font-size:15px;font-weight:600;color:#fff}.ss-song-artist{font-size:13px;color:#888}.ss-legend{padding:8px 20px;display:flex;flex-wrap:wrap;gap:10px;border-bottom:1px solid #2a2a4a;background:#16162a;flex-shrink:0}.ss-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:#999}.ss-legend-dot,.ss-inst-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ss-scroll-area{flex:1;overflow:auto;padding:8px 0}.ss-grid-container{display:flex;flex-direction:column}.ss-bar-numbers{display:flex;height:18px;flex-shrink:0;margin-bottom:2px}.ss-bar-num{font-size:9px;color:#555;text-align:center;flex-shrink:0}.ss-bar-num.hovered{color:#fff;font-weight:600}.ss-chord-row{display:flex;height:28px;margin-bottom:4px;flex-shrink:0}.ss-row-label{width:160px;flex-shrink:0;padding:0 12px;font-size:11px;color:#888;display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-chord-cells{display:flex}.ss-chord-cell{height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:default;transition:background-color .1s}.ss-chord-cell.hovered{outline:1px solid rgba(255,255,255,.3);z-index:1}.ss-chord-label{font-size:9px;font-weight:700;letter-spacing:.5px}.ss-inst-row{display:flex;height:22px;flex-shrink:0}.ss-inst-row:hover .ss-row-label{color:#fff}.ss-inst-cells{display:flex}.ss-inst-cell{height:22px;flex-shrink:0;cursor:default;transition:opacity .1s;border-right:1px solid rgba(255,255,255,.03)}.ss-inst-cell.hovered{outline:1px solid rgba(255,255,255,.25);z-index:1}.ss-tooltip{position:fixed;background:#1e1e3a;border:1px solid #444;border-radius:6px;padding:8px 12px;font-size:12px;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #00000080;max-width:280px}.ss-tooltip-header{font-weight:600;color:#fff;margin-bottom:4px}.ss-tooltip-chord{color:#4a9eff}.ss-tooltip-instruments{display:flex;flex-direction:column;gap:2px}.ss-tooltip-inst{display:flex;align-items:center;gap:5px;font-size:11px;color:#aaa}
