*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #3b82f6;--secondary-color: #8b5cf6;--bg-dark: #1e293b;--bg-light: #f8fafc;--text-dark: #0f172a;--text-light: #f1f5f9;--border-color: #e2e8f0;--hover-color: #f1f5f9}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-light);color:var(--text-dark)}.app-container{display:flex;height:100vh;overflow:hidden}.sidebar{width:320px;background-color:#fff;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;transition:width .3s ease-in-out,opacity .3s ease-in-out}.sidebar.collapsed{width:0;opacity:0;overflow:hidden;border-right:none}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));display:flex;justify-content:space-between;align-items:center}.sidebar-header-content{display:flex;flex-direction:column;gap:.25rem}.sidebar-header h1{color:#fff;font-size:1.5rem;font-weight:700;line-height:1.2}.sidebar-attribution{color:#ffffffd9;font-size:.875rem;text-decoration:none;transition:all .2s;font-weight:500;opacity:0;animation:fadeInSlide .8s ease-out 1s forwards}.sidebar-attribution:hover{color:#fff;text-decoration:underline}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.sidebar-header-buttons{display:flex;gap:.5rem;align-items:center}.sidebar-collapse{display:flex;background:#ffffff26;border:none;color:#fff;cursor:pointer;padding:.5rem;width:36px;height:36px;border-radius:.375rem;transition:all .2s;align-items:center;justify-content:center}.sidebar-collapse:hover{background:#ffffff40}.sidebar-close{display:none;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;line-height:1;opacity:.8;transition:opacity .2s}.sidebar-close:hover{opacity:1}.sidebar-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:1rem;left:1rem;z-index:1001;background-color:var(--primary-color);border:none;border-radius:.5rem;padding:.5rem;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .3s;color:#fff}.sidebar-toggle:hover{background-color:#2563eb}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.score-section{flex:1;overflow:auto;background-color:#fff;padding:3.5rem 1.5rem;border-bottom:1px solid var(--border-color)}.tools-section{height:380px;background-color:var(--bg-dark);display:flex;flex-direction:column;transition:height .3s ease-in-out}.tools-section.collapsed{height:60px}.tools-section.maximized{height:35vh}.tools-header{display:flex;background-color:#0f172a;border-bottom:1px solid #334155;align-items:stretch}.tools-tabs{display:flex;flex:1}.tab{flex:1;padding:1rem;background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.tab:hover{background-color:#1e293b}.tab.active{background-color:var(--bg-dark);border-bottom:3px solid var(--primary-color)}.tools-content{flex:1;padding:1.5rem;overflow:auto;opacity:1;transition:opacity .2s ease-in-out}.tools-section.collapsed .tools-content{opacity:0;pointer-events:none;height:0;padding:0;overflow:hidden}.tools-toggle{background:none;border:none;border-left:1px solid #334155;color:var(--text-light);cursor:pointer;padding:0 1.5rem;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.tools-toggle:hover{background-color:#1e293b}.chevron-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease-in-out}.chevron-icon svg{width:100%;height:100%}.chevron-icon.down{transform:rotate(180deg)}.exercise-list{flex:1;overflow-y:auto;padding:1rem}.exercise-filters{padding:0 0 1rem}.filter-label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem;color:var(--text-dark)}.filter-select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;background-color:#fff;cursor:pointer}.exercise-item{padding:1rem;margin-bottom:.75rem;border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:all .2s;background-color:#fff}.exercise-item:hover{background-color:var(--hover-color);border-color:var(--primary-color)}.exercise-item.selected{background-color:#eff6ff;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.exercise-title{font-weight:600;font-size:1rem;margin-bottom:.25rem;color:var(--text-dark)}.exercise-level{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.exercise-level.beginner{background-color:#dcfce7;color:#166534}.exercise-level.intermediate{background-color:#fef3c7;color:#92400e}.exercise-level.advanced{background-color:#fee2e2;color:#991b1b}.exercise-description{font-size:.875rem;color:#64748b}.loading-state,.empty-state{text-align:center;padding:2rem;color:#64748b}.score-viewer{display:flex;flex-direction:column;height:100%}.score-header{margin-bottom:1.5rem}.score-title{font-size:1.5rem;font-weight:700;color:var(--text-dark);margin-bottom:.5rem}.score-meta{display:flex;gap:1rem;font-size:.875rem;color:#64748b;margin-bottom:.75rem}.score-notes{padding:.75rem;background-color:#eff6ff;border-left:3px solid var(--primary-color);border-radius:.25rem;font-size:.875rem;color:#1e40af}.score-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;align-items:center}.control-group{display:flex;gap:.5rem;align-items:center;padding:.5rem;background-color:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.control-group label{font-size:.875rem;font-weight:600;color:#475569;margin-right:.5rem}.playback-controls{background-color:#eff6ff;border-color:#bfdbfe}.tempo-control{flex:.5;min-width:150px;max-width:250px;flex-direction:column;align-items:stretch}.tempo-control label{margin-bottom:.25rem}.tempo-control input[type=range]{width:100%;height:6px;background:#cbd5e1;border-radius:3px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.tempo-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary-color);cursor:pointer;border-radius:50%}.tempo-control input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--primary-color);cursor:pointer;border-radius:50%;border:none}.tempo-control input[type=range]:disabled{opacity:.5;cursor:not-allowed}.score-controls button{padding:.5rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.score-controls button:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.score-controls button:disabled{opacity:.5;cursor:not-allowed}.score-controls button.active{background-color:#10b981}.score-controls button.active:hover{background-color:#059669}.score-container{flex:1;border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;background-color:#fff;overflow:auto}.score-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#94a3b8;font-size:1.125rem}.metronome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-light)}.bpm-display{font-size:3rem;font-weight:700;margin-bottom:.5rem}.bpm-label{font-size:.875rem;color:#94a3b8;margin-bottom:1.5rem}.bpm-slider{width:100%;max-width:400px;margin-bottom:2rem}.bpm-slider input[type=range]{width:100%;height:6px;background:#334155;border-radius:3px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.bpm-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--primary-color);cursor:pointer;border-radius:50%}.bpm-slider input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--primary-color);cursor:pointer;border-radius:50%;border:none}.metronome-controls{display:flex;gap:1rem;align-items:center}.metronome-controls button{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.metronome-controls button:hover{background-color:#2563eb}.metronome-controls button.playing{background-color:#ef4444}.metronome-controls button.playing:hover{background-color:#dc2626}.time-signature-select{padding:.5rem 1rem;background-color:#334155;color:#fff;border:1px solid #475569;border-radius:.375rem;cursor:pointer;font-size:.875rem}.beat-indicator{width:60px;height:60px;border-radius:50%;background-color:#334155;transition:all .1s;margin-bottom:1rem}.beat-indicator.active{background-color:var(--primary-color);transform:scale(1.1);box-shadow:0 0 20px #3b82f699}.tuner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-light)}.tuner-display{text-align:center;margin-bottom:2rem}.detected-note{font-size:4rem;font-weight:700;margin-bottom:.5rem}.frequency-display{font-size:1.25rem;color:#94a3b8}.tuner-gauge{width:100%;max-width:400px;height:80px;background:linear-gradient(to right,#ef4444,#f97316,#fbbf24 40%,#22c55e 48%,#22c55e 52%,#fbbf24 60%,#f97316,#ef4444);border-radius:.5rem;position:relative;margin-bottom:2.5rem;overflow:visible;box-shadow:inset 0 2px 8px #0000004d}.gauge-marks{position:absolute;top:100%;left:0;right:0;height:20px;margin-top:.5rem}.gauge-mark{position:absolute;transform:translate(-50%);font-size:.75rem;color:#94a3b8;font-weight:500}.gauge-mark.center{color:#22c55e;font-weight:700}.gauge-center{position:absolute;left:50%;top:0;bottom:0;width:3px;background-color:#fff;transform:translate(-50%);box-shadow:0 0 8px #fff9;z-index:1}.gauge-center:before,.gauge-center:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:2px;height:12px;background-color:#fff6}.gauge-center:before{top:-12px}.gauge-center:after{bottom:-12px}.gauge-needle{position:absolute;top:50%;left:50%;width:0;height:0;transform:translate(-50%) translateY(-50%);transition:left .15s ease-out;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.gauge-needle:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:50px solid #fff;top:-45px}.gauge-needle:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-color:#fff;border-radius:50%;border:2px solid #1e293b}.tuner-status{font-size:1.125rem;font-weight:600;margin-bottom:1.5rem}.tuner-status.in-tune{color:#22c55e}.tuner-status.out-of-tune{color:#fbbf24}.tuner-controls button{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.tuner-controls button:hover{background-color:#2563eb}.tuner-controls button.active{background-color:#ef4444}.tuner-controls button.active:hover{background-color:#dc2626}.tuner-error{color:#f87171;text-align:center}.drone{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-light)}.drone-header{text-align:center;margin-bottom:.75rem}.drone-header h3{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.drone-subtitle{font-size:.75rem;color:#94a3b8}.drone-display{display:flex;flex-direction:column;align-items:center;margin-bottom:.75rem}.drone-indicator{width:80px;height:80px;border-radius:50%;background-color:#334155;display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:.5rem;position:relative;transition:all .3s}.drone-indicator.playing{background-color:var(--primary-color);box-shadow:0 0 30px #3b82f680}.drone-wave{width:6px;height:30px;background-color:#ffffff4d;border-radius:3px;transition:all .3s}.drone-indicator.playing .drone-wave{background-color:#fff;animation:wave .8s ease-in-out infinite}.drone-indicator.playing .drone-wave:nth-child(1){animation-delay:0s}.drone-indicator.playing .drone-wave:nth-child(2){animation-delay:.2s}.drone-indicator.playing .drone-wave:nth-child(3){animation-delay:.4s}@keyframes wave{0%,to{height:30px}50%{height:60px}}.selected-note{font-size:1.75rem;font-weight:700}.drone-mode-toggle{display:flex;gap:.5rem;margin-bottom:.75rem;max-width:400px;margin-left:auto;margin-right:auto}.mode-toggle-btn{flex:1;padding:.5rem 1rem;background-color:#1e293b;border:2px solid #334155;border-radius:.5rem;color:#94a3b8;font-size:.813rem;font-weight:600;cursor:pointer;transition:all .2s}.mode-toggle-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--text-light);background-color:#0f172a}.mode-toggle-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.mode-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.drone-main-controls{display:flex;flex-direction:column;gap:.625rem;margin-bottom:.75rem;max-width:400px;margin-left:auto;margin-right:auto}.drone-control-row{display:flex;align-items:center;gap:.75rem}.drone-label{font-size:.813rem;font-weight:600;color:#94a3b8;min-width:70px;text-align:right}.note-select-large{flex:1;padding:.625rem .75rem;background-color:#1e293b;border:2px solid #334155;border-radius:.5rem;color:var(--text-light);font-size:.938rem;font-weight:500;cursor:pointer;transition:all .2s}.note-select-large:hover:not(:disabled){border-color:var(--primary-color);background-color:#0f172a}.note-select-large:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f626}.note-select-large:disabled{opacity:.5;cursor:not-allowed}.note-select-large option{background-color:#1e293b;color:#fff}.drone-controls{display:flex;justify-content:center;margin-bottom:0}.drone-play-btn{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.625rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 3px 5px #0000001a}.drone-play-btn:hover{background-color:#2563eb;transform:translateY(-2px);box-shadow:0 6px 8px #00000026}.drone-play-btn.playing{background-color:#ef4444}.drone-play-btn.playing:hover{background-color:#dc2626}.drone-info-compact{max-width:400px;margin:0 auto;text-align:center;font-size:.8rem;color:#64748b;padding:.75rem 1rem;background-color:#3b82f61a;border-radius:.5rem;border:1px solid rgba(59,130,246,.2)}@media (max-width: 600px){.drone-mode-toggle,.drone-main-controls{max-width:100%}.drone-control-row{flex-direction:column;align-items:stretch;gap:.5rem}.drone-label{text-align:left;min-width:auto}.drone-play-btn{padding:.875rem 2rem;font-size:1rem}}.app-container.focus-mode .sidebar{display:none}.focus-controls{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;position:absolute;top:1rem;right:1rem;z-index:10;background-color:#fffffff2;padding:.75rem;border-radius:.5rem;box-shadow:0 2px 8px #0000001a}.focus-control-group{display:flex;gap:.375rem;align-items:center;padding:.25rem;background-color:#f8fafc;border-radius:.375rem;border:1px solid #e2e8f0}.tempo-display{font-size:.75rem;font-weight:600;color:#475569;padding:0 .5rem}.focus-controls button{padding:.5rem 1rem;background-color:#fff;color:var(--text-dark);border:1px solid var(--border-color);border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.focus-controls button:hover:not(:disabled){background-color:var(--hover-color);border-color:var(--primary-color)}.focus-controls button:disabled{opacity:.5;cursor:not-allowed}.focus-controls button.active{background-color:#10b981;color:#fff;border-color:#10b981}.focus-controls button.active:hover{background-color:#059669;border-color:#059669}.focus-button{background-color:var(--secondary-color)!important;color:#fff!important;border:none!important}.focus-button:hover{background-color:#7c3aed!important}.focus-button.active{background-color:var(--primary-color)!important}.focus-button.active:hover{background-color:#2563eb!important}.score-viewer.focus-mode{height:100%}.score-viewer.focus-mode .score-container{height:100%;border:none;border-radius:0;padding:2rem}@media (max-width: 768px){.app-container{flex-direction:column}.sidebar{position:fixed;top:0;left:0;height:100vh;width:80%;max-width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;box-shadow:2px 0 8px #00000026;opacity:1}.sidebar.collapsed{width:80%;max-width:320px;opacity:1;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay,.sidebar-close{display:block}.main-content{height:100vh;width:100%}.score-section{padding:1rem 1rem 1rem 5rem}.focus-controls{top:.5rem;right:.5rem;padding:.375rem;gap:.375rem}.focus-controls button{padding:.375rem .75rem;font-size:.8rem}.app-container.focus-mode .score-section{padding:0}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: portrait){.sidebar{position:fixed;top:0;left:0;height:100vh;width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;box-shadow:2px 0 8px #00000026;opacity:1}.sidebar.collapsed{width:320px;opacity:1;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{width:100%}.score-section{padding:1rem 1rem 1rem 5rem}.focus-controls{top:.5rem;right:.5rem;padding:.375rem;gap:.375rem}.focus-controls button{padding:.375rem .75rem;font-size:.8rem}.app-container.focus-mode .score-section{padding:0}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: landscape){.sidebar{position:fixed;top:0;left:0;height:100vh;width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;box-shadow:2px 0 8px #00000026;opacity:1}.sidebar.collapsed{width:320px;opacity:1;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{width:100%}.score-section{padding:1rem 1rem 1rem 5rem}.focus-controls{top:.5rem;right:.5rem;padding:.375rem;gap:.375rem}.focus-controls button{padding:.375rem .75rem;font-size:.8rem}.app-container.focus-mode .score-section{padding:0}}.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:10000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));padding:2rem;text-align:center}.modal-header h2{color:#fff;font-size:1.75rem;font-weight:700;margin:0}.modal-body{padding:2rem;color:var(--text-dark)}.modal-body p{margin:0 0 1rem;line-height:1.6;font-size:1rem}.modal-body p:last-child{margin-bottom:0}.modal-footer{padding:1.5rem 2rem;background-color:var(--bg-light);display:flex;justify-content:center}.modal-button{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #3b82f64d}.modal-button:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.modal-button:active{transform:translateY(0)}@media (max-width: 768px){.modal-content{width:95%;max-width:none;margin:1rem}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-body{padding:1.5rem}.modal-body p{font-size:.9375rem}.modal-footer{padding:1.25rem 1.5rem}}
