.landing-page{align-items:center;background:#000;display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.background-animation{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.floating-circle{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a61a;border:1px solid #14b8a633;border-radius:50%;height:100px;position:absolute;width:100px}.content{color:#fff;max-width:1200px;padding:2rem;text-align:center;z-index:10}.title{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#14b8a6);-webkit-background-clip:text;background-clip:text;font-size:4rem;font-weight:700;margin-bottom:1rem;text-shadow:0 4px 8px #00000080}.subtitle{font-size:1.5rem;font-weight:300;margin-bottom:3rem;opacity:.9}.features{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.feature{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:20px;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.feature:hover{background:#14b8a640;box-shadow:0 20px 40px #14b8a64d;transform:translateY(-5px)}.feature-icon{display:block;font-size:3rem;margin-bottom:1rem}.feature h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.feature p{line-height:1.6;opacity:.8}.cta-section{margin-top:2rem}.cta-button{background:linear-gradient(45deg,#14b8a6,#0d9488);border:none;border-radius:50px;box-shadow:0 8px 25px #14b8a699;cursor:pointer;display:inline-block;font-size:1.2rem;font-weight:600;padding:1rem 3rem;transition:all .3s ease}.cta-button,.cta-button:hover{color:#fff;text-decoration:none}.cta-button:hover{box-shadow:0 12px 35px #14b8a6cc;transform:translateY(-2px)}@media (max-width:768px){.title{font-size:2.5rem}.subtitle{font-size:1.2rem}.features{grid-template-columns:1fr}.content{padding:1rem}}.piano-page{background:#000;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem}.piano-container{color:#fff;margin:0 auto;max-width:1200px}.controls{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.control-group label{color:#ffffffe6;font-size:1.1rem}.instrument-btn.active:hover{background:linear-gradient(45deg,#14b8a6,#0d9488)}.piano{margin:0 auto 3rem}.instructions{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:15px;margin:0 auto;max-width:800px;padding:2rem}.instructions h3{color:#fff;font-size:1.3rem;margin-bottom:1rem}.instructions ul{list-style:none;padding:0}.instructions li{border-bottom:1px solid #14b8a633;color:#ffffffe6;padding:.5rem 0}.instructions li:last-child{border-bottom:none}.instructions li:before{content:"🎵 ";margin-right:.5rem}.metronome-controls{align-items:flex-start}.metronome-btn{min-width:100px}.tempo-control{display:flex;flex-direction:column;gap:.5rem;width:100%}.tempo-control label{color:#ffffffe6;font-size:.9rem}.tempo-slider{-webkit-appearance:none;appearance:none;background:#14b8a633;border-radius:3px;height:6px;outline:none;width:100%}.tempo-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(45deg,#14b8a6,#0d9488);border-radius:50%;box-shadow:0 2px 6px #0000004d;cursor:pointer;height:18px;width:18px}.tempo-slider::-moz-range-thumb{background:linear-gradient(45deg,#14b8a6,#0d9488);border:none;border-radius:50%;box-shadow:0 2px 6px #0000004d;cursor:pointer;height:18px;width:18px}.beat-indicator{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem}.beat-dot{background:#ffffff4d;border-radius:50%;height:12px;transition:all .1s ease;width:12px}.beat-dot.active{background:#14b8a6;box-shadow:0 0 10px #14b8a699}.recording-controls{align-items:flex-start}.recording-btn.active:hover{background:linear-gradient(45deg,#ef4444,#dc2626)}@media (max-width:768px){.recording-visualization{margin-bottom:1rem;padding:1rem}.note-labels{width:60px}.time-labels{font-size:.8rem;margin-left:60px}.note-label{font-size:.7rem;height:25px}.note-block{height:15px;top:5px}.recording-stats{gap:.5rem;grid-template-columns:1fr}.legend-items{justify-content:center}.piano-page{padding:1rem}.header{flex-direction:column;gap:1rem;text-align:center}.header h1{font-size:2rem}.controls{gap:1rem;grid-template-columns:1fr}.instrument-selector,.octave-controls{justify-content:center}.piano{padding:1rem}.white-key{height:150px}.black-key{height:90px}.metronome-controls{align-items:center}.tempo-control{width:200px}.recording-controls{align-items:center}.recording-info{flex-direction:column;gap:.5rem}.timeline{height:50px}.note-label{font-size:.6rem}.recording-stats{gap:.5rem;grid-template-columns:1fr}.legend-items{justify-content:center}.timeline-header{font-size:.8rem}}.timeline-note{animation:noteAppear .3s ease-out}@media (max-width:768px){.playback-controls{align-items:center}.playback-buttons{flex-wrap:wrap;justify-content:center}.playback-btn{font-size:.8rem;min-width:80px;padding:.6rem 1rem}.playback-progress{max-width:300px}}.prompt-dj{align-items:center;background:#000;box-sizing:border-box;color:#fff;display:flex;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1.8vmin;height:100%;justify-content:center;padding:2vmin;position:relative;width:100%}.prompts-area{flex:4 1;margin-top:2vmin}.prompts-container{margin-left:10vmin}.settings-container{flex:1 1;margin:2vmin 0 1vmin}.icon-button,.playback-container{align-items:center;display:flex;flex-shrink:0;justify-content:center}.icon-button{pointer-events:none;position:relative;width:12vmin}.icon-button:hover svg{transform:scale(1.2)}.icon-button svg{height:100%;transition:transform .5s cubic-bezier(.25,1.56,.32,.99);width:100%}.hitbox{aspect-ratio:1;border-radius:50%;cursor:pointer;pointer-events:all;position:absolute;top:9%;width:65%}.loader{stroke:#14b8a6;stroke-width:3;stroke-linecap:round;animation:promptdj-spin 1s linear infinite;transform-box:fill-box;transform-origin:center}@keyframes promptdj-spin{0%{transform:rotate(0deg)}to{transform:rotate(359deg)}}.toast{transition:transform .5s cubic-bezier(.19,1,.22,1)}.toast:not(.showing){transform:translate(-50%,-200%);transition-duration:1s}.prompt.filtered .text-input{background:#ef444433;border:1px solid #ef444466}.settings-controller{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:10px;box-shadow:0 4px 15px #14b8a633;box-sizing:border-box;color:#eee;display:block;font-family:Google Sans,sans-serif;font-size:1.5vmin;overflow-y:auto;padding:2vmin;scrollbar-color:#14b8a6 #1a1a1a;scrollbar-width:thin;transition:width .3s ease-out,max-height .3s ease-out}.settings-controller.showadvanced{max-height:40vmin}.settings-controller::-webkit-scrollbar{width:6px}.settings-controller::-webkit-scrollbar-track{background:#0003;border-radius:3px}.settings-controller::-webkit-scrollbar-thumb{background-color:#14b8a6;border-radius:3px}.setting{display:flex;flex-direction:column;gap:.5vmin;margin-bottom:.5vmin}.setting label{align-items:center;color:#ffffffe6;display:flex;font-weight:700;justify-content:space-between;-webkit-user-select:none;user-select:none;white-space:nowrap}.setting label span:last-child{color:#14b8a6;font-weight:400;min-width:3em;text-align:right}.setting input[type=range]{--track-height:8px;--track-bg:#0000004d;--track-border-radius:4px;--thumb-size:16px;--thumb-bg:#14b8a6;--thumb-border-radius:50%;--thumb-box-shadow:0 2px 6px #14b8a666;--value-percent:0%;-webkit-appearance:none;appearance:none;background:#0000;border:none;cursor:pointer;height:var(--track-height);margin:.5vmin 0;padding:0;vertical-align:middle;width:100%}.setting input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(to right,var(--thumb-bg) var(--value-percent),var(--track-bg) var(--value-percent));border:none;border-radius:var(--track-border-radius);box-shadow:inset 0 1px 3px #0000004d;cursor:pointer;height:var(--track-height);width:100%}.setting input[type=range]::-moz-range-track{background:var(--track-bg);border:none;border-radius:var(--track-border-radius);cursor:pointer;height:var(--track-height);width:100%}.setting input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--thumb-bg);border:2px solid #ffffff4d;border-radius:var(--thumb-border-radius);box-shadow:var(--thumb-box-shadow);cursor:pointer;height:var(--thumb-size);margin-top:calc((var(--thumb-size) - var(--track-height))/-2);width:var(--thumb-size)}.setting input[type=range]::-moz-range-thumb{background:var(--thumb-bg);border:none;border-radius:var(--thumb-border-radius);box-shadow:var(--thumb-box-shadow);cursor:pointer;height:var(--thumb-size);width:var(--thumb-size)}.setting input[type=number],.setting input[type=text],.setting select{background:#0000004d;border:1px solid #14b8a64d;border-radius:5px;box-sizing:border-box;color:#eee;font-family:inherit;font-size:1.5vmin;padding:.4vmin;transition:all .2s ease}.setting input[type=number]{width:6em}.setting input[type=text]{width:100%}.setting input[type=text]::placeholder{color:#ffffff80}.setting input[type=number]:focus,.setting input[type=text]:focus{background:#14b8a61a;border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a64d;outline:none}.setting select{width:100%}.setting select:focus{background:#14b8a61a;border-color:#14b8a6;outline:none}.setting select option{background-color:#1a1a1a;color:#eee}.checkbox-setting{align-items:center;flex-direction:row;gap:1vmin}.setting input[type=checkbox]{accent-color:#14b8a6;cursor:pointer;transform:scale(1.2)}.core-settings-row{display:flex;flex-direction:row;flex-wrap:wrap;gap:4vmin;justify-content:space-evenly;margin-bottom:1vmin}.core-settings-row .setting{min-width:16vmin}.core-settings-row label span:last-child{min-width:2.5em}.advanced-toggle{color:#ffffffb3;cursor:pointer;font-size:1.4vmin;margin:2vmin 0 1vmin;text-decoration:underline;transition:color .2s ease;-webkit-user-select:none;user-select:none;width:-webkit-fit-content;width:fit-content}.advanced-toggle:hover{color:#14b8a6}.advanced-settings{grid-gap:3vmin;display:grid;gap:3vmin;grid-template-columns:repeat(auto-fit,minmax(10vmin,1fr));max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out}.advanced-settings.visible{max-height:40vmin;max-width:120vmin;opacity:1}.divider{border:none;border-top:1px solid #14b8a64d;display:none;margin:2vmin 0;width:100%}.settings-controller.showadvanced .divider{display:block}.auto-row{align-items:center;display:flex;gap:.5vmin}.setting.auto input[type=range]{filter:grayscale(100%);opacity:.5;pointer-events:none}.auto-row span{color:#14b8a6;margin-left:auto}.auto-row label{color:#fffc;cursor:pointer}.auto-row input[type=checkbox]{accent-color:#14b8a6;cursor:pointer;margin:0}.prompt-dj.dragging{cursor:ns-resize;-webkit-user-select:none;user-select:none}@media (max-width:768px){.prompt-dj{font-size:2.2vmin;padding:1vmin}.prompts-container{gap:1vmin;margin-left:5vmin}.prompt{max-width:14vmin;min-width:12vmin}.settings-controller{font-size:1.8vmin;padding:1.5vmin}.text-input{font-size:2.2vmin}}.integrated-music-page{background:#000;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem}.integrated-container{color:#fff;margin:0 auto;max-width:1400px}.header{align-items:center;border-bottom:2px solid #14b8a64d;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.back-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff;font-size:1.1rem;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.back-button:hover{background:#14b8a640;color:#fff;text-decoration:none}.header h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#14b8a6);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700}.branding{text-align:center}.branding h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#14b8a6,#0d9488,#14b8a6);-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800;margin:0;text-shadow:0 0 30px #14b8a64d}.tagline{color:#fffc;font-size:1.1rem;font-weight:400;letter-spacing:.5px;margin:.5rem 0 0}.mode-toggle{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.mode-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.mode-btn.active{background:linear-gradient(45deg,#14b8a6,#0d9488);box-shadow:0 4px 15px #14b8a699}.mode-btn:hover{background:#14b8a640;transform:translateY(-2px)}.mode-btn.active:hover{background:linear-gradient(45deg,#14b8a6,#0d9488)}.piano-section{display:flex;flex-direction:column;gap:2rem}.piano-controls{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.control-group{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem;margin-bottom:20px}.control-group label{align-self:flex-end;color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px;width:100%}.instrument-selector{display:flex;flex-wrap:wrap;gap:.5rem}.instrument-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.instrument-btn.active{background:linear-gradient(45deg,#14b8a6,#0d9488);box-shadow:0 4px 15px #14b8a699}.instrument-btn:hover{background:#14b8a640}.instrument-icon{font-size:1.2rem}.octave-controls{display:flex;gap:.5rem;justify-content:center;width:100%}.octave-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;padding:.75rem 1.5rem;transition:all .3s ease}.octave-btn:hover{background:#14b8a640}.recording-controls{align-items:flex-end;display:flex;flex-direction:column;gap:1rem;width:100%}.recording-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef444426;border:1px solid #ef44444d;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;margin:0 15%;min-width:140px;padding:.75rem 1.5rem;transition:all .3s ease;width:70%}.recording-btn.active{animation:pulse 2s infinite;background:linear-gradient(45deg,#ef4444,#dc2626);box-shadow:0 4px 15px #ef444499}@keyframes pulse{0%,to{box-shadow:0 4px 15px #ef444499}50%{box-shadow:0 4px 20px #ef4444cc}}.recording-btn:hover{background:#ef444440}.recording-info{align-items:center;color:#ffffffe6;display:flex;font-size:.9rem;gap:1rem}.clear-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef444433;border:1px solid #ef44444d;border-radius:15px;color:#fff;cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .3s ease}.clear-btn:hover{background:#ef44444d}.piano{background:linear-gradient(145deg,#14b8a6,#3accac),linear-gradient(45deg,#ffffff1a,#0000 50%,#0000001a),radial-gradient(circle at 30% 30%,#ffffff26 0,#0000 50%),radial-gradient(circle at 70% 70%,#0000001a 0,#0000 50%);background-blend-mode:overlay,soft-light,soft-light,soft-light;border-radius:20px;box-shadow:0 20px 40px #14b8a666,0 0 0 1px #ffffff1a,inset 0 1px 0 #fff3,inset 0 -1px 0 #0000001a;margin:0 auto;max-width:800px;overflow:hidden;padding:2rem;position:relative;width:100%}.piano:before{animation:shimmer 3s ease-in-out infinite;background:linear-gradient(90deg,#0000,#ffffff1a 50%,#0000);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}@keyframes shimmer{0%,to{transform:translateX(-100%)}50%{transform:translateX(100%)}}.white-keys{z-index:1}.white-key,.white-keys{display:flex;position:relative}.white-key{align-items:center;background:linear-gradient(145deg,#fff,#f0fdfa);border:1px solid #ccfbf1;border-radius:0 0 10px 10px;box-shadow:0 4px 8px #0000001a;cursor:pointer;flex:1 1;flex-direction:column;height:200px;justify-content:flex-end;margin:0 1px;padding-bottom:1rem;transition:all .1s ease}.white-key:hover{background:linear-gradient(145deg,#f0fdfa,#ccfbf1);box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.white-key.pressed{background:linear-gradient(145deg,#ccfbf1,#99f6e4);box-shadow:inset 0 2px 4px #0000001a;transform:translateY(2px)}.black-keys{left:32px;position:absolute;right:0;top:32px;width:736px;z-index:2}.black-key{align-items:center;background:linear-gradient(145deg,#0d9488,#14b8a6);border:1px solid #0f766e;border-radius:0 0 8px 8px;box-shadow:0 4px 8px #0000004d;cursor:pointer;display:flex;flex-direction:column;height:120px;justify-content:flex-end;padding-bottom:.5rem;position:absolute;transition:all .1s ease;width:6%}.black-key:hover{background:linear-gradient(145deg,#14b8a6,#0d9488);box-shadow:0 6px 12px #0006;transform:translateY(-2px)}.black-key.pressed{background:linear-gradient(145deg,#0f766e,#0d9488);box-shadow:inset 0 2px 4px #0000004d;transform:translateY(2px)}.key-label{color:#14b8a6;font-size:.8rem;font-weight:600;margin-bottom:.25rem}.black-key .key-label{color:#ccfbf1}.melody-preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:15px;margin:0 auto;max-width:400px;padding:1.5rem;text-align:center}.melody-actions{display:flex;justify-content:center}.use-melody-btn{background:linear-gradient(45deg,#14b8a6,#0d9488);border:none;border-radius:25px;box-shadow:0 4px 15px #14b8a699;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.use-melody-btn:hover{box-shadow:0 6px 20px #14b8a6cc;transform:translateY(-2px)}.dj-section{display:flex;flex-direction:column;gap:2rem}.prompts-area{justify-content:center;width:100%}.prompts-area,.prompts-container{align-items:flex-end;display:flex;gap:2vmin}.prompts-container{flex-direction:row;flex-shrink:1;height:100%;overflow-x:auto;padding:1vmin;scrollbar-color:#14b8a6 #1a1a1a;scrollbar-width:thin}.prompts-container::-webkit-scrollbar{height:8px}.prompts-container::-webkit-scrollbar-track{background:#111;border-radius:4px}.prompts-container::-webkit-scrollbar-thumb{background-color:#14b8a6;border-radius:4px}.prompts-container::-webkit-scrollbar-thumb:hover{background-color:#0d9488}.prompt{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:10px;box-shadow:0 4px 15px #14b8a633;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100%;max-height:80vmin;max-width:16vmin;min-width:14vmin;overflow:hidden;position:relative;transition:all .3s ease;width:100%}.prompt:hover{background:#14b8a640;box-shadow:0 8px 25px #14b8a64d;transform:translateY(-2px)}.remove-button{align-items:center;background:#ef444433;border:1px solid #ef44444d;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.8vmin;height:2.8vmin;justify-content:center;left:1.2vmin;line-height:2.8vmin;opacity:.7;position:absolute;top:1.2vmin;transition:all .2s ease;width:2.8vmin;z-index:10}.remove-button:hover{background:#ef444466;opacity:1;transform:scale(1.1)}.prompt-controls{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.2vmin;height:8vmin;margin-bottom:1vmin;padding:0 .5vmin}.prompt-controls,.text-input{box-sizing:border-box;width:100%}.text-input{word-wrap:break-word;-webkit-font-smoothing:antialiased;background:#0000;border:none;border-radius:5px;color:#fff;flex-grow:1;font-family:Google Sans,sans-serif;font-size:1.8vmin;max-height:100%;outline:none;overflow-y:auto;padding:.4vmin;resize:none;scrollbar-color:#14b8a6 #1a1a1a;scrollbar-width:thin;text-align:center}.text-input::-webkit-scrollbar{width:6px}.text-input::-webkit-scrollbar-track{background:#0003;border-radius:3px}.text-input::-webkit-scrollbar-thumb{background-color:#14b8a6;border-radius:3px}.text-input:focus{background:#14b8a61a;box-shadow:0 0 0 2px #14b8a64d}.weight-slider{cursor:ns-resize;height:150px;padding:5px;position:relative}.scroll-container,.weight-slider{align-items:center;display:flex;flex-direction:column;justify-content:center}.scroll-container{flex-grow:1;width:100%}.value-display{color:#14b8a6;font-size:1.3vmin;font-weight:600;margin:.5vmin 0;text-align:center;-webkit-user-select:none;user-select:none}.slider-container{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border:1px solid #14b8a64d;border-radius:6px;box-shadow:inset 0 2px 4px #0000004d,0 2px 4px #14b8a633;height:100%;position:relative;width:12px}.thumb{border-radius:6px;bottom:0;box-shadow:0 2px 8px #0006,0 0 0 1px #ffffff1a;left:0;position:absolute;transition:all .2s ease;width:100%}.thumb:hover{box-shadow:0 4px 12px #00000080,0 0 0 1px #fff3}.add-prompt-button-container{align-items:flex-end;display:flex;flex-shrink:0;height:100%}.add-prompt-btn{align-items:center;background:#14b8a626;border:2px solid #14b8a64d;border-radius:50%;color:#14b8a6;cursor:pointer;display:flex;font-size:3vmin;font-weight:700;height:12vmin;justify-content:center;transition:all .3s ease;width:12vmin}.add-prompt-btn:hover{background:#14b8a640;box-shadow:0 4px 15px #14b8a666;transform:scale(1.1)}.melody-integration{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:15px;margin:0 auto;max-width:800px;padding:2rem}.melody-integration h3{color:#fff;font-size:1.3rem}.melody-info,.melody-integration h3{margin-bottom:1rem;text-align:center}.melody-info p{color:#ffffffe6;line-height:1.6;margin-bottom:1rem}.melody-stats{color:#14b8a6;font-size:.9rem;font-weight:600;gap:2rem}.dj-controls,.melody-stats{display:flex;justify-content:center}.dj-controls{gap:1rem;margin-top:2rem}.play-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:1rem 2rem;transition:all .3s ease}.play-btn.playing{background:linear-gradient(45deg,#22c55e,#16a34a);box-shadow:0 4px 15px #22c55e99}.play-btn:hover:not(.playing){background:#22c55e40}.reset-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#3b82f626;border:1px solid #3b82f64d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:1rem 2rem;transition:all .3s ease}.reset-btn:hover{background:#3b82f640}.toast{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:10px;box-shadow:0 8px 25px #14b8a64d;color:#fff;gap:15px;justify-content:space-between;left:50%;line-height:1.6;max-width:80vw;min-width:200px;padding:15px;position:fixed;top:20px;transform:translateX(-50%);z-index:11}.toast,.toast button{align-items:center;display:flex}.toast button{aspect-ratio:1;background:#ffffffe6;border:none;border-radius:100px;color:#000;cursor:pointer;font-size:16px;height:24px;justify-content:center;transition:all .2s ease;width:24px}.toast button:hover{background:#fff;transform:scale(1.1)}.recording-visualization{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:15px;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:1200px;overflow-x:auto;padding:2rem;width:100%}.recording-visualization h3{color:#fff;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.piano-roll-container{margin-bottom:1.5rem}.piano-roll-header{margin-bottom:.5rem}.time-labels{color:#fffc;display:flex;font-size:.9rem;justify-content:space-between;margin-left:80px}.metronome-controls{gap:1rem}.bpm-control,.metronome-controls{align-items:center;display:flex;flex-direction:column;width:100%}.bpm-control{gap:.5rem}.bpm-control label{color:#ffffffe6;font-size:.9rem;font-weight:600}.bpm-slider{-webkit-appearance:none;appearance:none;background:#fff3;border-radius:3px;height:6px;max-width:200px;outline:none;width:100%}.bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#14b8a6;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:18px;-webkit-transition:all .2s ease;transition:all .2s ease;width:18px}.bpm-slider::-webkit-slider-thumb:hover{box-shadow:0 4px 8px #0006;transform:scale(1.1)}.bpm-slider::-moz-range-thumb{background:#14b8a6;border:none;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:18px;-moz-transition:all .2s ease;transition:all .2s ease;width:18px}.bpm-slider::-moz-range-thumb:hover{box-shadow:0 4px 8px #0006;transform:scale(1.1)}.bpm-input{background:#ffffff1a;border:1px solid #14b8a64d;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;outline:none;padding:.5rem;text-align:center;transition:all .2s ease;width:80px}.bpm-input:focus{border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a64d}.bpm-input::-webkit-inner-spin-button,.bpm-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.metronome-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;min-width:150px;padding:.75rem 1.5rem;transition:all .3s ease}.metronome-btn.active{animation:pulse 1.5s ease-in-out infinite;background:linear-gradient(45deg,#14b8a6,#0d9488);box-shadow:0 4px 15px #14b8a699}.metronome-btn:hover{background:#14b8a640;transform:scale(1.05)}.metronome-btn.active:hover{background:linear-gradient(45deg,#14b8a6,#0d9488)}.piano-roll{background:#0000004d;border:1px solid #14b8a64d;border-radius:8px;display:flex;min-height:300px;overflow:hidden}.note-labels{background:#0006;border-right:1px solid #14b8a64d;flex-direction:column;width:80px}.note-label,.note-labels{display:flex;flex-shrink:0}.note-label{align-items:center;background:#ffffff1a;border-bottom:1px solid #ffffff1a;color:#333;font-size:.8rem;font-weight:600;height:30px;justify-content:center;transition:all .2s ease}.note-label.played{background:#14b8a633;color:#fff;font-weight:700}.note-label.unplayed{background:#ffffff0d;color:#ffffff80;opacity:.4}.note-label:hover{background:#14b8a64d;color:#fff;opacity:1}.note-grid{display:flex;flex:1 1;flex-direction:column;min-height:300px;position:relative}.note-row{border-bottom:1px solid #ffffff1a;flex-shrink:0;height:30px;position:relative}.note-row:last-child{border-bottom:none}.note-block{border-radius:3px;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:20px;min-width:4px;position:absolute;top:5px;transition:all .2s ease}.note-block:hover{box-shadow:0 4px 8px #0006;transform:scale(1.1);z-index:10}.note-grid:before{background-image:linear-gradient(90deg,#ffffff0d 1px,#0000 0);background-size:20px 100%;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.recording-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem}.stat{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.stat-label{color:#fffc;font-size:.9rem}.stat-value{color:#14b8a6;font-size:1rem;font-weight:600}.legend{border-top:1px solid #14b8a64d;padding-top:1rem}.legend h4{color:#ffffffe6;font-size:1rem;margin-bottom:.75rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{align-items:center;color:#fffc;display:flex;font-size:.9rem;gap:.5rem}.legend-color{border-radius:3px;box-shadow:0 1px 3px #0000004d;height:16px;width:16px}.playback-controls{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.playback-buttons{align-items:center;display:flex;gap:.5rem}.playback-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;min-width:100px;padding:.75rem 1.5rem;transition:all .3s ease}.play-btn{background:#22c55e26;border:1px solid #22c55e4d}.play-btn:hover:not(:disabled){background:#22c55e40}.pause-btn{border:1px solid #f59e0b4d;box-shadow:0 4px 15px #f59e0b99}.pause-btn,.pause-btn:hover{background:linear-gradient(45deg,#f59e0b,#d97706)}.stop-btn{background:#ef444426;border:1px solid #ef44444d}.stop-btn:hover:not(:disabled){background:#ef444440}.restart-btn{background:#3b82f626;border:1px solid #3b82f64d}.restart-btn:hover:not(:disabled){background:#3b82f640}.playback-btn:disabled{cursor:not-allowed;opacity:.5}.playback-progress{display:flex;flex-direction:column;gap:.5rem;max-width:400px;width:100%}.progress-bar{background:#ffffff1a;border:1px solid #fff3;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;height:100%;transition:width .1s ease}.progress-time{color:#fffc;font-size:.8rem;text-align:center}.playback-indicator{background:linear-gradient(180deg,#ef4444,#dc2626);bottom:0;box-shadow:0 0 8px #ef4444cc;pointer-events:none;position:absolute;top:0;width:2px;z-index:10}.playback-indicator:before{background:#ef4444;border-radius:50%;box-shadow:0 0 6px #ef4444cc;content:"";height:8px;left:-3px;position:absolute;top:-4px;width:8px}@keyframes noteAppear{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.note-block{animation:noteAppear .3s ease-out}.recording-visualization::-webkit-scrollbar{height:8px}.recording-visualization::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.recording-visualization::-webkit-scrollbar-thumb{background:#14b8a680;border-radius:4px}.recording-visualization::-webkit-scrollbar-thumb:hover{background:#14b8a6b3}@media (max-width:768px){.recording-visualization{margin-bottom:1rem;padding:1rem}.note-labels{width:60px}.time-labels{font-size:.8rem;margin-left:60px}.note-label{font-size:.7rem;height:25px}.note-block{height:15px;top:5px}.recording-stats{gap:.5rem;grid-template-columns:1fr}.legend-items{justify-content:center}.playback-controls{align-items:center}.playback-buttons{flex-wrap:wrap;justify-content:center}.playback-btn{font-size:.8rem;min-width:80px;padding:.6rem 1rem}.playback-progress{max-width:300px}}.audio-recording-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:15px;margin-left:auto;margin-right:auto;margin-top:2rem;max-width:800px;padding:2rem}.audio-recording-controls h3{color:#fff;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.recording-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1.5rem}.record-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef444426;border:1px solid #ef44444d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.record-btn:hover:not(:disabled){background:#ef444440;transform:scale(1.05)}.record-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.stop-record-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#3b82f626;border:1px solid #3b82f64d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.stop-record-btn:hover{background:#3b82f640;transform:scale(1.05)}.download-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#22c55e26;border:1px solid #22c55e4d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.download-btn:hover{background:#22c55e40;transform:scale(1.05)}.clear-audio-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#6b728026;border:1px solid #6b72804d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.clear-audio-btn:hover{background:#6b728040;transform:scale(1.05)}.recording-status{margin-bottom:1rem;text-align:center}.recording-indicator{align-items:center;color:#14b8a6;display:flex;font-weight:600;gap:.5rem;justify-content:center}.pulse-dot{animation:pulse 1.5s ease-in-out infinite;background-color:#ef4444;border-radius:50%;height:12px;width:12px}.recording-info{background:#22c55e1a;border:1px solid #22c55e33;border-radius:10px;padding:1rem;text-align:center}.recording-info p{color:#ffffffe6;font-size:.95rem;margin:0}@media (max-width:768px){.recording-buttons{align-items:center;flex-direction:column}.clear-audio-btn,.download-btn,.record-btn,.stop-record-btn{max-width:250px;width:100%}}.auto-record-info{background:#3b82f61a;border:1px solid #3b82f633;border-radius:8px;margin-top:1rem;padding:.75rem}.auto-record-info p{color:#fffc;font-size:.9rem;margin:0;text-align:center}.midi-import-controls{align-items:flex-end;display:flex;flex-direction:column;gap:10px;width:100%}.midi-file-input{display:none}.midi-import-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#14b8a626;border:1px solid #14b8a64d;border-radius:25px;color:#fff!important;cursor:pointer;display:block;font-size:.9rem;font-weight:600;gap:8px;margin:0 15%;min-width:140px;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .3s ease;width:70%!important}.midi-import-btn:hover{background:#14b8a640;box-shadow:0 4px 15px #14b8a666;transform:translateY(-2px)}.midi-info{align-items:center;background:#14b8a61a;border:1px solid #14b8a633;border-radius:6px;display:flex;gap:10px;padding:8px 12px}.midi-info span{color:#14b8a6;font-size:12px;font-weight:500}.clear-midi-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef444426;border:1px solid #ef44444d;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;padding:4px 8px;transition:all .2s ease}.clear-midi-btn:hover{background:#ef444440;transform:translateY(-2px)}.loading-animation{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.loading-container{color:#fff;text-align:center}.music-notes{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.note{animation:float 2s ease-in-out infinite;color:#14b8a6;font-size:3rem}.note-1{animation-delay:0s}.note-2{animation-delay:.5s}.note-3{animation-delay:1s}.note-4{animation-delay:1.5s}@keyframes float{0%,to{opacity:1;transform:translateY(0) rotate(0deg)}50%{opacity:.7;transform:translateY(-20px) rotate(10deg)}}.loading-text{color:#14b8a6;font-size:1.5rem;font-weight:600;margin-bottom:2rem}.dots{display:inline-block}.dots span{animation:dotPulse 1.5s infinite;opacity:0}.dots span:first-child{animation-delay:0s}.dots span:nth-child(2){animation-delay:.5s}.dots span:nth-child(3){animation-delay:1s}@keyframes dotPulse{0%,to{opacity:0}50%{opacity:1}}.loading-bar{background:#ffffff1a;border-radius:2px;height:4px;margin:0 auto;overflow:hidden;width:300px}.loading-progress{animation:loadingMove 3s ease-in-out forwards;background:linear-gradient(90deg,#14b8a6,#0d9488,#14b8a6);background-size:200% 100%;border-radius:2px;height:100%}@keyframes loadingMove{0%{background-position:0 50%;width:0}50%{background-position:100% 50%;width:70%}to{background-position:0 50%;width:100%}}@media (max-width:768px){.loading-container{padding:0 2rem}.loading-bar{width:250px}.music-notes{gap:.5rem}.note{font-size:2rem}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{min-height:100vh}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a}::-webkit-scrollbar-thumb{background:#14b8a680;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#14b8a6b3}a:focus,button:focus{outline:2px solid #14b8a680;outline-offset:2px}.fade-in{animation:fadeIn .6s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .8s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.loading{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#14b8a6;display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.da486b63.css.map*/