:root{--primary-color: #6366f1;--primary-hover: #5855eb;--secondary-color: #64748b;--success-color: #10b981;--background: #0f172a;--surface: #1e293b;--surface-hover: #334155;--border: #475569;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--background);color:var(--text-primary);line-height:1.6;overflow-x:hidden}#app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.5rem 2rem;box-shadow:var(--shadow);text-align:center}.app-header h1{font-size:2rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:.75rem}.app-main{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.step{display:none;animation:fadeIn .3s ease}.step.active{display:block}.step-content{background:var(--surface);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}.step-content h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.step-content p{color:var(--text-secondary);margin-bottom:2rem}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem;text-align:center;background:var(--background);transition:all .3s ease;cursor:pointer}.upload-area:hover{border-color:var(--primary-color);background:var(--surface-hover)}.upload-area.dragover{border-color:var(--primary-color);background:var(--primary-color);background-opacity:.1}.upload-area i{font-size:3rem;color:var(--text-muted);margin-bottom:1rem}.upload-area p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem}.file-list{margin:2rem 0;display:grid;gap:1rem}.file-item{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;display:flex;align-items:center;justify-content:space-between}.file-info{display:flex;align-items:center;gap:1rem}.file-info i{color:var(--primary-color);font-size:1.2rem}.file-name{font-weight:500;color:var(--text-primary)}.file-size{color:var(--text-muted);font-size:.9rem}.file-selector{margin-bottom:2rem}.file-selector label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-control{width:100%;padding:.75rem;background:var(--background);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:1rem}.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.midi-canvas-container{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden;position:relative}#midi-canvas,#results-canvas{width:100%;height:400px;cursor:crosshair;display:block}.motif-controls{display:flex;gap:1rem;justify-content:center}.results-layout{display:grid;grid-template-columns:300px 1fr;gap:2rem;margin-top:2rem}.results-sidebar{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.results-sidebar h3{margin-bottom:1rem;color:var(--text-primary)}.results-file-list{margin-bottom:2rem}.results-file-item{padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between}.results-file-item:hover{background:var(--surface-hover);border-color:var(--primary-color)}.results-file-item.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.results-viewer{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.results-viewer h3{margin-bottom:1rem;color:var(--text-primary)}.no-matches-message{display:flex;align-items:center;justify-content:center;height:200px;text-align:center;color:var(--text-muted)}.no-matches-content h3{margin:0 0 1rem;color:var(--text-secondary);font-size:1.25rem}.no-matches-content p{margin:.5rem 0;font-size:.875rem;line-height:1.4}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover{background:#059669;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-small{padding:.5rem .75rem;font-size:.75rem}.selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;margin-top:-2rem;gap:1rem}.midi-controls{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem}.zoom-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.zoom-controls label{font-size:.875rem;color:var(--text-secondary);margin-right:.5rem;white-space:nowrap}#zoom-level,#zoom-level-y,#results-zoom-level,#results-zoom-level-y{font-size:.875rem;color:var(--text-primary);min-width:50px;text-align:center}.control-hint{margin-left:auto;display:flex;align-items:center;gap:1rem;max-width:300px}.control-hint small{color:var(--text-muted);font-size:.75rem;opacity:.8;display:flex;align-items:center;gap:.5rem}.color-legend{display:inline-flex;align-items:center;gap:.25rem}.color-dot{width:8px;height:8px;border-radius:50%}.color-dot.exact{background-color:#10b981}.color-dot.close{background-color:#f97316}.match-indicator{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.125rem .375rem;border-radius:4px;margin-left:.5rem}.match-indicator.exact{background-color:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.match-indicator.close{background-color:#f9731633;color:#f97316;border:1px solid rgba(249,115,22,.3)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.note{cursor:pointer;transition:all .1s ease}.note:hover{stroke-width:2}.note.selected{fill:#06b6d4!important;stroke:#0891b2;stroke-width:2}.note.highlighted{fill:#10b981!important;stroke:#059669;stroke-width:2}.note.motif-occurrence{fill:#ef4444!important;stroke:#dc2626;stroke-width:2}.audio-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.results-audio-controls{display:flex;align-items:center;gap:1rem;margin-left:auto}.results-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.results-header-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.channel-selector{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.channel-selector select{min-width:150px;padding:.5rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--background);color:var(--text-color);font-size:.9rem}.channel-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color-alpha)}.btn-audio{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--success-color);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;white-space:nowrap}.btn-audio:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-audio:disabled{background:var(--surface-hover);color:var(--text-muted);cursor:not-allowed;transform:none}.btn-audio i{font-size:.9rem}.volume-control{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.volume-control label{color:var(--text-secondary)}.volume-control input[type=range]{width:80px;height:4px;background:var(--border);border-radius:2px;outline:none;-webkit-appearance:none}.volume-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary-color);border-radius:50%;cursor:pointer}.volume-control input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--primary-color);border-radius:50%;cursor:pointer;border:none}#volume-display,#speed-display{font-size:.8rem;color:var(--text-muted);min-width:40px}.playback-speed{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.playback-speed label{color:var(--text-secondary)}.playback-speed input[type=range]{width:80px;height:4px;background:var(--border);border-radius:2px;outline:none;-webkit-appearance:none}.playback-speed input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary-color);border-radius:50%;cursor:pointer}.playback-speed input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--primary-color);border-radius:50%;cursor:pointer;border:none}.selection-controls{display:flex;gap:1rem}.selection-controls-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem}.selection-controls-right{display:flex;gap:1rem}.motif-controls{display:flex;flex-direction:column;gap:1rem}.btn-audio.playing{background:#dc2626}.btn-audio.playing:hover{background:#b91c1c}.btn-audio.playing i{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.btn-audio.loading{background:var(--secondary-color);cursor:wait}.btn-audio.loading i{animation:spin 1s linear infinite}.canvas-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10}.zoom-controls-overlay{position:absolute;top:.75rem;right:.75rem;background:#1e293bf2;border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow);pointer-events:auto}.zoom-controls-overlay .zoom-controls{gap:.5rem;margin:0;flex-wrap:nowrap}.zoom-controls-overlay .zoom-controls label{font-size:.75rem;color:var(--text-secondary);margin-right:.25rem;white-space:nowrap}.zoom-controls-overlay .zoom-controls span{font-size:.75rem;color:var(--text-primary);min-width:40px;text-align:center}.zoom-controls-overlay .btn-small{padding:.25rem .5rem;font-size:.7rem}.control-hint-overlay{position:absolute;bottom:.75rem;left:.75rem;right:.75rem;background:#1e293bf2;border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.control-hint-overlay small{color:var(--text-muted);font-size:.7rem;opacity:.9;display:block;text-align:center}.midi-canvas-container{position:relative}@media (max-width: 1024px){.results-layout{grid-template-columns:1fr}.app-main{padding:1rem}}@media (max-width: 768px){.motif-controls{flex-direction:column;align-items:stretch}.upload-area{padding:2rem 1rem}.step-content{padding:1.5rem}.zoom-controls-overlay{top:.5rem;right:.5rem;padding:.25rem}.zoom-controls-overlay .zoom-controls{flex-wrap:wrap;gap:.25rem}.zoom-controls-overlay .zoom-controls label{font-size:.65rem;margin-right:.125rem}.zoom-controls-overlay .zoom-controls span{font-size:.65rem;min-width:35px}.zoom-controls-overlay .btn-small{padding:.125rem .25rem;font-size:.6rem}.control-hint-overlay{bottom:.5rem;left:.5rem;right:.5rem;padding:.25rem}.control-hint-overlay small{font-size:.6rem}}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted)}.loading i{animation:spin 1s linear infinite;margin-right:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state i{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state h3{margin-bottom:.5rem;color:var(--text-secondary)}.btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}
