html,body,#root{margin:0;padding:0;height:100%;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#1e1e1e;color:#e0e0e0}.App{display:flex;flex-direction:column;min-height:100vh;text-align:center}.App-header{padding:1rem 2rem;background-color:#252526;border-bottom:1px solid #333}.App-header h1{margin:0;font-size:1.5rem;font-weight:600}.main-content{display:flex;flex-direction:column;flex-grow:1;padding:2rem;gap:2rem}.left-column{display:flex;flex-direction:column;align-items:center;gap:2rem}.right-column{flex-grow:1;display:flex;flex-direction:column;gap:2rem}@media (min-width: 992px){.main-content{flex-direction:row;align-items:flex-start}.left-column{position:sticky;top:2rem;flex-basis:50%}.right-column{flex-basis:50%}}svg{flex-shrink:0;max-width:100%;height:auto}.note-display{background:#252526;border:1px solid #333;border-radius:12px;padding:1.5rem;width:100%;max-width:400px;box-sizing:border-box}.status{font-size:1rem;color:#aaa;margin:0 0 .5rem}.note{font-size:4rem;font-weight:700;color:#61dafb;margin:0;line-height:1}.recording-controls{background:#252526;border:1px solid #333;border-radius:12px;padding:1.5rem;text-align:center}.recording-controls .status{font-size:1rem;color:#aaa;margin:0 0 1rem}.controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}.controls button{min-width:120px}.start-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:#252526;border:1px solid #333;border-radius:12px}.start-container .description{font-size:1rem;color:#aaa;margin-top:1rem}button{background-color:#0e639c;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease-in-out}button:hover{background-color:#17b}button.secondary{background-color:#3e3e42;color:#e0e0e0}button.secondary:hover{background-color:#4e4e52}button.danger{background-color:#c5282f}button.danger:hover{background-color:#d5383f}a{color:#61dafb;text-decoration:none}.controls-panel{display:flex;flex-direction:column;gap:2rem;width:100%}.control-group{background:#252526;border:1px solid #333;border-radius:12px;padding:1.5rem;text-align:left;width:100%;box-sizing:border-box}.left-column .control-group{max-width:400px}.control-group h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#e0e0e0;border-bottom:1px solid #333;padding-bottom:.75rem}.control-group .description{font-size:.9rem;color:#aaa;margin:-.5rem 0 1rem}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:1.5rem;transition:background-color .2s ease-in-out}.collapsible-header.expanded{margin:-1.5rem -1.5rem 0;border-radius:12px 12px 0 0}.collapsible-header.collapsed{margin:-1.5rem;border-radius:12px}.collapsible-header:hover{background-color:#ffffff0d}.collapsible-header h3{margin:0;padding:0;border:none;flex-grow:1}.collapse-toggle{background:none!important;border:none;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;margin-left:1rem;transition:opacity .2s ease-in-out;opacity:.6;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;outline:none}.collapse-toggle:hover{opacity:1;background:none!important}.collapse-toggle:active{background:none!important}.collapse-toggle:focus{background:none!important}.chevron{width:8px;height:8px;border-right:2px solid #e0e0e0;border-bottom:2px solid #e0e0e0;transform:rotate(45deg);transition:transform .2s ease-in-out}.collapse-toggle.expanded .chevron{transform:rotate(-135deg)}.collapse-toggle.collapsed .chevron{transform:rotate(45deg)}.collapsible-content{margin-top:1rem;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.recommendation-control{display:flex;flex-direction:column;gap:.75rem}.recommendation-control p{margin:0 0 .5rem;font-weight:500}.recommendation-control .buttons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.recommendation-control button{background-color:#3e3e42;color:#e0e0e0;width:100%}.recommendation-control button.active{background-color:#61dafb;color:#1e1e1e;font-weight:700}.calibration-control{margin-top:1rem}.calibration-control label{font-size:1rem;margin-bottom:.5rem;display:block}.calibration-control input[type=range]{width:100%;cursor:pointer}.note-history-display{background:#252526;border:1px solid #333;border-radius:12px;padding:1.5rem;text-align:left;overflow:hidden}.note-history-display h4{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#e0e0e0;border-bottom:1px solid #333;padding-bottom:.75rem}.history-items{display:flex;flex-wrap:wrap;gap:.75rem;color:#aaa;justify-content:center;align-items:center;min-height:100px}.note-history-sheet{display:block;width:100%;height:auto;background-color:#2c2c2e;border-radius:8px;padding:1rem 0}.note-history-sheet .staff line{stroke:#555;stroke-width:1}.note-history-sheet .transition-line{stroke-width:3;stroke-linecap:round;opacity:.8}.note-history-sheet .note-element .note-head{fill:#61dafb;stroke:#1e1e1e;stroke-width:2;transition:all .2s ease}.note-history-sheet .note-element .note-label{font-size:14px;font-weight:700;fill:#e0e0e0;text-anchor:middle;pointer-events:none;opacity:0;transition:opacity .2s ease}.note-history-sheet .note-element:hover .note-head{fill:#fff;r:7}.note-history-sheet .note-element:hover .note-label{opacity:1}.note-history-sheet .ledger-line{stroke:#777;stroke-width:1}.note-history-sheet .octave-shift-label{font-size:12px;font-style:italic;fill:#aaa;text-anchor:middle}.note-history-sheet .key-signature-label{font-size:16px;font-weight:700;fill:#c5c5c5}.note-history-sheet .staff-line{stroke:#555;stroke-width:1}.note-history-sheet .staff-connector{stroke-dasharray:4,4}.recording-controls-section{position:relative}.media-controller{background:linear-gradient(145deg,#2d2d2d,#1a1a1a);border:2px solid #404040;border-radius:12px;padding:0;box-shadow:0 8px 16px #0006,inset 0 1px #ffffff1a,inset 0 -1px #0000004d;overflow:hidden}.controller-body{padding:1.2rem;background:linear-gradient(145deg,#333,#2a2a2a);position:relative}.download-icon-btn{position:absolute;bottom:12px;right:12px;background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:all .2s ease}.download-icon-btn:hover:not(.disabled){background:#58a6ff1a;transform:translateY(-2px)}.download-icon-btn.disabled{opacity:.3;cursor:not-allowed}.simple-download-icon{width:16px;height:16px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.simple-download-arrow{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:8px solid #58a6ff;margin-bottom:2px;transition:all .2s ease}.download-icon-btn:hover:not(.disabled) .simple-download-arrow{border-top-color:#79b8ff;animation:bounce .6s ease-in-out infinite}.simple-download-line{width:12px;height:2px;background:#58a6ff;transition:all .2s ease}.download-icon-btn:hover:not(.disabled) .simple-download-line{background:#79b8ff}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(2px)}}.status-display{margin-bottom:1.5rem}.display-screen{background:#1a1a1a;border:2px inset #333;border-radius:6px;padding:.8rem 1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:inset 2px 2px 4px #000c,inset -1px -1px 2px #ffffff1a}.status-text{color:#00ff41;font-family:Courier New,monospace;font-size:.85rem;font-weight:700;text-shadow:0 0 3px #00ff41;flex:1;text-align:left}.recording-indicator{display:flex;align-items:center;gap:.6rem}.rec-text{color:#666;font-family:Courier New,monospace;font-size:.75rem;font-weight:700;transition:color .3s ease}.recording-indicator.active .rec-text{color:red;text-shadow:0 0 2px #ff0000}.recording-dot{width:10px;height:10px;border-radius:50%;background:#333;border:1px solid #555;transition:all .3s ease}.recording-indicator.active .recording-dot{background:red;border-color:red;box-shadow:0 0 6px red,inset 0 1px 1px #ffffff4d;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.9)}}.media-buttons{display:flex;justify-content:center;gap:2rem;align-items:center}.media-btn{width:60px;height:60px;border:3px solid #555;border-radius:50%;background:radial-gradient(circle at 30% 30%,#4a4a4a,#2a2a2a);box-shadow:0 4px 6px #0000004d,inset 0 1px 3px #ffffff1a,inset 0 -2px 3px #0000004d;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;position:relative}.media-btn:hover{box-shadow:0 6px 10px #0006,inset 0 1px 3px #ffffff26,inset 0 -2px 3px #0006;border-color:#666}.media-btn:active{transform:translateY(2px);box-shadow:0 2px 4px #0006,inset 0 3px 5px #0006,inset 0 -1px 1px #ffffff1a}.media-btn.disabled,.media-btn:disabled{opacity:.4;cursor:not-allowed;background:radial-gradient(circle at 30% 30%,#333,#222);border-color:#333}.media-btn.disabled:hover,.media-btn:disabled:hover{box-shadow:0 4px 6px #0000004d,inset 0 1px 3px #ffffff1a,inset 0 -2px 3px #0000004d;border-color:#333}.record-icon{width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;background:#dc3545;border:2px solid #a71e2a;flex-shrink:0;box-shadow:inset 0 1px 2px #fff3,0 2px 4px #0003}.armed-icon{width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;background:red;border:2px solid #a71e2a;flex-shrink:0;box-shadow:inset 0 1px 2px #fff3,0 2px 4px #0003}.stop-icon{width:20px;height:20px;position:relative;display:flex;align-items:center;justify-content:center}.stop-square{width:16px;height:16px;background:linear-gradient(to right,#ccc,#999);border-radius:2px;box-shadow:0 1px 2px #00000080,inset 0 1px 1px #ffffff4d}.clear-icon{width:20px;height:20px;position:relative;display:flex;align-items:center;justify-content:center}.cross-line{position:absolute;width:16px;height:2px;background:linear-gradient(to right,#ccc,#999);border-radius:1px;box-shadow:0 1px 2px #00000080,inset 0 1px 1px #ffffff4d}.cross-line-1{transform:rotate(45deg)}.cross-line-2{transform:rotate(-45deg)}.play-icon{width:20px;height:20px;position:relative;display:flex;align-items:center;justify-content:center}.play-triangle{width:0;height:0;border-left:12px solid #ccc;border-top:8px solid transparent;border-bottom:8px solid transparent;margin-left:3px}.pause-icon{width:20px;height:20px;position:relative;display:flex;align-items:center;justify-content:center;gap:4px}.pause-bar{width:4px;height:14px;background:linear-gradient(to right,#ccc,#999);border-radius:1px;box-shadow:0 1px 2px #00000080,inset 0 1px 1px #ffffff4d}.media-btn.playing{background-color:#c5282f}.media-btn.playing:hover{background-color:#d5383f}.calibration-control label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.calibration-control input[type=checkbox]{width:auto;margin:0}.control-description{font-size:.85rem;color:#888;margin:.5rem 0 0;line-height:1.4}@keyframes feedback-animation{0%{transform:scale(0) translateY(0);opacity:0}40%{transform:scale(1.2) translateY(0);opacity:1}to{transform:scale(.5) translateY(-100px);opacity:0}}@keyframes sparkle-animation{0%,to{transform:scale(0);opacity:0}50%{transform:scale(1);opacity:1}}.feedback-item .feedback-text,.feedback-item .feedback-text-glow{animation:feedback-animation 1.2s forwards}.feedback-item .sparkle{animation:sparkle-animation .7s forwards;transform-origin:center}.control-item{margin-bottom:1rem}.control-item label{display:block;margin-bottom:.5rem;font-weight:500;color:#e0e0e0}.control-item select,.control-item input[type=range]{width:100%;padding:.5rem;border:1px solid #444;border-radius:4px;background-color:#3c3c3c;color:#e0e0e0;font-size:.9rem}.control-item select:focus,.control-item input[type=range]:focus{outline:none;border-color:#61dafb}.control-item input[type=checkbox]{margin-right:.5rem}.recommendation-panel{background:#252526;border:1px solid #333;border-radius:12px;padding:1.5rem}.recommendation-panel h3{margin-top:0;color:#61dafb}.current-note-info{background:#333;border-radius:8px;padding:1rem;margin-bottom:1rem}.current-note-info p{margin:.25rem 0}.recommendation-info h4{color:#61dafb;margin-bottom:.5rem}.explanation{color:#ccc;line-height:1.5;margin-bottom:1rem}.recommended-notes{margin-bottom:1rem}.note-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.note-chip{background:#61dafb;color:#1e1e1e;padding:.25rem .75rem;border-radius:20px;font-weight:600;font-size:.9rem}.hit-feedback{background:#2d5a2d;border:1px solid #4caf50;border-radius:8px;padding:1rem;margin-top:1rem}.hit-message{margin:0;color:#4caf50;font-weight:500}.waiting-message{text-align:center;color:#aaa;font-style:italic;padding:2rem}.ad-banner-container{width:100%;max-width:100%;margin:0;background-color:#252526;border:1px solid #333;border-radius:12px;overflow:hidden;box-sizing:border-box;min-height:120px}.ad-banner-container.loading,.ad-banner-container.blocked{padding:1.5rem;text-align:center;display:flex;align-items:center;justify-content:center}.ad-loading{display:flex;align-items:center;justify-content:center;gap:12px;color:#aaa;font-size:14px;width:100%}.loading-spinner{width:20px;height:20px;border:2px solid #555;border-top:2px solid #61dafb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ad-blocked-message{display:flex;align-items:center;gap:16px;text-align:left;color:#e0e0e0;width:100%}.ad-blocked-icon{font-size:24px;flex-shrink:0}.ad-blocked-content h4{margin:0 0 8px;font-size:16px;font-weight:600;color:#e0e0e0}.ad-blocked-content p{margin:0 0 12px;font-size:14px;line-height:1.5;color:#aaa}.refresh-button{background-color:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s ease}.refresh-button:hover{background-color:#0056b3}.refresh-button:active{transform:translateY(1px)}.ad-label{background-color:#3e3e42;color:#aaa;font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;text-align:center;border-bottom:1px solid #555}.adsbygoogle{min-height:90px;max-width:100%!important;width:100%!important;display:block!important;box-sizing:border-box!important;overflow:hidden!important}.ad-banner-container:not(.loading):not(.blocked){display:flex;flex-direction:column}@media (max-width: 768px){.ad-blocked-message{flex-direction:column;text-align:center;gap:12px}.ad-blocked-content{text-align:center}.adsbygoogle{min-height:50px}}.ad-banner-container.above-tuning{border-radius:12px;box-shadow:0 2px 8px #0000001a;width:100%!important;max-width:100%!important;box-sizing:border-box!important}.ad-banner-container *{max-width:100%!important;box-sizing:border-box!important}.right-column .ad-banner-container{width:100%!important;max-width:100%!important;flex-shrink:1;min-width:0}
