:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}#root{width:100%;height:100vh}*{box-sizing:border-box;margin:0;padding:0}html,body{color:#fff;background:#000;width:100%;height:100%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden}.app{width:100%;height:100%}.game-container{width:100%;height:100%;position:relative}.main-menu{background:linear-gradient(135deg,#0d1b2a 0%,#1b263b 50%,#0d1b2a 100%);flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;display:flex;position:fixed;inset:0;overflow:hidden}.main-menu-bg{background:radial-gradient(at 20%,#415a784d 0%,#0000 50%),radial-gradient(at 80%,#415a7833 0%,#0000 50%);position:absolute;inset:0}.gradient-overlay{background:linear-gradient(#0d1b2acc 0%,#0000 30% 70%,#0d1b2acc 100%);position:absolute;inset:0}.main-menu-content{z-index:1;flex:1;grid-template-columns:320px 1fr 350px;gap:40px;padding:60px 40px 20px;display:grid;position:relative}.menu-nav{flex-direction:column;justify-content:space-between;display:flex}.menu-nav-list{flex-direction:column;gap:8px;display:flex}.menu-nav-item{color:#8b9dc3;letter-spacing:2px;text-align:left;cursor:pointer;text-transform:uppercase;background:#1a2837e6;border:none;border-left:4px solid #0000;border-radius:0 8px 8px 0;padding:16px 24px;font-size:1.3rem;font-weight:600;transition:all .15s}.menu-nav-item:hover:not(:disabled){color:#fff;background:#415a78cc;border-left-color:#4fc3f7;transform:translate(8px)}.menu-nav-item.active{color:#fff;background:linear-gradient(90deg,#4fc3f74d 0%,#415a78cc 100%);border-left-color:#4fc3f7}.menu-nav-item:disabled{opacity:.4;cursor:not-allowed}.menu-footer{color:#5a6a7d;margin-top:auto;padding:20px;font-size:.9rem}.menu-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.game-logo{text-shadow:0 0 60px #4fc3f780;margin:0;line-height:.85}.logo-line1,.logo-line2{letter-spacing:-4px;background:linear-gradient(#fff 0%,#b0c4de 50%,#789 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:8rem;font-weight:900;display:block}.logo-line2{margin-top:-10px}.tagline{color:#8b9dc3;letter-spacing:1px;margin-top:30px;font-size:1.2rem}.menu-right{flex-direction:column;justify-content:flex-start;padding-top:20px;display:flex}.news-panel{background:#1a2837b3;border:1px solid #415a784d;border-radius:12px;padding:24px}.news-panel h3{color:#fff;letter-spacing:2px;text-align:center;border-bottom:1px solid #415a784d;margin:0 0 20px;padding-bottom:12px;font-size:1.1rem}.news-item{border-bottom:1px solid #415a7833;padding:12px 0}.news-item:last-child{border-bottom:none}.news-date{color:#4fc3f7;letter-spacing:1px;margin-bottom:4px;font-size:.75rem;font-weight:600;display:block}.news-item p{color:#aab2bd;margin:0;font-size:.95rem}.menu-bottom-bar{z-index:1;background:#0d1b2af2;border-top:1px solid #415a784d;align-items:center;padding:16px 40px;display:flex;position:relative}.player-slot{background:#415a7833;border-radius:8px;align-items:center;gap:16px;min-width:200px;padding:10px 24px;display:flex}.player-name{color:#fff;font-weight:600}.player-status{color:#4fc3f7;letter-spacing:1px;font-size:.85rem}.song-list-screen{background:linear-gradient(135deg,#0d1b2a 0%,#1b263b 50%,#0d1b2a 100%);flex-direction:column;height:100%;display:flex;overflow:hidden}.song-list-header{background:#0d1b2ae6;border-bottom:1px solid #415a784d;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.back-btn{color:#fff;cursor:pointer;background:#415a784d;border:1px solid #415a7880;border-radius:6px;padding:10px 20px;transition:all .2s}.header-center{gap:30px;display:flex}.header-hint{color:#5a6a7d;border:1px solid #415a784d;border-radius:4px;padding:6px 12px;font-size:.85rem}.header-right{color:#8b9dc3;font-size:.9rem}.song-list-content{flex:1;grid-template-columns:1fr 400px;display:grid;overflow:hidden}.song-list-left{border-right:1px solid #415a7833;padding:20px;overflow-y:auto}.song-list-left .search-input{color:#fff;background:#1a2837cc;border:1px solid #415a784d;border-radius:8px;width:100%;margin-bottom:16px;padding:12px 16px;font-size:1rem}.song-list-left .search-input:focus{border-color:#4fc3f7;outline:none}.song-list-scroll{flex-direction:column;gap:4px;display:flex}.song-group{margin-bottom:8px}.group-header{color:#5a6a7d;letter-spacing:1px;background:#1a283780;border-radius:4px;margin-bottom:4px;padding:8px 16px;font-size:.85rem;font-weight:600}.song-list-item{cursor:pointer;background:#1a283766;border-left:3px solid #0000;border-radius:0 6px 6px 0;justify-content:space-between;align-items:center;padding:12px 16px;transition:all .15s;display:flex}.song-list-item:hover,.song-list-item.selected{background:#415a7880;border-left-color:#4fc3f7}.song-item-info{flex-direction:column;flex:1;gap:2px;display:flex}.song-item-artist{color:#8b9dc3;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.song-item-name{color:#fff;font-size:1rem;font-weight:500}.song-item-stats{align-items:center;gap:12px;margin-right:12px;display:flex}.song-stars{color:gold;text-align:right;min-width:30px;font-size:.9rem;font-weight:600}.song-accuracy{color:#8b9dc3;font-size:.9rem}.song-list-item .delete-btn{cursor:pointer;opacity:.3;background:0 0;border:none;padding:4px;font-size:1rem;transition:opacity .2s}.song-list-item:hover .delete-btn{opacity:.6}.song-list-item .delete-btn:hover{opacity:1}.song-list-right{background:#0d1b2a80;padding:24px;overflow-y:auto}.song-details-panel{flex-direction:column;gap:20px;display:flex}.album-art-container{aspect-ratio:1;background:#1a2837cc;border:1px solid #415a784d;border-radius:12px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.album-art-image{object-fit:cover;width:100%;height:100%}.album-art-placeholder{opacity:.3;font-size:4rem}.song-details-info{flex-direction:column;gap:12px;display:flex}.detail-artist{color:#8b9dc3;margin:0;font-size:1.1rem;font-weight:500}.detail-title{color:#fff;margin:0;font-size:1.6rem;font-weight:700;line-height:1.2}.detail-meta{border-top:1px solid #415a784d;flex-direction:column;gap:6px;margin-top:8px;padding-top:16px;display:flex}.detail-meta p{color:#8b9dc3;margin:0;font-size:.9rem}.detail-meta span{color:#5a6a7d}.detail-difficulty{text-align:center;background:#1a283799;border-radius:8px;margin-top:16px;padding:16px}.detail-difficulty h4{color:#5a6a7d;letter-spacing:2px;margin:0 0 12px;font-size:.8rem}.star-rating{justify-content:center;align-items:center;gap:12px;display:flex}.star-count{color:#fff;font-size:1.5rem;font-weight:700}.stars{color:gold;letter-spacing:2px;font-size:1.2rem}.detail-highscore{text-align:center;background:#1a283799;border-radius:8px;margin-top:16px;padding:20px}.detail-highscore h4{color:#5a6a7d;letter-spacing:2px;margin:0 0 12px;font-size:.8rem}.no-score{color:#8b9dc3;font-size:1.5rem;font-weight:600}.btn-play{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2e7d32 0%,#1b5e20 100%);border:none;border-radius:8px;width:100%;margin-top:8px;padding:16px;font-size:1.1rem;font-weight:600;transition:all .2s}.btn-play:hover{transform:translateY(-2px);box-shadow:0 4px 20px #2e7d3266}.no-song-selected{color:#5a6a7d;justify-content:center;align-items:center;height:100%;font-size:1.1rem;display:flex}.song-select{background:linear-gradient(135deg,#0a0a0f 0%,#1a1a2e 50%,#0f0f1a 100%);flex-direction:column;height:100%;padding:30px;display:flex}.song-select-header{margin-bottom:30px}.song-select-header h2{margin-top:10px;font-size:2rem}.song-select-header .artist{color:#ffffffb3;font-size:1.2rem}.selection-panel{max-width:600px}.selection-section{margin-bottom:30px}.selection-section h3{color:#fffc;margin-bottom:15px;font-size:1.2rem}.speed-slider-container{align-items:center;gap:15px;margin-bottom:10px;display:flex}.speed-slider{appearance:none;background:#fff3;border-radius:4px;outline:none;flex:1;height:8px}.speed-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#74b544;border-radius:50%;width:20px;height:20px;box-shadow:0 0 10px #74b54480}.speed-value{color:#74b544;min-width:60px;font-size:1.1rem;font-weight:700}.button-group{flex-wrap:wrap;gap:10px;display:flex}.button-group .btn{min-width:100px}.button-group .btn.disabled{opacity:.3;cursor:not-allowed}.song-info-panel{background:#ffffff0d;border-radius:10px;margin-bottom:30px;padding:20px}.song-info-panel h3{margin-bottom:15px}.song-info-panel p{color:#fffc;margin-bottom:8px}.btn-play{background:linear-gradient(135deg,#74b544,#5a9a3a);padding:20px 60px;font-size:1.3rem}.settings-page{background:linear-gradient(135deg,#0a0a0f 0%,#1a1a2e 50%,#0f0f1a 100%);flex-direction:column;height:100%;padding:30px;display:flex;overflow-y:auto}.settings-header{margin-bottom:30px}.settings-header h2{margin-top:10px;font-size:2rem}.settings-content{max-width:600px}.settings-section{background:#ffffff0d;border-radius:15px;margin-bottom:25px;padding:25px}.settings-section h3{color:#74b544;margin-bottom:20px;font-size:1.3rem}.setting-row{margin-bottom:20px}.setting-row:last-child{margin-bottom:0}.setting-row label{color:#fffc;margin-bottom:10px;font-size:1rem;display:block}.slider-container{align-items:center;gap:15px;display:flex}.slider-container input[type=range]{flex:1}.slider-container span{text-align:right;min-width:60px;font-weight:700}.setting-row.checkbox label{cursor:pointer;align-items:center;gap:10px;display:flex}.setting-row.checkbox input[type=checkbox]{cursor:pointer;width:20px;height:20px}.hint{color:#ffffff80;margin-bottom:15px;font-size:.9rem}.keybind-grid{flex-direction:column;gap:10px;display:flex}.keybind-row{background:#ffffff0d;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.fret-name{font-size:1.1rem;font-weight:700}.keybind-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:8px;min-width:120px;padding:8px 20px;font-size:1rem;transition:all .2s}.keybind-btn:hover{background:#fff3}.keybind-btn.listening{background:#74b544;border-color:#74b544;animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.reset-btn{margin-top:10px;background:#ff646433!important;border-color:#ff646480!important}.file-uploader{background:linear-gradient(135deg,#0a0a0f 0%,#1a1a2e 50%,#0f0f1a 100%);flex-direction:column;justify-content:center;align-items:center;height:100%;padding:30px;display:flex}.file-uploader.confirm{text-align:center}.file-uploader.confirm h3{margin-bottom:20px;font-size:1.8rem}.song-preview{background:#ffffff0d;border-radius:15px;min-width:400px;margin-bottom:30px;padding:30px}.song-preview p{margin-bottom:10px;font-size:1.1rem}.cancel-btn{margin-top:20px}.drop-zone{text-align:center;cursor:pointer;background:#ffffff08;border:3px dashed #fff3;border-radius:20px;max-width:500px;padding:60px 40px;transition:all .3s;position:relative}.drop-zone:hover,.drop-zone.drag-over{background:#74b54414;border-color:#74b544}.drop-zone.loading{opacity:.6;cursor:wait}.drop-icon{margin-bottom:20px;font-size:4rem}.drop-text{margin-bottom:10px;font-size:1.4rem;font-weight:600}.drop-hint{color:#ffffff80;font-size:1rem}.file-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.error-message{color:#f66;background:#ff323233;border:1px solid #ff323266;border-radius:10px;margin-top:20px;padding:15px 20px}.btn{cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:10px;padding:12px 24px;font-size:1rem;font-weight:700;transition:all .2s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#74b544,#5a9a3a);box-shadow:0 4px 20px #74b5444d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #74b54480}.btn-secondary{color:#fff;background:#ffffff1a;border:1px solid #ffffff4d}.btn-secondary:hover:not(:disabled){background:#fff3}.game-background{z-index:-1;width:100%;height:100%;position:absolute;top:0;left:0}.game-scene{width:100%;height:100%;position:absolute;top:0;left:0}.game-scene canvas{display:block}.ui-container{pointer-events:none;flex-direction:column;justify-content:space-between;width:100%;height:100%;padding:25px;display:flex;position:absolute;top:0;left:0}.ui-container>*{pointer-events:auto}.fps-counter{color:#74b544;background:#000000b3;border-radius:8px;padding:8px 16px;font-family:monospace;font-size:1rem;position:absolute;top:20px;left:50%;transform:translate(-50%)}.back-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:8px;padding:10px 20px;font-size:1rem;transition:all .2s;position:absolute;top:20px;left:20px}.back-btn:hover{background:#fff3}.score-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0009;border:1px solid #ffffff1a;border-radius:12px;align-self:flex-start;align-items:center;gap:20px;margin-top:50px;padding:15px 25px;display:flex}.score{color:#fff;text-shadow:0 0 10px #fff6;letter-spacing:2px;font-family:Courier New,monospace;font-size:2.5rem;font-weight:700}.multiplier{color:#dddd43;text-shadow:0 0 10px #ddd44380;font-size:2rem;font-weight:700}.combo-display{text-align:center;position:absolute;top:50%;left:30px;transform:translateY(-50%)}.combo-number{text-shadow:0 0 30px;font-size:5rem;font-weight:700;line-height:1}.combo-label{letter-spacing:8px;opacity:.9;margin-top:5px;font-size:1.2rem}.controls-panel{align-self:center;gap:15px;margin-bottom:30px;display:flex}.settings-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0009;border:1px solid #ffffff1a;border-radius:15px;min-width:280px;padding:25px;position:absolute;top:80px;right:25px}.settings-panel .setting-row{margin-bottom:15px}.settings-panel .setting-row label{color:#fffc;margin-bottom:8px;font-size:.9rem;display:block}.settings-panel input[type=range]{-webkit-appearance:none;background:#fff3;border-radius:3px;outline:none;width:100%;height:6px}.settings-panel input[type=range]::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#74b544;border-radius:50%;width:18px;height:18px;box-shadow:0 0 10px #74b54480}.help-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0009;border:1px solid #ffffff1a;border-radius:12px;padding:20px 25px;position:absolute;bottom:25px;right:25px}.help-panel h4{color:#74b544;text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;font-size:1rem}.help-panel p{color:#ffffffb3;margin:6px 0;font-size:.9rem}.star-power-panel{text-align:center;min-width:150px;position:absolute;top:50%;right:30px;transform:translateY(-50%)}.star-power-label{letter-spacing:3px;color:#0ff;text-shadow:0 0 10px #00ffff80;margin-bottom:10px;font-size:.9rem}.star-power-bar{background:#0009;border:2px solid #ffffff4d;border-radius:10px;width:100%;height:20px;overflow:hidden}.star-power-fill{background:linear-gradient(90deg,#0ff,#08f);height:100%;transition:width .1s}.star-power-ready{color:#ff0;text-shadow:0 0 10px #ff0c;margin-top:10px;font-size:.8rem;font-weight:700;animation:.8s infinite pulse}@media (width<=768px){.menu-header h1{font-size:1.5rem}.song-grid{grid-template-columns:1fr}.button-group{flex-direction:column}.button-group .btn{width:100%}.score-panel{padding:10px 15px}.score{font-size:1.5rem}.multiplier{font-size:1.2rem}.combo-number{font-size:3rem}.settings-panel{width:100%;margin-top:10px;position:relative;top:auto;right:auto}.help-panel{display:none}}.song-select-clonehero{background:linear-gradient(135deg,#0d1b2a 0%,#1b263b 50%,#0d1b2a 100%);flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;display:flex;position:fixed;inset:0;overflow:hidden}.select-bg{background:radial-gradient(at 50% 0,#4fc3f733 0%,#0000 50%),radial-gradient(at 50% 100%,#415a784d 0%,#0000 50%);position:absolute;inset:0}.select-content{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex;position:relative}.song-title{color:#fff;text-shadow:0 2px 20px #00000080;margin-bottom:40px;font-size:3rem;font-weight:700}.select-panel{background:#1a2837e6;border-radius:8px;width:100%;max-width:450px;overflow:hidden;box-shadow:0 10px 40px #00000080}.panel-header{text-align:center;color:#fff;background:#0d1b2af2;border-bottom:1px solid #415a784d;padding:16px 20px;font-size:1.4rem;font-weight:600}.panel-subheader{text-align:center;color:#8b9dc3;letter-spacing:2px;text-transform:uppercase;background:#0d1b2acc;border-bottom:1px solid #415a7833;padding:12px 20px;font-size:.9rem}.panel-body{min-height:200px;padding:8px}.instrument-list{flex-direction:column;gap:4px;display:flex}.instrument-item{color:#fff;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:16px;padding:16px 20px;font-size:1.2rem;transition:all .15s;display:flex}.instrument-item:hover,.instrument-item.selected{background:#415a7899}.instrument-item.selected{color:#1a1a2e;background:#c8c8d2f2}.instrument-icon{background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.instrument-item.selected .instrument-icon{background:#0000001a}.diff-badge{color:#fff;background:#e65100;border:2px solid #1a2837e6;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;position:absolute;bottom:-4px;right:-4px}.instrument-item.selected .diff-badge{border-color:#c8c8d2f2}.instrument-name{flex:1}.difficulty-list{flex-direction:column;gap:4px;display:flex}.difficulty-item{color:#fff;cursor:pointer;text-align:center;background:0 0;border:none;border-radius:6px;padding:16px 20px;font-size:1.3rem;transition:all .15s}.difficulty-item:hover,.difficulty-item.selected{color:#1a1a2e;background:#c8c8d2f2}.ready-section{flex-direction:column;gap:16px;padding:16px;display:flex}.ready-btn{color:#1a1a2e;cursor:pointer;background:#c8c8d2f2;border:none;border-radius:6px;padding:20px;font-size:1.5rem;font-weight:600;transition:all .15s}.ready-btn:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.current-selection{background:#0d1b2a99;border-radius:6px;flex-direction:column;gap:12px;padding:16px;display:flex}.sel-item{justify-content:space-between;align-items:center;display:flex}.sel-label{color:#8b9dc3;font-size:.9rem}.sel-value{color:#fff;font-size:1.1rem;font-weight:500}.playback-speed{border-top:1px solid #415a784d;flex-direction:column;gap:8px;margin-top:8px;padding-top:12px;display:flex}.playback-speed .speed-slider{width:100%;margin:0}.playback-speed .speed-value{text-align:center;color:#4fc3f7}.back-option{color:#8b9dc3;cursor:pointer;text-align:center;background:0 0;border:none;padding:12px;font-size:.95rem;transition:all .15s}.back-option:hover{color:#fff}.select-bottom-bar{z-index:1;background:#0d1b2af2;border-top:1px solid #415a784d;justify-content:flex-start;align-items:center;padding:16px 40px;display:flex;position:relative}.back-nav-btn{color:#fff;cursor:pointer;background:#415a784d;border:1px solid #415a7880;border-radius:6px;padding:12px 24px;font-size:1rem;transition:all .2s}.back-nav-btn:hover{background:#415a7880}.upload-btn{color:#fff;cursor:pointer;background:#2e7d32;border:none;border-radius:6px;margin-left:16px;padding:8px 16px;font-size:.9rem;transition:all .2s}.upload-btn:hover{background:#388e3c}
