@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&family=Zen+Kaku+Gothic+New:wght@400;700&display=swap";:root{--bg: #0b0614;--bg2: #170c29;--pink: #ff6fc4;--pink-soft: #ffd6f2;--cyan: #7ef0ff;--violet: #b66dff;--amber: #ffd37e;--red: #ff5a6e;--text: #f3eaff;--mono: "Space Grotesk", "Zen Kaku Gothic New", ui-monospace, monospace;--body: "Zen Kaku Gothic New", "Space Grotesk", system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased;user-select:none;touch-action:manipulation}#app{position:fixed;inset:0}button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer}.hidden{display:none!important}.scanlines{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0 2px,rgba(0,0,0,.14) 2px 4px);mix-blend-mode:multiply;z-index:40}.loading{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);letter-spacing:.4em;color:var(--pink-soft);text-shadow:0 0 18px var(--pink);animation:pulse-glow 1.2s ease-in-out infinite;text-align:center}.loading.error{color:var(--red);text-shadow:0 0 18px var(--red);animation:none}.loading small{letter-spacing:.05em;opacity:.7}@keyframes pulse-glow{50%{opacity:.55}}.title-screen{position:absolute;inset:0;overflow:hidden}.title-bg{position:absolute;inset:0;width:100%;height:100%}.boot-log{position:absolute;top:8%;left:50%;transform:translate(-50%);width:min(640px,88vw);font-family:var(--mono);font-size:clamp(11px,1.6vh,14px);line-height:1.9;color:#9de8c9;text-shadow:0 0 8px rgba(157,232,201,.6);z-index:5;transition:opacity .5s}.boot-log .hana-line{color:var(--pink-soft);text-shadow:0 0 10px var(--pink)}.boot-log.fade-out{opacity:0}.title-main{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:6;text-align:center;padding:20px}.bloom-in{animation:bloom-in 1s cubic-bezier(.16,1,.3,1)}@keyframes bloom-in{0%{opacity:0;transform:scale(1.06);filter:blur(10px) saturate(2)}}.title-emblem canvas{width:clamp(120px,22vh,220px);height:clamp(120px,22vh,220px);filter:drop-shadow(0 0 24px rgba(255,111,196,.5));animation:emblem-float 5s ease-in-out infinite}@keyframes emblem-float{50%{transform:translateY(-10px)}}.glitch-logo{position:relative;font-family:var(--mono);font-weight:700;font-size:clamp(34px,7.5vw,76px);letter-spacing:.06em;color:var(--text);text-shadow:0 0 12px rgba(255,111,196,.9),0 0 46px rgba(255,111,196,.5)}.glitch-logo:before,.glitch-logo:after{content:attr(data-text);position:absolute;inset:0;overflow:hidden}.glitch-logo:before{color:var(--cyan);animation:glitch-a 2.7s infinite steps(1);opacity:.8}.glitch-logo:after{color:var(--pink);animation:glitch-b 3.1s infinite steps(1);opacity:.8}@keyframes glitch-a{0%,92%{transform:none;clip-path:inset(0 0 100% 0)}93%{transform:translate(-3px,2px);clip-path:inset(12% 0 60% 0)}95%{transform:translate(3px,-1px);clip-path:inset(60% 0 8% 0)}97%{transform:none;clip-path:inset(0 0 100% 0)}}@keyframes glitch-b{0%,88%{transform:none;clip-path:inset(0 0 100% 0)}89%{transform:translate(4px,1px);clip-path:inset(40% 0 34% 0)}91%{transform:translate(-2px,-2px);clip-path:inset(5% 0 78% 0)}94%{transform:none;clip-path:inset(0 0 100% 0)}}.title-sub{font-family:var(--mono);font-size:clamp(11px,1.8vw,15px);letter-spacing:.22em;color:var(--violet);text-shadow:0 0 12px rgba(182,109,255,.7)}.title-menu{display:flex;flex-direction:column;gap:10px;margin-top:18px;width:min(360px,80vw)}.menu-btn{font-family:var(--mono);font-size:15px;letter-spacing:.14em;padding:13px 26px;color:var(--pink-soft);border:1px solid rgba(255,111,196,.5);background:linear-gradient(90deg,#ff6fc41a,#7ef0ff0f);clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);transition:all .18s}.menu-btn:hover{background:linear-gradient(90deg,#ff6fc452,#7ef0ff2e);border-color:var(--pink);box-shadow:0 0 22px #ff6fc473;transform:translate(4px);color:#fff}.title-hint{margin-top:12px;font-size:12.5px;color:#f3eaff99;letter-spacing:.1em}.title-ver{position:absolute;bottom:14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:#f3eaff52}.modal{position:absolute;inset:0;display:grid;place-items:center;background:#06030cbf;backdrop-filter:blur(6px);z-index:30}.modal-box{width:min(520px,90vw);max-height:86vh;overflow-y:auto;padding:28px 30px;background:linear-gradient(160deg,#1c0e30f5,#0e081af5);border:1px solid rgba(182,109,255,.55);box-shadow:0 0 40px #b66dff40;clip-path:polygon(18px 0,100% 0,100% calc(100% - 18px),calc(100% - 18px) 100%,0 100%,0 18px);display:flex;flex-direction:column;gap:14px;line-height:1.75;font-size:14px}.modal-box h2{font-family:var(--mono);font-size:17px;letter-spacing:.16em;color:var(--cyan);text-shadow:0 0 12px rgba(126,240,255,.6)}.how-keys{display:flex;gap:10px}kbd{font-family:var(--mono);padding:4px 12px;border:1px solid rgba(255,214,242,.5);border-radius:6px;background:#ff6fc41f;box-shadow:0 2px #ff6fc459}.setting-row{display:grid;grid-template-columns:1fr auto;gap:4px 10px;font-family:var(--mono);font-size:13px;letter-spacing:.08em}.setting-row span{color:var(--pink-soft)}.setting-row input[type=range]{grid-column:1 / -1;accent-color:var(--pink);width:100%}.setting-row.checkbox{display:flex;align-items:center;gap:10px}.setting-row.checkbox input{accent-color:var(--pink);width:16px;height:16px}.select-screen{position:absolute;inset:0;display:flex;flex-direction:column;background:radial-gradient(1000px 500px at 80% -10%,rgba(182,109,255,.16),transparent),radial-gradient(800px 500px at 10% 110%,rgba(255,111,196,.12),transparent),linear-gradient(180deg,#0c0716,#170c29);overflow:hidden}.select-header{display:flex;align-items:center;gap:18px;padding:20px 28px 12px}.select-header h1{font-family:var(--mono);font-size:clamp(16px,2.6vw,24px);letter-spacing:.2em;color:var(--pink-soft);text-shadow:0 0 16px rgba(255,111,196,.6)}.select-header h1 span{font-size:.6em;color:var(--violet);letter-spacing:.12em}.back-btn{font-family:var(--mono);font-size:13px;letter-spacing:.14em;color:var(--cyan);padding:8px 14px;border:1px solid rgba(126,240,255,.4);transition:all .15s}.back-btn:hover{background:#7ef0ff24;box-shadow:0 0 14px #7ef0ff59}.song-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:18px;padding:14px 28px 20px;scrollbar-width:thin;scrollbar-color:var(--violet) transparent}.song-card{display:flex;gap:22px;padding:18px;background:linear-gradient(120deg,#1c0e30d9,#0d0818e6);border:1px solid hsla(var(--hue1),80%,65%,.35);clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);animation:card-in .6s cubic-bezier(.16,1,.3,1) both;animation-delay:var(--delay);transition:border-color .2s,box-shadow .2s}.song-card:hover{border-color:hsla(var(--hue1),90%,70%,.85);box-shadow:0 0 32px hsla(var(--hue1),90%,65%,.22)}@keyframes card-in{0%{opacity:0;transform:translateY(26px)}}.song-jacket{width:clamp(96px,16vh,150px);height:clamp(96px,16vh,150px);flex-shrink:0;filter:drop-shadow(0 6px 18px rgba(0,0,0,.55))}.song-info{display:flex;flex-direction:column;gap:5px;min-width:0;flex:1}.song-sector{font-family:var(--mono);font-size:10.5px;letter-spacing:.3em;color:hsla(var(--hue2),90%,72%,.9)}.song-title{font-family:var(--mono);font-size:clamp(19px,3vw,27px);letter-spacing:.04em;color:#fff;text-shadow:0 0 14px hsla(var(--hue1),95%,70%,.55)}.song-subtitle{font-size:12.5px;color:#f3eaffa6}.song-meta{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:#f3eaff8c}.song-transmission{font-size:12.5px;color:var(--pink-soft);opacity:.85;border-left:2px solid hsla(var(--hue1),90%,70%,.6);padding-left:10px;margin:4px 0}.chart-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.chart-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-family:var(--mono);padding:9px 16px;border:1px solid hsla(var(--hue2),85%,65%,.5);background:hsla(var(--hue2),85%,60%,.08);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);transition:all .15s}.chart-btn:hover{background:hsla(var(--hue2),90%,60%,.24);box-shadow:0 0 18px hsla(var(--hue2),90%,65%,.4);transform:translateY(-2px)}.chart-name{font-size:13px;letter-spacing:.16em;color:#fff}.chart-level{font-size:11px;color:hsla(var(--hue2),95%,75%,1)}.best{font-size:9.5px;letter-spacing:.08em;color:var(--amber)}.best.none{color:#f3eaff4d}.select-footer{padding:12px 28px 16px;font-size:12.5px;color:var(--pink-soft);opacity:.75;font-family:var(--mono);letter-spacing:.05em}.play-screen{position:absolute;inset:0;overflow:hidden}#play-canvas{position:absolute;inset:0;display:block}.hud{position:absolute;inset:0;pointer-events:none;z-index:10}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:16px;padding:12px 18px;background:linear-gradient(180deg,rgba(8,4,16,.8),transparent)}.hud-song{display:flex;flex-direction:column;min-width:0}.hud-song-title{font-family:var(--mono);font-size:14px;letter-spacing:.08em;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:32vw}.hud-chart-tag{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--violet)}.hud-progress{flex:1;height:4px;background:#ffffff1f;border-radius:2px;overflow:hidden}.hud-progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--pink),var(--cyan));box-shadow:0 0 10px var(--pink)}.hud-score{font-family:var(--mono);font-weight:700;font-size:clamp(18px,2.6vw,26px);letter-spacing:.12em;color:#fff;text-shadow:0 0 14px rgba(255,111,196,.8);font-variant-numeric:tabular-nums}.hud-sync{position:absolute;top:64px;right:16px;display:flex;align-items:center;gap:8px;font-family:var(--mono)}.hud-sync-label{font-size:8.5px;letter-spacing:.2em;color:var(--cyan);text-align:right;line-height:1.5}.hud-sync-bar{width:clamp(70px,12vw,140px);height:8px;border:1px solid rgba(126,240,255,.5);border-radius:4px;overflow:hidden;background:#0006}.hud-sync-fill{height:100%;width:40%;background:linear-gradient(90deg,#3ba8c9,var(--cyan));box-shadow:0 0 8px var(--cyan);transition:width .25s}.hud-sync-fill.high{background:linear-gradient(90deg,var(--pink),var(--pink-soft));box-shadow:0 0 12px var(--pink)}.hud-sync-fill.low{background:linear-gradient(90deg,#8a2f3c,var(--red));box-shadow:0 0 8px var(--red)}.hud-sync-pct{font-size:10px;color:var(--cyan);width:34px}.hud-acc{position:absolute;top:92px;right:16px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:#f3eaffbf}.hud-acc b{color:#fff;font-variant-numeric:tabular-nums}.hud-center{position:absolute;left:0;right:0;top:30%;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.hud-combo{display:flex;flex-direction:column;align-items:center;opacity:0;transition:opacity .2s}.hud-combo.visible{opacity:1}.hud-combo-num{font-family:var(--mono);font-weight:700;font-size:clamp(40px,8vh,72px);line-height:1;color:#fff;text-shadow:0 0 22px rgba(255,111,196,.9),0 0 60px rgba(255,111,196,.5);font-variant-numeric:tabular-nums}.hud-combo-label{font-family:var(--mono);font-size:11px;letter-spacing:.5em;color:var(--pink-soft)}.hud-combo.pop .hud-combo-num{animation:combo-pop .18s ease-out}@keyframes combo-pop{0%{transform:scale(1.22)}to{transform:scale(1)}}.hud-judgment{font-family:var(--mono);font-weight:700;font-size:clamp(20px,3.6vh,32px);letter-spacing:.3em;min-height:1.3em;text-shadow:0 0 18px currentColor}.hud-judgment.pop{animation:judge-pop .36s cubic-bezier(.16,1,.3,1)}@keyframes judge-pop{0%{transform:scale(1.5);opacity:0;filter:blur(4px)}30%{transform:scale(1);opacity:1;filter:none}}.hud-log{position:absolute;left:14px;bottom:12px;font-family:var(--mono);font-size:10px;line-height:1.8;letter-spacing:.08em;color:#9de8c9a6;text-shadow:0 0 8px rgba(157,232,201,.4)}.hud-log div{animation:log-in .3s ease-out}@keyframes log-in{0%{opacity:0;transform:translate(-8px)}}.pause-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#06030cd1;backdrop-filter:blur(8px);z-index:20}.pause-box{display:flex;flex-direction:column;gap:12px;width:min(320px,84vw);text-align:center}.pause-box h2{font-family:var(--mono);font-size:16px;letter-spacing:.18em;color:var(--pink-soft);margin-bottom:10px;text-shadow:0 0 14px var(--pink)}.pause-box .menu-btn,.pause-box button{font-family:var(--mono);font-size:14px;letter-spacing:.14em;padding:12px;color:var(--pink-soft);border:1px solid rgba(255,111,196,.5);background:#ff6fc414;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);transition:all .15s}.pause-box button:hover{background:#ff6fc447;color:#fff}.result-screen{position:absolute;inset:0;display:grid;place-items:center;overflow:hidden;background:radial-gradient(900px 600px at 50% -20%,rgba(255,111,196,.18),transparent),linear-gradient(180deg,#0c0716,#1a0d2e)}.result-inner{width:min(820px,94vw);max-height:96vh;overflow-y:auto;display:flex;flex-direction:column;gap:20px;padding:30px clamp(16px,4vw,44px);animation:bloom-in .7s cubic-bezier(.16,1,.3,1)}.result-label{font-family:var(--mono);font-size:11px;letter-spacing:.34em;color:var(--cyan);text-shadow:0 0 10px rgba(126,240,255,.6)}.result-song{font-family:var(--mono);font-size:clamp(20px,3.4vw,30px);color:#fff;margin-top:6px}.result-song span{font-size:.55em;color:var(--violet);letter-spacing:.14em}.result-body{display:flex;gap:clamp(18px,5vw,54px);align-items:center}.result-rank-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.result-rank{font-size:clamp(84px,17vw,168px);line-height:1;font-family:var(--mono);font-weight:700}.rank-Splus .result-rank,.rank-S .result-rank{color:var(--pink-soft)}.rank-A .result-rank{color:var(--cyan)}.rank-B .result-rank{color:var(--violet)}.rank-C .result-rank,.rank-D .result-rank{color:#f3eaffbf;text-shadow:0 0 20px rgba(255,90,110,.5)}.result-badge{font-family:var(--mono);font-size:12px;letter-spacing:.3em;color:var(--amber);border:1px solid rgba(255,211,126,.6);padding:5px 14px;text-shadow:0 0 10px rgba(255,211,126,.7);animation:pulse-glow 1.6s infinite}.result-stats{flex:1;display:flex;flex-direction:column;gap:14px;min-width:0}.result-score{display:flex;align-items:baseline;gap:16px}.result-score .label{font-family:var(--mono);font-size:12px;letter-spacing:.3em;color:var(--violet)}.result-score .value{font-family:var(--mono);font-weight:700;font-size:clamp(30px,5.5vw,52px);color:#fff;text-shadow:0 0 20px rgba(255,111,196,.8);font-variant-numeric:tabular-nums}.repair-row{display:flex;align-items:center;gap:12px;font-family:var(--mono)}.repair-row .label{font-size:10px;letter-spacing:.22em;color:var(--cyan);white-space:nowrap}.repair-row .value{font-size:13px;color:#fff;width:64px;font-variant-numeric:tabular-nums}.repair-bar{flex:1;height:10px;border:1px solid rgba(126,240,255,.5);border-radius:5px;overflow:hidden;background:#0006}.repair-fill{height:100%;width:0;background:linear-gradient(90deg,var(--cyan),var(--pink));box-shadow:0 0 12px var(--pink)}.judge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.jg{display:flex;flex-direction:column;align-items:center;gap:2px;font-family:var(--mono);padding:10px 4px;border:1px solid rgba(255,255,255,.14);background:#ffffff08}.jg span{font-size:9px;letter-spacing:.18em;opacity:.85}.jg b{font-size:clamp(16px,2.6vw,24px);font-variant-numeric:tabular-nums}.jg.perfect{color:var(--pink-soft);border-color:#ffd6f266}.jg.great{color:var(--cyan);border-color:#7ef0ff66}.jg.good{color:var(--amber);border-color:#ffd37e66}.jg.miss{color:var(--red);border-color:#ff5a6e66}.result-sub{font-family:var(--mono);font-size:12.5px;letter-spacing:.1em;color:#f3eaffb3}.result-sub b{color:#fff}.result-quote{font-size:14px;color:var(--pink-soft);border-left:3px solid var(--pink);padding:6px 0 6px 14px;text-shadow:0 0 12px rgba(255,111,196,.35)}.result-actions{display:flex;gap:14px;flex-wrap:wrap}.result-actions .menu-btn{flex:1;min-width:180px}@media(max-width:640px){.song-card{flex-direction:column;align-items:center;text-align:center}.song-info{align-items:center}.song-transmission{border-left:none;padding-left:0}.chart-row{justify-content:center}.result-body{flex-direction:column}.hud-song-title{max-width:40vw}.hud-sync{top:56px}.hud-acc{top:84px}}
