:root{--vh: 1vh;--actual-vh: 100vh;--safe-area-inset-top: env(safe-area-inset-top);--safe-area-inset-bottom: env(safe-area-inset-bottom);--safe-area-inset-left: env(safe-area-inset-left);--safe-area-inset-right: env(safe-area-inset-right)}@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/PressStart2P.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*{margin:0;padding:0;box-sizing:border-box;touch-action:manipulation}html,body{height:100%}body{font-family:"Press Start 2P",Courier New,monospace;background:linear-gradient(135deg,#f4a6d7,#9adbe8);background-size:8px 8px,8px 8px,100% 100%;color:#2d2d2d;touch-action:manipulation;font-size:12px;display:grid;place-items:center;overflow:hidden}.app-frame{width:375px;height:500px;background:#fdf7e4;box-shadow:0 8px 24px #00000040;position:relative;overflow:hidden}.start-screen,.play-screen,.result-screen,.loading-screen,.pause-overlay{position:absolute;inset:0}.pause-overlay{position:fixed;top:0;left:0;width:100%;height:100%;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(5px);display:none;background:#000000b3}.pause-container{box-shadow:0 8px 32px #0000004d;width:85%;max-width:280px;margin:auto;border:4px solid #2d2d2d;border-radius:12px;padding:16px;background:linear-gradient(135deg,#f4a6d7,#9adbe8);text-align:center}.pause-title{font-family:"Press Start 2P",monospace;color:#2d2d2d;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white;font-size:14px;margin-bottom:8px}.pause-message{font-family:"Press Start 2P",monospace;color:#2d2d2d;line-height:1.6;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:10px;margin-bottom:10px}.resume-button,.quit-button{background:#ffffffe5;border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;font-family:"Press Start 2P",monospace;cursor:pointer;transition:all .1s ease;text-shadow:none;font-size:10px;padding:8px 12px;display:block;width:100%;max-width:200px;margin:4px auto;text-align:center}.resume-button:hover,.quit-button:hover{background:#e9df97;color:#2d2d2d;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.resume-button:active,.quit-button:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.login-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f4a6d7,#9adbe8,#e9df97);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:1;transition:opacity .5s ease}.login-screen.fade-out{opacity:0}.login-container{background:#fff;border:4px solid #2d2d2d;border-radius:16px;box-shadow:8px 8px #f4a6d77f,-2px -2px #9adbe84d;padding:1.5rem;max-width:320px;width:90%;text-align:center}.login-title{font-family:"Press Start 2P",monospace;font-size:20px;color:#2d2d2d;margin-bottom:.5rem;text-shadow:2px 2px 0 #f4a6d7,-1px -1px 0 #9adbe8}.login-subtitle{font-family:"Press Start 2P",monospace;font-size:9px;color:#666;margin-bottom:1.5rem;line-height:1.6}.login-message{font-family:"Press Start 2P",monospace;font-size:9px;color:#2d2d2d;margin-bottom:1.5rem;line-height:1.6}.login-button{font-family:"Press Start 2P",monospace;font-size:11px;color:#fff;background:linear-gradient(135deg,#1da1f2,#0d8ecf);border:3px solid #2d2d2d;border-radius:12px;padding:10px 14px;cursor:pointer;box-shadow:8px 8px #2d2d2d4d;transition:all .1s ease;width:100%;margin-bottom:.8rem;text-shadow:1px 0 0 rgb(255 255 255 / 30%),-1px 0 0 rgb(255 255 255 / 30%),0 1px 0 rgb(255 255 255 / 30%),0 -1px 0 rgb(255 255 255 / 30%)}.login-button:hover{background:linear-gradient(135deg,#0d8ecf,#1da1f2);transform:translate(4px,4px);box-shadow:4px 4px #2d2d2d4d}.login-button:active{transform:translate(8px,8px);box-shadow:none}.login-button:disabled{background:linear-gradient(45deg,#ccc,#aaa);color:#666;cursor:not-allowed;opacity:.6}.login-button.secondary{background:linear-gradient(45deg,#9adbe8,#b8e6d4);color:#2d2d2d;margin-top:0}.login-button.secondary:hover{background:linear-gradient(45deg,#b8e6d4,#9adbe8)}.login-error{font-family:"Press Start 2P",monospace;font-size:9px;color:#ff7b9a;background:#ffe8ed;border:2px solid #ff7b9a;border-radius:8px;padding:10px;margin-bottom:.8rem;line-height:1.6}.login-user-info{display:flex;align-items:center;gap:.8rem;margin-bottom:1.5rem;padding:12px;background:#f5f5f5;border:3px solid #2d2d2d;border-radius:12px}.login-avatar{width:40px;height:40px;border-radius:50%;border:2px solid #2d2d2d}.login-user-details{flex:1;text-align:left}.login-username{font-family:"Press Start 2P",monospace;font-size:11px;color:#2d2d2d;margin-bottom:.25rem}.login-handle{font-family:"Press Start 2P",monospace;font-size:8px;color:#666}.login-loading{font-family:"Press Start 2P",monospace;font-size:11px;color:#2d2d2d;margin-top:.8rem}.login-loading:after{content:"...";animation:dots 1.5s steps(4,end) infinite}.login-player-name-setup{margin-bottom:1.5rem}.login-player-name-input{font-family:"Press Start 2P",monospace;font-size:11px;color:#2d2d2d;background:#fff;border:3px solid #2d2d2d;border-radius:8px;padding:10px 12px;width:100%;margin-bottom:.8rem;box-sizing:border-box;text-align:center}.login-player-name-input:focus{outline:none;border-color:#f4a6d7;box-shadow:0 0 0 3px #f4a6d74d}.login-player-name-input::placeholder{color:#999;opacity:.8;font-size:10px}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}@media (height <=568px){.login-container{padding:1.5rem;max-width:280px}.login-title{font-size:20px}.login-subtitle,.login-message{font-size:9px;margin-bottom:1.5rem}.login-button{font-size:10px;padding:.8rem 1.5rem}}.play-screen{display:none;flex-direction:column;padding:0;gap:0}.top-row{display:grid;grid-template-columns:1fr;grid-auto-rows:auto;gap:0;place-items:center center}.youtube-container{width:368px;height:207px;border:none;background:#000}#youtube-player{width:100%;height:100%}.game-ui-bar{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;width:100%;font-size:10px;height:40px;background:#ffffffe5;padding:6px 8px}.score-display,.combo-display{font-family:"Press Start 2P",monospace;font-size:11px;color:#2d2d2d;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;line-height:1.2;white-space:nowrap}.score-display span,.combo-display span{display:block;margin-top:2px;text-align:right}.pause-button{background:#fffc;border:2px solid #2d2d2d;border-radius:4px;color:#2d2d2d;font-family:"Press Start 2P",monospace;font-size:10px;padding:4px 6px;cursor:pointer;transition:all .1s ease;max-width:64px;overflow:hidden;text-overflow:ellipsis}.pause-button:hover{background:#f4a6d7;color:#fff}.game-ui-bar .score-display,.game-ui-bar .combo-display{flex:0 0 auto}.game-ui-bar .pause-button{margin-left:auto;min-width:36px}.canvas-container{position:relative;padding:0;flex:0 0 auto;display:block;width:375px;height:253px;min-height:0}.canvas-container canvas{width:375px!important;height:253px!important;max-width:none;border:none;background:#000;margin:0}#gameCanvas{background:#000}.loading-screen{position:absolute;inset:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:1;transition:opacity .5s ease-out}.app-frame .loading-screen{z-index:9999;background:linear-gradient(135deg,#b8e6d4,#9adbe8,#e9df97)}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-container{box-shadow:8px 8px #2d2d2d4d;max-height:90vh;overflow:hidden;width:90%;max-width:320px;border:4px solid #2d2d2d;background:linear-gradient(135deg,#e9df97,#f4a6d7);border-radius:12px;padding:14px;text-align:center}.loading-title{font-family:"Press Start 2P",Courier New,monospace;font-weight:900;color:#2d2d2d;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90vw;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white,2px 2px 0 white,-2px -2px 0 white,2px -2px 0 white,-2px 2px 0 white;animation:bounce8bit 2s ease-in-out infinite;font-size:14px;margin-bottom:6px}.loading-subtitle{font-family:"Press Start 2P",Courier New,monospace;color:#f4a6d7;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:9px;margin-bottom:8px}.loading-progress{margin-bottom:20px}.loading-bar{margin-bottom:12px;position:relative;width:100%;height:10px;border:3px solid #2d2d2d;background:#fff;border-radius:8px;overflow:hidden}.loading-fill{position:relative;height:100%;width:0%;background:#9adbe8;transition:width .2s ease}.loading-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgb(255 255 255 / 40%) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-text{font-family:"Press Start 2P",Courier New,monospace;color:#2d2d2d;font-weight:700;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:10px;margin-top:6px}.loading-status{font-family:"Press Start 2P",Courier New,monospace;font-size:10px;color:#9adbe8;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;min-height:16px}.loading-screen .build-info{position:absolute;bottom:20px;right:20px;text-align:right;opacity:.7;font-size:10px;line-height:1.4;color:#2d2d2d}.press-start-button{margin-top:16px;font-family:"Press Start 2P",Courier New,monospace;font-size:12px;padding:12px 16px;background:#fff;color:#2d2d2d;border:4px solid #2d2d2d;cursor:pointer;text-transform:uppercase;box-shadow:6px 6px #2d2d2d4d}.press-start-button:active{transform:translate(2px,2px);box-shadow:4px 4px #2d2d2d4d}.start-screen{background:linear-gradient(135deg,#e9df97,#f4a6d7,#9adbe8);justify-content:flex-start;box-sizing:border-box;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding:12px;gap:8px}.build-info{text-align:right;line-height:1.4;color:#2d2d2d;position:absolute;bottom:6px;right:6px;font-size:8px;opacity:.8}.build-version{font-weight:700;color:#f4a6d7;text-shadow:1px 1px 0 white;margin-bottom:2px}.build-details{font-family:Courier New,monospace;font-size:9px;color:#2d2d2d}.title{font-weight:900;margin-bottom:8px;line-height:1.2;white-space:normal;word-break:keep-all;overflow-wrap:break-word;max-width:95vw;animation:bounce8bit 2s ease-in-out infinite;font-size:18px;text-align:center;color:#2d2d2d;text-shadow:2px 0 0 #fff,-2px 0 0 #fff,0 2px 0 #fff,0 -2px 0 #fff}@keyframes bounce8bit{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.subtitle{margin-bottom:8px;text-align:center;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:10px;color:#2d2d2d}.song-selection{margin-bottom:8px;width:100%;max-width:340px}.song-selection label{color:#2d2d2d;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;display:block;font-size:10px;margin:4px 0}.alpha-bar{display:grid;grid-template-columns:auto 1fr;align-items:stretch;gap:8px;margin-bottom:8px}.alpha-filter{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:6px;margin:0;align-content:start}.alpha-mode{display:flex;flex-direction:column;gap:6px;margin:0;align-items:stretch;height:100%}.mode-btn{background:#ffffffd9;border:2px solid #2d2d2d;border-radius:6px;color:#2d2d2d;font-family:"Press Start 2P",monospace;font-size:9px;padding:4px 6px;width:100%;cursor:pointer;transition:all .1s ease}.mode-btn.selected{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border-width:2px;outline:2px solid #2d2d2d;outline-offset:0}.alpha-btn{background:#ffffffd9;border:2px solid #2d2d2d;border-radius:6px;color:#2d2d2d;font-family:"Press Start 2P",monospace;font-size:9px;padding:4px 6px;cursor:pointer;transition:all .1s ease}.alpha-btn.selected{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border-width:2px;outline:2px solid #2d2d2d;outline-offset:0}.song-list{max-height:220px;width:100%;max-width:100%;box-sizing:border-box;box-shadow:4px 4px #2d2d2d4d;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;height:160px;overflow:hidden auto;border:3px solid #2d2d2d;border-radius:8px;background:#ffffffe5}.song-item{cursor:pointer;font-family:"Press Start 2P",monospace;color:#2d2d2d;transition:all .1s ease;background:#fffc;touch-action:pan-y;-webkit-tap-highlight-color:transparent;word-break:break-word;display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:8px 10px;border-bottom:2px solid #eee;font-size:9px;white-space:normal;overflow-wrap:anywhere}.song-item:last-child{border-bottom:none}.song-item:hover{background:linear-gradient(45deg,#f4a6d7,#9adbe8);transform:translate(4px)}.song-item.disabled,.song-item.disabled:hover,.song-item.disabled.selected{background:#c8c8c87f;color:#888;cursor:not-allowed;transform:none;border-left:none;text-shadow:none;opacity:.6}.song-item.selected{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border-left:6px solid #2d2d2d;font-weight:700;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white}.song-left{display:inline-flex;align-items:center;gap:8px;min-width:0}.song-emoji{flex:0 0 auto}.song-title{flex:1 1 auto;min-width:0;white-space:normal;font-weight:700}.song-right{text-align:right;display:flex;flex-direction:column;gap:2px;min-width:90px}.song-ranking-col{display:flex;align-items:center;justify-content:center;padding-left:4px}.song-ranking-btn{background:#ffffffe5;border:2px solid #2d2d2d;border-radius:4px;color:#2d2d2d;cursor:pointer;font-size:12px;padding:4px 6px;transition:all .15s ease;box-shadow:0 1px #ccc;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.song-ranking-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px #ccc}.song-ranking-btn:active{transform:translateY(1px);box-shadow:0 0 #ccc}.song-item.disabled .song-ranking-btn{opacity:.5;cursor:not-allowed;pointer-events:none}.song-meta{font-weight:400}.song-meta-sub{opacity:.8;font-size:9px;font-weight:400}.song-group-title{background:linear-gradient(45deg,#e9df97,#f4a6d7);font-family:"Press Start 2P",monospace;color:#2d2d2d;border-bottom:2px solid #2d2d2d;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:8px;font-weight:700}.song-group-left{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px}.song-group-date{font-weight:700}.song-list::-webkit-scrollbar{width:8px}.song-list::-webkit-scrollbar-track{background:#e0e0e0;border-radius:4px}.song-list::-webkit-scrollbar-thumb{background:#f4a6d7;border-radius:4px;border:1px solid #2d2d2d}.song-list::-webkit-scrollbar-thumb:hover{background:#9adbe8}.difficulty-selection{margin-bottom:8px;width:100%;max-width:340px}.difficulty-selection label{color:#2d2d2d;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;display:block;font-size:10px;margin:4px 0}.difficulty-buttons{grid-template-columns:repeat(3,1fr);display:flex;gap:6px}.difficulty-btn{background:#fffc;border:2px solid #2d2d2d;border-radius:6px;color:#2d2d2d;font-family:"Press Start 2P",monospace;cursor:pointer;transition:all .1s ease;display:flex;align-items:center;justify-content:center;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;flex:1;font-size:9px;padding:8px 0}.difficulty-btn:hover{background:linear-gradient(45deg,#f4a6d7,#9adbe8);transform:translateY(-2px);box-shadow:2px 2px #2d2d2d4d}.difficulty-btn.selected{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border-color:#2d2d2d;border-width:3px;font-weight:700}.start-button{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border:3px solid #2d2d2d;border-radius:12px;color:#2d2d2d;font-family:"Press Start 2P",monospace;cursor:pointer;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;box-shadow:8px 8px #2d2d2d4d;transition:all .1s ease;font-size:11px;padding:10px 14px}.start-button:disabled{background:linear-gradient(45deg,#ccc,#aaa);color:#666;cursor:not-allowed;opacity:.6}.start-button:hover:not(:disabled){transform:translate(4px,4px);box-shadow:4px 4px #2d2d2d4d}.start-button:active:not(:disabled){transform:translate(8px,8px);box-shadow:none}.ranking-button{background:#9adbe8;border:3px solid #2d2d2d;border-radius:12px;color:#2d2d2d;font-family:"Press Start 2P",monospace;cursor:pointer;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;box-shadow:6px 6px #2d2d2d4d;transition:all .1s ease;font-size:10px;padding:8px 12px;font-weight:700}.ranking-button:hover{transform:translate(-2px,-2px);box-shadow:8px 8px #2d2d2d66}.ranking-button:active{transform:translate(2px,2px);box-shadow:4px 4px #2d2d2d4d}.banana-emoji{font-size:24px;margin:0 8px;animation:sway8bit 3s ease-in-out infinite}@keyframes sway8bit{0%,to{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}.result-screen{background:linear-gradient(135deg,#e9df97,#f4a6d7,#9adbe8);padding:20px 8px;display:none;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.result-container{background:#fffffff2;border:4px solid #2d2d2d;border-radius:16px;padding:24px;text-align:center;max-width:400px;box-shadow:8px 8px #2d2d2d4d;width:100%;display:flex;flex-direction:column;align-items:center;gap:6px}.result-title{font-weight:900;color:#2d2d2d;margin-bottom:8px;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white,2px 2px 0 white,-2px -2px 0 white,2px -2px 0 white,-2px 2px 0 white;animation:bounce8bit 2s ease-in-out infinite;font-size:14px}.song-title-result{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:nowrap;font-weight:700;color:#f4a6d7;margin-bottom:8px;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:10px}.song-title-result .banana-emoji{flex:0 0 auto}#songTitleResult{flex:1 1 auto;min-width:0;text-align:center;white-space:normal;overflow-wrap:anywhere}.result-stats{margin-bottom:8px}.result-item{display:flex;justify-content:space-between;align-items:center;color:#2d2d2d;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;font-size:10px;margin:3px 0}.result-label{font-weight:700}.result-value{font-size:16px;color:#f4a6d7;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white}.result-message{font-size:16px;color:#2d2d2d;margin-bottom:8px;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white}.result-buttons{display:flex;flex-direction:column;gap:8px;width:100%}.result-buttons-row{display:flex;gap:6px;width:100%}.result-button{background:linear-gradient(45deg,#f4a6d7,#9adbe8);border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;font-family:"Press Start 2P",monospace;cursor:pointer;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;box-shadow:4px 4px #2d2d2d4d;transition:all .1s ease;font-size:10px;padding:8px 12px;margin:0;width:100%}.result-button.small-button{font-size:8px;padding:6px 8px;flex:1}.result-button:hover{transform:translate(2px,2px);box-shadow:2px 2px #2d2d2d4d}.result-button:active{transform:translate(4px,4px);box-shadow:none}#shareResultButton{background:linear-gradient(45deg,#e9df97,#f4a6d7)}#shareResultButton:hover{background:linear-gradient(45deg,#f4a6d7,#e9df97)}#shareResultButton:disabled{background:linear-gradient(45deg,#ccc,#aaa);color:#666;cursor:not-allowed;opacity:.6}.ranking-section{width:100%;margin-top:12px;display:flex;flex-direction:column;gap:12px}.ranking-submit{display:flex;flex-direction:column;gap:8px}.player-name-display{display:flex;flex-direction:column;gap:4px}.player-name-label{font-family:"Press Start 2P",monospace;font-size:8px;color:#2d2d2d;text-align:center}.player-name-input{font-family:"Press Start 2P",monospace;font-size:10px;padding:8px;border:3px solid #2d2d2d;border-radius:8px;background:#fff;text-align:center}.player-name-input:focus{outline:none;border-color:#e9df97;box-shadow:0 0 0 2px #e9df977f}.player-name-input:disabled,.player-name-input[readonly]{background:#f5f5f5;color:#666;cursor:default;opacity:.9}.submit-status{font-family:"Press Start 2P",monospace;font-size:9px;padding:10px;background:linear-gradient(45deg,#9adbe8,#f4a6d7);border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;text-align:center;box-shadow:4px 4px #2d2d2d4d;min-height:36px;display:flex;align-items:center;justify-content:center}.ranking-button{font-family:"Press Start 2P",monospace;font-size:10px;padding:10px;background:linear-gradient(45deg,#e9df97,#f4a6d7);border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;cursor:pointer;box-shadow:4px 4px #2d2d2d4d;transition:all .1s ease}.ranking-button:hover{transform:translate(2px,2px);box-shadow:2px 2px #2d2d2d4d}.ranking-button:active{transform:translate(4px,4px);box-shadow:none}.ranking-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.ranking-display{background:#fffc;border:3px solid #2d2d2d;border-radius:8px;padding:4px 8px;max-height:150px;display:flex;flex-direction:column}.ranking-title{font-family:"Press Start 2P",monospace;font-size:10px;color:#2d2d2d;margin-bottom:12px;text-align:center;flex-shrink:0}.ranking-list{font-family:"Press Start 2P",monospace;font-size:8px;color:#2d2d2d;text-align:left;max-height:190px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:#f4a6d7 #fff}.ranking-list::-webkit-scrollbar{width:8px}.ranking-list::-webkit-scrollbar-track{background:#fff;border-radius:4px}.ranking-list::-webkit-scrollbar-thumb{background:#f4a6d7;border-radius:4px;border:2px solid #fff}.ranking-list::-webkit-scrollbar-thumb:hover{background:#ff9ac7}.ranking-item{padding:6px 8px;margin:4px 0;background:#fff;border:2px solid #2d2d2d;border-radius:4px;display:grid;grid-template-columns:32px 1fr 65px;gap:6px;align-items:center;min-height:28px}.ranking-item.user-score{background:linear-gradient(45deg,#e9df97,#f4a6d7);border-color:#e9df97;font-weight:700}.ranking-rank{font-weight:700;text-align:center;font-size:9px}.ranking-rank.top1{color:gold;text-shadow:1px 1px 0 rgb(0 0 0 / 20%)}.ranking-rank.top2{color:silver;text-shadow:1px 1px 0 rgb(0 0 0 / 20%)}.ranking-rank.top3{color:#cd7f32;text-shadow:1px 1px 0 rgb(0 0 0 / 20%)}.ranking-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:#2d2d2d}.ranking-score{text-align:right;font-weight:700;color:#f4a6d7;font-size:9px}.ranking-item.user-score .ranking-score{color:#2d2d2d}.ranking-error{color:#ff6b6b;font-size:8px;text-align:center;padding:8px}.result-button.primary-button{background:linear-gradient(135deg,#f4a6d7,#9adbe8);font-weight:900;font-size:16px;border:4px solid #2d2d2d}.result-button.primary-button:hover{background:linear-gradient(135deg,#ff9ac7,#7ecde0);transform:scale(1.05)}.ranking-screen{background:linear-gradient(135deg,#9adbe8,#f4a6d7,#e9df97);padding:20px 8px;display:none;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.ranking-container{background:#fffffff2;border:4px solid #2d2d2d;border-radius:16px;padding:24px;text-align:center;max-width:400px;box-shadow:8px 8px #2d2d2d4d;width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}.ranking-header{width:100%;margin-bottom:8px}.ranking-title-main{font-weight:900;color:#2d2d2d;font-size:18px;margin-bottom:8px;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white;animation:bounce8bit 2s ease-in-out infinite}.song-title-ranking{font-size:10px;font-weight:700;color:#f4a6d7;margin-bottom:8px}.difficulty-ranking{font-size:10px;font-weight:900;color:#2d2d2d;margin-bottom:8px;padding:4px 8px;background:linear-gradient(45deg,#e9df97,#f4a6d7);border:2px solid #2d2d2d;border-radius:6px;display:inline-block;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;box-shadow:2px 2px #2d2d2d4d}.user-rank-display{font-size:14px;font-weight:700;color:#2d2d2d;margin-top:8px;padding:8px 12px;background:linear-gradient(45deg,#e9df97,#f4a6d7);border:3px solid #2d2d2d;border-radius:8px;text-shadow:1px 0 0 white,-1px 0 0 white,0 1px 0 white,0 -1px 0 white;animation:pulse 1.5s ease-in-out infinite}.user-rank-display .rank-row{display:flex;align-items:center;gap:4px;margin:2px 0}.user-rank-display .rank-row:first-child{margin-bottom:4px}.user-rank-display strong{font-size:16px;color:#ff6b9d}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ranking-buttons{display:flex;gap:8px;width:100%;margin-top:8px}.ranking-buttons .result-button{flex:1;font-size:10px;padding:8px 12px}.ranking-list-screen{background:linear-gradient(135deg,#e9df97,#f4a6d7,#9adbe8);padding:12px 8px;display:none;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;align-items:center;gap:12px}.ranking-list-container{background:#fffffff2;border:4px solid #2d2d2d;border-radius:16px;padding:16px;text-align:center;max-width:500px;width:100%;box-shadow:8px 8px #2d2d2d4d;display:flex;flex-direction:column;gap:12px}.ranking-list-header-section{display:flex;flex-direction:column;gap:8px;padding-bottom:12px;border-bottom:3px solid #2d2d2d}.ranking-list-title{font-weight:900;font-size:16px;color:#2d2d2d;text-shadow:2px 0 0 white,-2px 0 0 white,0 2px 0 white,0 -2px 0 white;animation:bounce8bit 2s ease-in-out infinite}.ranking-list-song-select-wrapper{display:flex;flex-direction:column;gap:6px}.ranking-list-song-label{font-size:11px;font-weight:700;color:#2d2d2d;text-align:left}.ranking-list-song-select{width:100%;padding:10px 12px;font-family:"Press Start 2P",monospace;font-size:10px;background:#fff;border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;cursor:pointer;box-shadow:4px 4px #2d2d2d33;transition:all .1s ease}.ranking-list-song-select:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #2d2d2d4d}.ranking-list-song-select:focus{outline:none;border-color:#f4a6d7}.ranking-list-difficulty-wrapper{display:flex;flex-direction:column;gap:6px}.ranking-list-difficulty-label{font-size:11px;font-weight:700;color:#2d2d2d;text-align:left}.ranking-list-difficulty-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.ranking-list-difficulty-btn{padding:8px 12px;font-family:"Press Start 2P",monospace;font-size:8px;background:#fff;border:3px solid #2d2d2d;border-radius:8px;color:#2d2d2d;cursor:pointer;box-shadow:3px 3px #2d2d2d33;transition:all .1s ease;flex:1;min-width:60px}.ranking-list-difficulty-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px #2d2d2d4d}.ranking-list-difficulty-btn.active{background:var(--difficulty-color, #f4a6d7);color:#fff;font-weight:700;transform:scale(1.05)}.ranking-list-display{min-height:200px;max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch;border:3px solid #2d2d2d;border-radius:8px;background:#fff;padding:8px}.ranking-list-loading{display:none;text-align:center;padding:40px 20px;font-size:12px;color:#2d2d2d;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.ranking-list-error{display:none;padding:12px;background:#ff6b9d;border:3px solid #2d2d2d;border-radius:8px;color:#fff;font-size:10px;font-weight:700;text-align:center}.ranking-list-header{display:grid;grid-template-columns:60px 2fr 90px 70px;gap:4px;padding:8px 4px;background:#e9df97;border-bottom:3px solid #2d2d2d;font-size:9px;font-weight:700;color:#2d2d2d;border-radius:4px 4px 0 0}.ranking-list-row{display:grid;grid-template-columns:60px 2fr 90px 70px;gap:4px;padding:8px 4px;border-bottom:2px solid #f0f0f0;font-size:9px;color:#2d2d2d;transition:background .2s ease}.ranking-list-row:hover{background:#e9df9733}.ranking-list-row:last-child{border-bottom:none}.ranking-list-row.rank-1{background:linear-gradient(90deg,#ffd70033,#ffd7000d);font-weight:700}.ranking-list-row.rank-2{background:linear-gradient(90deg,#c0c0c033,#c0c0c00d);font-weight:700}.ranking-list-row.rank-3{background:linear-gradient(90deg,#cd7f3233,#cd7f320d);font-weight:700}.rank-col{text-align:center;font-weight:700}.player-col{text-align:left;word-wrap:break-word;overflow-wrap:break-word;line-height:1.3}.score-col,.combo-col{text-align:right}.ranking-list-empty{padding:40px 20px;text-align:center;color:#2d2d2d}.empty-icon{font-size:48px;margin-bottom:16px}.empty-message{font-size:12px;font-weight:700;margin-bottom:8px}.empty-submessage{font-size:10px;opacity:.7}.ranking-list-back-button{width:100%;padding:12px 16px;font-family:"Press Start 2P",monospace;font-size:11px;background:#9adbe8;border:3px solid #2d2d2d;border-radius:12px;color:#2d2d2d;cursor:pointer;box-shadow:4px 4px #2d2d2d4d;transition:all .1s ease;font-weight:700}.ranking-list-back-button:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #2d2d2d66}.ranking-list-back-button:active{transform:translate(2px,2px);box-shadow:2px 2px #2d2d2d4d}@media (max-width: 375px){.ranking-list-container{padding:12px}.ranking-list-title{font-size:14px}.ranking-list-song-select{font-size:9px;padding:8px 10px}.ranking-list-difficulty-btn{font-size:7px;padding:6px 8px;min-width:50px}.ranking-list-header,.ranking-list-row{grid-template-columns:50px 2fr 80px 60px;font-size:8px}}
