:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.App{width:100vw;height:100vh;margin:0;padding:0;position:relative;overflow:hidden}.visualizer{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1}.main-content{position:relative;z-index:2;pointer-events:none;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box}.sequencer{background:#00000008;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border-radius:4px;padding:1rem;margin:0;pointer-events:auto;width:100%;max-width:800px}.controls{margin:1rem 0;display:flex;flex-direction:column;gap:1rem;align-items:center}.control-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:300px}.control-group label{font-size:.9rem;color:#fff}.control-group input[type=range]{width:100%;-webkit-appearance:none;height:6px;background:#fff3;border-radius:3px;outline:none}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#4caf50;border-radius:50%;cursor:pointer;transition:all .2s}.control-group select{width:100%;padding:.75rem;border-radius:8px;border:1px solid rgba(255,255,255,.2);background-color:#ffffff1a;color:#fff;font-size:1rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.5em}.control-group select option{background-color:#333;color:#fff}button{width:100%;max-width:300px;padding:1rem;font-size:1.2rem;background-color:#4caf50cc;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;touch-action:manipulation}button:hover{background-color:#4caf50;transform:translateY(-2px)}button:active{transform:translateY(0)}.grid-container{display:flex;gap:.5rem;margin-top:1rem;overflow-x:visible;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.note-labels{display:flex;flex-direction:column;gap:.5rem;min-width:60px}.note-label{height:clamp(30px,8vw,40px);display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;font-family:monospace;color:#fff;font-size:clamp(.8rem,3vw,1rem)}.grid{display:flex;flex-direction:column;gap:.5rem;min-width:0;flex:1}.row{display:flex;gap:.5rem}.step{width:clamp(30px,8vw,40px);height:clamp(30px,8vw,40px);background-color:#ffffff1a;border:none;border-radius:4px;cursor:pointer;transition:all .2s;touch-action:manipulation}.step:hover{background-color:#fff3}.step.active{background-color:#4caf50cc}.step.current{box-shadow:0 0 2px 1px #fffc}.step.active.current{background-color:#4caf50}.instructions{margin-top:2rem;color:#666}.instructions p{margin:.5rem 0}.envelope-controls{display:flex;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:8px;margin:1rem 0}.envelope-controls .control-group{min-width:120px}.envelope-controls label{font-size:.8rem;color:#ffffffe6;margin-bottom:.3rem}.envelope-controls input[type=range]{width:100%;height:4px;background:#fff3;border-radius:2px;outline:none;-webkit-appearance:none}.envelope-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#4caf50;border-radius:50%;cursor:pointer;transition:all .2s}.envelope-controls input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);background:#66bb6a}@media (min-width: 768px){.main-content{padding:2rem}.sequencer{padding:2rem;margin:1rem}.controls{flex-direction:row;justify-content:center;gap:2rem}.control-group,button{max-width:200px}}.play-button{width:48px;height:48px;padding:0;display:flex;align-items:center;justify-content:center;background-color:#4caf50cc;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .3s}.play-button:hover{background-color:#4caf50;transform:scale(1.1)}.play-button:active{transform:scale(.95)}.play-button svg{width:24px;height:24px}@media (prefers-color-scheme: light){.control-group label,.note-label,.control-group select{color:#666}}.bpm-control{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.5rem;border-radius:8px}.bpm-button{width:36px;height:36px;padding:0;font-size:1.2rem;background-color:#4caf50cc;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center}.bpm-button:hover{background-color:#4caf50;transform:scale(1.1)}.bpm-button:active{transform:scale(.95)}.bpm-value{min-width:48px;text-align:center;font-size:1.2rem;color:#fff;font-family:monospace}@media (prefers-color-scheme: light){.bpm-value{color:#666}}
