/*! tailwindcss v4.1.10 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-border-style:solid;--tw-font-weight:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:host,:root{--font-sans:var(--font-geist-sans);--color-blue-600:oklch(54.6% .245 262.881);--color-gray-200:oklch(92.8% .006 264.531);--color-white:#fff;--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--font-weight-semibold:600;--radius-xl:.75rem;--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono);--color-foreground:var(--foreground)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--background:#fff;--foreground:#171717}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{background:var(--background);color:var(--foreground);font-family:var(--font-sans),ui-sans-serif,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{-webkit-tap-highlight-color:transparent}}@layer components;@layer utilities{.fixed{position:fixed}.static{position:static}.bottom-0{bottom:calc(var(--spacing)*0)}.z-10{z-index:10}.mb-16{margin-bottom:calc(var(--spacing)*16)}.ml-0{margin-left:calc(var(--spacing)*0)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.h-dvh{height:100dvh}.w-12{width:calc(var(--spacing)*12)}.w-14{width:calc(var(--spacing)*14)}.w-full{width:100%}.grow{flex-grow:1}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}.overflow-y-auto{overflow-y:auto}.rounded-xl{border-radius:var(--radius-xl)}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-gray-200{border-color:var(--color-gray-200)}.bg-white{background-color:var(--color-white)}.p-0{padding:calc(var(--spacing)*0)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.px-0{padding-inline:calc(var(--spacing)*0)}.px-6{padding-inline:calc(var(--spacing)*6)}.pt-3{padding-top:calc(var(--spacing)*3)}.pt-6{padding-top:calc(var(--spacing)*6)}.pb-3{padding-bottom:calc(var(--spacing)*3)}.pb-\[35px\]{padding-bottom:35px}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-blue-600{color:var(--color-blue-600)}.capitalize{text-transform:capitalize}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}:host,html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}:root{--color-bg:#0d0a1a;--color-primary:#ff00c1;--color-secondary:#00f2ff;--color-accent:#f9ff00;--font-main:"Press Start 2P",monospace}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}body,html{height:100%;width:100%;margin:0;overflow:hidden}body{font-family:var(--font-main),ui-monospace,monospace;background:var(--color-bg);color:var(--color-secondary);display:flex;justify-content:center;align-items:center;background-image:radial-gradient(circle at 10% 20%,rgba(255,0,193,.1) 0,transparent 25%),radial-gradient(circle at 90% 80%,rgba(0,242,255,.1) 0,transparent 25%),radial-gradient(circle at 50% 50%,rgba(249,255,0,.05) 0,transparent 30%)}.generator-container{width:100%;max-width:500px;max-height:92dvh;background:rgba(13,10,26,.9);border-radius:15px;border:3px solid;border-image:linear-gradient(160deg,var(--color-primary),var(--color-secondary)) 1;box-shadow:0 0 50px rgba(255,0,193,.3);display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:10px;position:relative;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.header{padding:15px 12px;text-align:center;font-size:clamp(1em,4vw,1.2em);text-shadow:0 0 10px var(--color-primary);background:rgba(0,0,0,.3);flex-shrink:0;z-index:10;overscroll-behavior:contain;touch-action:manipulation}.header,.main-content{border-bottom:2px solid var(--color-primary)}.main-content{flex-grow:1;display:flex;flex-direction:column;gap:20px;overflow-y:auto;z-index:5}.section-title{font-size:.9em;color:var(--color-accent);text-shadow:0 0 5px var(--color-accent);margin-bottom:10px;padding-bottom:5px;border-bottom:1px dashed rgba(249,255,0,.5);display:flex;justify-content:space-between;align-items:center}.playlist-container{background:rgba(0,0,0,.2);border-radius:8px;padding:10px;min-height:20dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(0,242,255,.2)}.playlist-container::-webkit-scrollbar{width:8px}.playlist-container::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:4px}.playlist{list-style:none;padding:0;margin:0}#trackList li,.playlist li{display:flex;-webkit-box-orient:vertical;white-space:normal;word-break:break-word;line-height:1.1em}.playlist-item{display:flex;align-items:center;padding:10px 12px;margin-bottom:8px;border-radius:5px;cursor:pointer;transition:.2s;font-size:.78em}.playlist-item:hover{background:rgba(255,255,255,.1)}.playlist-item.playing{background:var(--color-primary);color:#000;text-shadow:none;box-shadow:0 0 10px var(--color-primary)}.play-icon{margin-right:15px;font-size:1.1em}.channel-controls{display:flex;gap:10px;margin-bottom:15px}.channel-btn{flex:1;padding:8px;font-family:var(--font-main);font-size:.8em;background:rgba(0,0,0,.3);color:var(--color-secondary);border:1px solid var(--color-secondary);border-radius:5px;cursor:pointer;transition:.2s;position:relative}.channel-btn.active{background:var(--color-accent);color:#000;border-color:var(--color-accent);box-shadow:0 0 10px var(--color-accent)}.channel-btn.playing:after{content:"";position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--color-primary);border-radius:50%;box-shadow:0 0 5px var(--color-primary);animation:pulse 1s infinite}@keyframes pulse{0%{transform:scale(.9);opacity:.7}70%{transform:scale(1.2);opacity:1}to{transform:scale(.9);opacity:.7}}.generator-controls{display:grid;grid-template-columns:repeat(6,1fr);gap:15px}.control-group{background:rgba(0,0,0,.2);border-radius:8px;padding:15px;border:1px solid rgba(0,242,255,.2)}.control-group.pitch,.control-group.tempo{grid-column:span 3}.control-group.drums,.control-group.effect,.control-group.waveform{grid-column:span 2}.control-group label{display:block;margin-bottom:10px;font-size:.7em}input[type=range],select{width:100%;background:rgba(0,0,0,.5);color:var(--color-secondary);border:1px solid var(--color-secondary);border-radius:5px;padding:8px;font-family:var(--font-main);font-size:.7em;cursor:pointer}input[type=range]{padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--color-accent);cursor:pointer;border-radius:50%;border:3px solid #000;box-shadow:0 0 5px var(--color-accent)}.piano-roll-container{height:200px;overflow-x:auto;background:#080610;border:1px solid var(--color-secondary);border-radius:8px}.piano-roll{display:flex;height:100%}.piano-roll-step{flex:0 0 35px;border-right:1px solid rgba(0,242,255,.2);display:flex;flex-direction:column}.piano-roll-step.beat{border-right:1px solid rgba(0,242,255,.5)}.piano-key{flex-grow:1;border-bottom:1px solid rgba(255,0,193,.1);cursor:pointer;transition:background .1s}.piano-key.active-sound-0{background-color:var(--color-accent)}.piano-key.active-sound-1{background-color:var(--color-primary)}.piano-key.active-sound-2{background-color:var(--color-secondary)}.sound-select-container{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.sound-select-controls{display:flex;gap:10px}.sound-btn{flex:1;padding:8px;font-size:.7em;border-radius:5px;border:1px solid;cursor:pointer;transition:.2s;background:rgba(0,0,0,.3)}.sound-btn.sound-0{border-color:var(--color-accent);color:var(--color-accent)}.sound-btn.sound-1{border-color:var(--color-primary);color:var(--color-primary)}.sound-btn.sound-2{border-color:var(--color-secondary);color:var(--color-secondary)}.sound-btn.active{color:#000}.sound-btn.sound-0.active{background:var(--color-accent);box-shadow:0 0 10px var(--color-accent)}.sound-btn.sound-1.active{background:var(--color-primary);box-shadow:0 0 10px var(--color-primary)}.sound-btn.sound-2.active{background:var(--color-secondary);box-shadow:0 0 10px var(--color-secondary)}.playback-controls-wrapper{margin-top:20px}.playback-controls{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:10px;align-items:center}.control-button{padding:12px 10px;font-family:var(--font-main);font-size:.7em;color:#000;background:var(--color-secondary);border:none;border-radius:5px;cursor:pointer;transition:.2s}.control-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,242,255,.7)}#playStopBtn.playing{background:var(--color-primary)}#playStopBtn.playing:hover{box-shadow:0 5px 15px rgba(255,0,193,.7)}.nav-bar{display:flex;gap:4px;margin-top:14px;overflow-x:auto;padding-bottom:8px}.nav-btn{flex:1 0 50%;text-align:center;padding:10px 0;background:#252525;color:#fff;border:none;border-radius:6px}.tab-header{display:flex;align-items:center;gap:.5rem;font-size:.9em;color:var(--color-accent);text-shadow:0 0 5px var(--color-accent);padding:.4rem .75rem;border-bottom:2px solid var(--color-primary)}.tab-header button{all:unset;cursor:pointer;color:inherit;line-height:1}.back-btn{font-size:clamp(.75rem,5vw,1.25rem);line-height:1;border:none;background:transparent;color:var(--color-secondary);transform:translateX(-4px);white-space:nowrap;display:flex;align-items:center;gap:.4rem;cursor:pointer}#trackList{max-height:52vh;overflow-y:auto;margin-bottom:.75rem}.track-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:.5rem}.track-buttons button{padding:14px;font-family:var(--font-main);font-size:.75em;color:#000;background:var(--color-secondary);border:none;border-radius:5px;cursor:pointer;transition:.2s}.track-buttons button:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,242,255,.7)}.track-buttons button#deleteTrackBtn:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(255,0,25,.7)}.track-buttons button:nth-child(odd){border-right:1px dashed rgba(0,242,255,.4)}.track-buttons button:nth-child(-n+2){border-bottom:1px dashed rgba(0,242,255,.3)}.track-buttons button#deleteTrackBtn{background:#ff2c2c;color:#000}#trackList li{border-bottom:1px dashed rgba(0,242,255,.2);padding:.35rem .6rem;margin-bottom:.25rem}#trackList li.selected{background:#222;color:#fff}.modal{position:fixed;z-index:2000;inset:0;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);cursor:pointer}.modal.hidden{display:none}.modal-body{background:#fff;padding:1rem;border-radius:.5rem;width:80%;max-width:18rem;box-shadow:0 2px 12px rgba(0,0,0,.2);cursor:auto}.modal-body input{width:100%;padding:.5rem;margin-bottom:.75rem;border:1px solid #ccc;border-radius:4px;font-size:.8em}.modal-body input#nameInput{color:#222;background:#fafafa;border:1px solid #999;caret-color:#222}.modal-body input#nameInput:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 50%,transparent)}.modal-body label{color:#222;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:break-word}.modal-buttons{display:flex;gap:.5rem;justify-content:flex-end;color:#222;border:none;border-radius:4px}.modal-buttons button{flex:1;padding:.7rem 0;font-size:.85em}.visualizer-section{background:rgba(0,0,0,.3);padding:5px;flex-shrink:0;flex:1 1 auto;min-height:0}#visualizer{width:100%;height:45px}.start-overlay{position:absolute;inset:0;background:rgba(13,10,26,.95);z-index:1000;display:flex;justify-content:center;align-items:center;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}#startBtn{font-size:1.5em;padding:20px 40px;background:var(--color-accent);color:#000;border:3px solid #000;border-radius:10px;cursor:pointer;animation:startPulse 2s infinite}@keyframes startPulse{0%{transform:scale(1);box-shadow:0 0 15px var(--color-accent)}50%{transform:scale(1.05);box-shadow:0 0 30px var(--color-accent)}to{transform:scale(1);box-shadow:0 0 15px var(--color-accent)}}.tab.hidden{display:none}.nav-btn.active{background:#ff007a;color:#fff}.hidden{display:none!important}.header.back-btn{display:flex;gap:.6rem;align-items:center;font-size:clamp(.8em,3.8vw,1.4em);cursor:pointer;overflow:hidden;text-overflow:ellipsis}#pitchValue,.header.back-btn{white-space:nowrap}