.character-silhouette{display:inline-block;color:#ffffff4d;transition:all .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.character-silhouette svg{width:100%;height:100%;display:block}.character-silhouette--small{width:40px;height:40px}.character-silhouette--medium{width:60px;height:60px}.character-silhouette--large{width:80px;height:80px}.character-silhouette--xlarge{width:180px;height:180px}.character-silhouette--xxlarge{width:220px;height:220px}.character-silhouette--background{position:absolute;color:#ffffff1a;pointer-events:none;z-index:1;animation:silhouetteFadeWithRhythm 3s ease-in-out}.character-silhouette--background.character-silhouette--image img{opacity:1}.character-silhouette--popup{color:#ffffffe6;animation:silhouettePopup 3s ease-in-out forwards}@keyframes silhouetteFade{0%{opacity:0;transform:scale(.8)}20%{opacity:1;transform:scale(1)}80%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes silhouetteFadeWithRhythm{0%{opacity:0;transform:scale(.7)}10%{opacity:.9;transform:scale(1)}20%{opacity:.9;transform:scale(1.05)}30%{opacity:.9;transform:scale(1)}40%{opacity:.9;transform:scale(1.03)}50%{opacity:.9;transform:scale(1)}60%{opacity:.9;transform:scale(1.02)}70%{opacity:.9;transform:scale(1)}80%{opacity:.9;transform:scale(1.01)}90%{opacity:.7;transform:scale(.95)}to{opacity:0;transform:scale(.8)}}@keyframes silhouettePopup{0%{opacity:0;transform:scale(.5) translateY(10px)}15%{opacity:1;transform:scale(1) translateY(0)}85%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.8) translateY(-5px)}}.character-silhouette[data-character=初音ミク]{color:#39c5bb66}.character-silhouette[data-character=鏡音リン],.character-silhouette[data-character=鏡音レン]{color:#ffd60066}.character-silhouette[data-character=巡音ルカ]{color:#f696}.character-silhouette[data-character=MEIKO]{color:#dc354566}.character-silhouette[data-character=KAITO]{color:#007bff66}.character-silhouette:not(.character-silhouette--background):hover{color:#fffc;transform:scale(1.05);filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}.character-silhouette--image{overflow:hidden;border-radius:10%}.character-silhouette--image img{transition:all .3s ease}.character-silhouette--image:hover img{transform:scale(1.05)}@media (max-width: 768px){.character-silhouette--small{width:30px;height:30px}.character-silhouette--medium{width:45px;height:45px}.character-silhouette--large{width:60px;height:60px}.character-silhouette--xlarge{width:120px;height:120px}.character-silhouette--xxlarge{width:150px;height:150px}}.retro-collection-board{position:fixed;top:20px;right:20px;min-width:280px;max-width:320px;max-height:calc(100vh - 40px);z-index:1000;transition:all .3s ease}.retro-collection-signboard{background:linear-gradient(145deg,#2a2a3e,#1f1f2e);border:4px solid #4a9eff;border-radius:15px;box-shadow:0 0 25px #4a9eff4d,inset 0 2px 4px #ffffff1a;padding:6px}.retro-collection-border{background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:2px solid #6bb6ff;border-radius:10px;padding:15px;position:relative;overflow:hidden}.retro-collection-border:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#4a9eff,#6bb6ff,#4a9eff);border-radius:10px;z-index:-1;animation:collection-border-glow 3s ease-in-out infinite alternate}@keyframes collection-border-glow{0%{opacity:.5}to{opacity:1}}.retro-collection-board.collapsed{max-height:auto;overflow:visible}.retro-collection-board.expanded{max-height:calc(100vh - 40px);overflow:visible}.collection-header{cursor:pointer;-webkit-user-select:none;user-select:none}.retro-collection-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:900;color:gold;text-align:center;margin-bottom:4px;text-shadow:1px 1px 0px #ff6b6b,2px 2px 0px #4ecdc4,3px 3px 6px rgba(0,0,0,.3);letter-spacing:1px;text-transform:uppercase;animation:collection-title-glow 2s ease-in-out infinite alternate}@keyframes collection-title-glow{0%{text-shadow:1px 1px 0px #ff6b6b,2px 2px 0px #4ecdc4,3px 3px 6px rgba(0,0,0,.3);color:gold}to{text-shadow:1px 1px 0px #ff8e8e,2px 2px 0px #6ee8e8,3px 3px 12px rgba(0,0,0,.5);color:#ffeb3b}}.retro-collection-subtitle{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:12px;font-weight:700;color:#a0c4ff;text-align:center;margin-bottom:12px;letter-spacing:1px}.header-controls{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.collection-count{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:gold;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.retro-toggle-button{background:linear-gradient(145deg,#ff6b6b,#ff5252);border:2px solid #ffd700;border-radius:8px;padding:6px 8px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ff6b6b4d,inset 0 1px 2px #fff3}.retro-toggle-button:hover{background:linear-gradient(145deg,#ff5252,#ff3030);transform:translateY(-1px);box-shadow:0 3px 12px #ff6b6b66,inset 0 1px 2px #ffffff4d}.retro-hamburger-icon{display:flex;flex-direction:column;gap:2px}.retro-hamburger-icon span{width:12px;height:2px;background:#fff;border-radius:1px;transition:all .3s ease}.retro-collection-items{max-height:calc(100vh - 220px);overflow-y:auto;margin-top:15px;padding-top:10px;border-top:2px solid #6bb6ff}.retro-empty-message{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#a0c4ff;text-align:center;padding:20px 10px;background:#4a9eff1a;border:1px solid #4a9eff;border-radius:8px;letter-spacing:.5px}.retro-collection-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:8px;background:#4a9eff1a;border:1px solid #4a9eff;border-radius:8px;transition:all .3s ease;animation:retro-item-slideIn .5s ease-out}@keyframes retro-item-slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.retro-collection-item:hover{background:#4a9eff33;transform:translate(3px);border-color:#6bb6ff}.retro-item-icon{flex-shrink:0;animation:retro-star-sparkle 2s ease-in-out infinite}@keyframes retro-star-sparkle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(5deg)}}.retro-item-info{flex:1;min-width:0}.retro-item-name{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.retro-item-composer{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:11px;font-weight:700;color:#a0c4ff;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.retro-item-time{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:10px;color:#888;font-weight:700}.retro-collection-items::-webkit-scrollbar{width:6px}.retro-collection-items::-webkit-scrollbar-track{background:#1a1a2ecc;border-radius:3px}.retro-collection-items::-webkit-scrollbar-thumb{background:#4a9eff;border-radius:3px}.retro-collection-items::-webkit-scrollbar-thumb:hover{background:#6bb6ff}@media (max-width: 768px){.retro-collection-board{top:15px;right:15px;min-width:240px;max-width:280px;max-height:calc(100vh - 30px)}.retro-collection-items{max-height:calc(100vh - 180px)}.retro-collection-title{font-size:16px}.retro-collection-subtitle{font-size:11px}.retro-collection-item{padding:6px 8px}.retro-item-name{font-size:12px}.retro-item-composer{font-size:10px}}@media (max-width: 480px){.retro-collection-board{top:15px;right:10px;min-width:220px;max-width:260px;max-height:calc(100vh - 30px)}.retro-collection-title{font-size:14px}.retro-collection-items{max-height:calc(100vh - 160px)}}@media (max-width: 768px) and (orientation: landscape){.retro-collection-board{max-width:250px;max-height:calc(100vh - 30px)}.retro-collection-items{max-height:calc(100vh - 150px)}}@media (max-height: 600px){.retro-collection-board{top:10px;max-height:calc(100vh - 20px)}.retro-collection-items{max-height:calc(100vh - 140px)}.retro-collection-signboard{padding:4px}.retro-collection-border{padding:10px}.retro-collection-title{font-size:14px;margin-bottom:2px}.retro-collection-subtitle{font-size:10px;margin-bottom:8px}}.song-popup{position:fixed;top:20px;left:20px;max-width:400px;width:auto;background:linear-gradient(145deg,#2a2a3e,#1f1f2e);border:4px solid #4a9eff;border-radius:20px;box-shadow:0 0 30px #4a9eff66,inset 0 2px 4px #ffffff1a,0 8px 32px #0009;z-index:1500;color:#fff;overflow:hidden;opacity:0;transform:translate(-100%) translateY(-20px) scale(.8);transition:all .5s cubic-bezier(.34,1.56,.64,1);pointer-events:none;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace}.song-popup--visible{opacity:1;transform:translate(0) translateY(0) scale(1);pointer-events:auto;animation:retroPopupGlow .8s ease-out}.song-popup__content{padding:8px;position:relative;background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:2px solid #6bb6ff;border-radius:15px;margin:8px}.song-popup__content:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#4a9eff,#6bb6ff,#4a9eff);border-radius:15px;z-index:-1;animation:retro-border-glow 3s ease-in-out infinite alternate}.song-popup__content:after{content:"♪";position:absolute;top:8px;right:12px;font-size:18px;color:gold;text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4;animation:retroStarTwinkle 2s infinite ease-in-out}.song-popup__header{margin-bottom:12px;position:relative;padding:15px}.song-popup__title{margin:0 0 6px;font-size:18px;font-weight:900;color:gold;text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3);line-height:1.2;letter-spacing:2px;animation:retroTitleGlow 2s ease-in-out infinite alternate;text-align:left;text-transform:uppercase;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace}.song-popup__composer{margin:0;font-size:14px;color:#a0c4ff;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.5);text-align:right;letter-spacing:1px;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace}.song-popup__phrase{margin:12px 0;padding:8px 12px;background:#ffffff0d;border-left:3px solid #00d4ff;border-radius:6px;font-style:italic;font-size:13px;line-height:1.4;color:#ffffffe6}.song-popup__characters{display:flex;align-items:center;gap:8px;margin-top:12px}.song-popup__character-icon{opacity:.8;transition:opacity .2s ease}.song-popup__character-icon:hover{opacity:1}.song-popup__progress{height:6px;background:#1a1a2ecc;border:1px solid #6bb6ff;overflow:hidden;border-radius:0 0 16px 16px;position:relative;margin:0 6px 6px}.song-popup__progress:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(74,158,255,.4),transparent);animation:retroProgressShimmer 2.5s infinite}.song-popup__progress-bar{height:100%;background:linear-gradient(90deg,#4a9eff,#6bb6ff,#4a9eff);width:0;animation:progressFill linear forwards;box-shadow:0 0 10px #4a9effb3;position:relative}.song-popup__progress-bar:after{content:"";position:absolute;top:0;right:0;width:3px;height:100%;background:gold;box-shadow:0 0 6px gold}@keyframes progressFill{0%{width:0%}to{width:100%}}@keyframes retroPopupGlow{0%{box-shadow:0 0 30px #4a9eff66,inset 0 2px 4px #ffffff1a,0 8px 32px #0009}50%{box-shadow:0 0 50px #4a9effb3,inset 0 2px 4px #fff3,0 8px 32px #0009}to{box-shadow:0 0 30px #4a9eff66,inset 0 2px 4px #ffffff1a,0 8px 32px #0009}}@keyframes retro-border-glow{0%{opacity:.5}to{opacity:1}}@keyframes retroStarTwinkle{0%,to{opacity:.7;transform:scale(1) rotate(0);text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4}50%{opacity:1;transform:scale(1.3) rotate(180deg);text-shadow:2px 2px 0px #ff8e8e,4px 4px 0px #6ee8e8,6px 6px 10px rgba(255,215,0,.8)}}@keyframes retroTitleGlow{0%{text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3);color:gold}to{text-shadow:2px 2px 0px #ff8e8e,4px 4px 0px #6ee8e8,6px 6px 20px rgba(0,0,0,.5);color:#ffed4e}}@keyframes retroProgressShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 768px){.song-popup{top:16px;left:16px;right:16px;max-width:none;width:auto}.song-popup__title{font-size:16px;letter-spacing:1.5px}.song-popup__composer{font-size:12px}.song-popup__phrase{font-size:11px;padding:6px 10px}.song-popup__header{padding:12px}.song-popup__content:after{font-size:16px;top:6px;right:10px}}@media (max-height: 600px){.song-popup{top:10px}.song-popup__header{padding:10px;margin-bottom:8px}.song-popup__phrase{margin:6px 0;padding:4px 8px}}@media (prefers-reduced-motion: reduce){.song-popup{transition:opacity .3s ease}.song-popup--visible{transform:none;animation:none}.song-popup__content:before,.song-popup__content:after,.song-popup__title{animation:none}.song-popup__progress:before{animation:none}}.ending-screen{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);z-index:2000;overflow-y:auto;padding:20px;box-sizing:border-box}.ending-signboard{position:relative;background:linear-gradient(145deg,#2a2a3e,#1f1f2e);border:4px solid #4a9eff;border-radius:20px;box-shadow:0 0 30px #4a9eff4d,inset 0 2px 4px #ffffff1a;padding:8px;max-width:900px;width:95%;max-height:90vh;overflow-y:auto}.ending-border{background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:2px solid #6bb6ff;border-radius:15px;padding:30px;position:relative;overflow:visible}.ending-border:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#4a9eff,#6bb6ff,#4a9eff);border-radius:15px;z-index:-1;animation:ending-border-glow 3s ease-in-out infinite alternate}@keyframes ending-border-glow{0%{opacity:.5}to{opacity:1}}.ending-header{text-align:center;margin-bottom:25px}.ending-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:32px;font-weight:900;color:gold;text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3);letter-spacing:3px;text-transform:uppercase;animation:ending-title-glow 2s ease-in-out infinite alternate;margin-bottom:10px}@keyframes ending-title-glow{0%{text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3);color:gold}to{text-shadow:2px 2px 0px #ff8e8e,4px 4px 0px #6ee8e8,6px 6px 20px rgba(0,0,0,.5);color:#ffeb3b}}.ending-subtitle{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:700;color:#a0c4ff;letter-spacing:2px}.ending-characters{display:flex;flex-direction:column;align-items:center;margin-bottom:25px;background:linear-gradient(145deg,#4a9eff1a,#6bb6ff1a);border:2px solid rgba(74,158,255,.3);border-radius:15px;padding:20px;box-shadow:0 4px 15px #4a9eff33}.characters-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:16px;font-weight:900;color:gold;text-transform:uppercase;letter-spacing:1px;margin-bottom:15px;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.characters-row{display:flex;gap:15px;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:10px}.ending-character-display{filter:drop-shadow(0 0 8px rgba(255,255,255,.4));transition:transform .3s ease;animation:character-gentle-float 3s ease-in-out infinite}.ending-character-display:hover{transform:scale(1.1)}.ending-character-display:nth-child(2n){animation-delay:.5s}.ending-character-display:nth-child(3n){animation-delay:1s}@keyframes character-gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.characters-count{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:12px;font-weight:700;color:#a0c4ff;text-transform:uppercase;letter-spacing:.5px;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.song-gallery{margin-bottom:30px}.gallery-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:20px;font-weight:900;color:gold;text-align:center;margin-bottom:20px;text-shadow:1px 1px 2px rgba(0,0,0,.5);letter-spacing:1px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;padding:10px;max-height:400px;overflow-y:auto}.song-card{background:linear-gradient(145deg,#1a1a2ee6,#0f0f1ae6);border:2px solid #6bb6ff;border-radius:12px;padding:15px;transition:all .3s ease;display:flex;flex-direction:column;justify-content:space-between;min-height:180px}.song-card:hover{transform:translateY(-3px);border-color:#4a9eff;box-shadow:0 8px 25px #4a9eff66}.song-card-content{flex:1;display:flex;flex-direction:column;align-items:center}.song-icon{font-size:28px;text-align:center;margin-bottom:10px;animation:song-icon-rotate 3s ease-in-out infinite}@keyframes song-icon-rotate{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.character-icons{display:flex;gap:5px;justify-content:center;align-items:center;flex-wrap:wrap}.ending-character-icon{filter:drop-shadow(0 0 5px rgba(255,255,255,.3));transition:transform .3s ease}.ending-character-icon:hover{transform:scale(1.1)}.song-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;text-align:center;line-height:1.3}.song-composer{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:12px;font-weight:700;color:#a0c4ff;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;text-align:center}.song-time{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:10px;color:#888;font-weight:700;text-align:center}.song-link-button{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:1px;text-shadow:1px 1px 2px rgba(0,0,0,.5);background:linear-gradient(145deg,#4a9eff,#6bb6ff);border:2px solid #ffffff;border-radius:8px;padding:8px 16px;cursor:pointer;transition:all .3s ease;margin-top:10px;box-shadow:0 2px 8px #4a9eff4d}.song-link-button:hover{background:linear-gradient(145deg,#6bb6ff,#4a9eff);transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff80}.song-link-button:active{transform:translateY(0);box-shadow:0 2px 6px #4a9eff66}.ending-actions{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:20px}.ending-button{position:relative;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:900;color:#fff;border:3px solid #ffd700;border-radius:12px;padding:15px 30px;cursor:pointer;transition:all .3s ease;overflow:hidden;text-transform:uppercase;letter-spacing:2px;min-width:160px}.restart-button{background:linear-gradient(145deg,#4ecdc4,#45b7aa)}.restart-button:hover{background:linear-gradient(145deg,#45b7aa,#3da58f);transform:translateY(-2px);box-shadow:0 6px 20px #4ecdc466}.share-button{background:linear-gradient(145deg,#ff6b6b,#ff5252)}.share-button:hover{background:linear-gradient(145deg,#ff5252,#ff3030);transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.button-glow{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(255,215,0,.3) 0%,transparent 70%);animation:ending-button-pulse 2s ease-in-out infinite alternate;border-radius:9px}@keyframes ending-button-pulse{0%{opacity:.5}to{opacity:1}}@media (max-width: 768px){.ending-signboard{width:98%}.ending-title{font-size:24px}.ending-subtitle{font-size:14px}.ending-stats{flex-direction:column;align-items:center;gap:20px}.gallery-grid{grid-template-columns:1fr;gap:15px;max-height:350px}.ending-actions{flex-direction:column;align-items:center;gap:20px}.ending-button{width:100%;max-width:300px}}@media (max-width: 480px){.ending-signboard{width:98%}.ending-border{padding:20px}.ending-title{font-size:20px}.gallery-grid{max-height:300px;grid-template-columns:1fr;gap:12px}.song-card{padding:12px}}.ending-signboard::-webkit-scrollbar,.gallery-grid::-webkit-scrollbar{width:8px}.ending-signboard::-webkit-scrollbar-track,.gallery-grid::-webkit-scrollbar-track{background:#1a1a2ecc;border-radius:4px}.ending-signboard::-webkit-scrollbar-thumb,.gallery-grid::-webkit-scrollbar-thumb{background:#4a9eff;border-radius:4px}.ending-signboard::-webkit-scrollbar-thumb:hover,.gallery-grid::-webkit-scrollbar-thumb:hover{background:#6bb6ff}.share-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:3000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.share-modal{background:linear-gradient(145deg,#2a2a3e,#1f1f2e);border:3px solid #4a9eff;border-radius:20px;box-shadow:0 0 30px #4a9eff66,inset 0 2px 4px #ffffff1a;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;animation:modal-appear .3s ease-out}@keyframes modal-appear{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:2px solid rgba(74,158,255,.3)}.share-modal-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:900;color:gold;margin:0;text-shadow:1px 1px 2px rgba(0,0,0,.5);letter-spacing:1px}.share-modal-close{background:none;border:2px solid #ff6b6b;color:#ff6b6b;font-size:18px;font-weight:700;width:35px;height:35px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.share-modal-close:hover{background:#ff6b6b;color:#fff;transform:scale(1.1)}.share-modal-content{padding:20px 25px}.no-songs-message{text-align:center;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:16px;color:#a0c4ff;padding:40px 20px}.songs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;max-height:300px;overflow-y:auto;padding:10px}.song-share-card{background:linear-gradient(145deg,#1a1a2ee6,#0f0f1ae6);border:2px solid #6bb6ff;border-radius:12px;padding:15px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;position:relative;min-height:120px}.song-share-card:hover{transform:translateY(-2px);border-color:#4a9eff;box-shadow:0 8px 25px #4a9eff66}.song-share-card.selected{border-color:gold;background:linear-gradient(145deg,#ffd7001a,#ffd7000d);box-shadow:0 0 20px #ffd7004d}.song-share-characters{display:flex;gap:5px;margin-bottom:10px;justify-content:center;flex-wrap:wrap}.share-character-icon{filter:drop-shadow(0 0 5px rgba(255,255,255,.3))}.song-share-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:12px;font-weight:700;color:#fff;text-align:center;margin-bottom:5px;line-height:1.3}.song-share-composer{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:10px;color:#a0c4ff;text-align:center;font-weight:700}.selection-indicator{position:absolute;top:5px;right:5px;background:gold;color:#000;font-size:12px;font-weight:700;padding:2px 6px;border-radius:10px;animation:selection-pulse 1s ease-in-out infinite}@keyframes selection-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.share-preview{margin:20px 25px;padding:15px;background:linear-gradient(145deg,#4a9eff1a,#6bb6ff1a);border:2px solid rgba(74,158,255,.3);border-radius:12px}.share-preview-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:gold;margin:0 0 10px}.share-preview-content{display:flex;flex-direction:column;align-items:center;gap:10px}.share-preview-text{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:12px;color:#fff;text-align:center;line-height:1.4}.share-preview-characters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.share-preview-character{filter:drop-shadow(0 0 8px rgba(255,255,255,.4));animation:character-gentle-float 3s ease-in-out infinite}.share-modal-actions{display:flex;gap:15px;padding:20px 25px;border-top:2px solid rgba(74,158,255,.3);justify-content:flex-end}.share-cancel-button{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#a0c4ff;background:transparent;border:2px solid #a0c4ff;border-radius:8px;padding:12px 20px;cursor:pointer;transition:all .3s ease}.share-cancel-button:hover{background:#a0c4ff;color:#1a1a2e}.share-confirm-button{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(145deg,#4a9eff,#6bb6ff);border:2px solid #ffffff;border-radius:8px;padding:12px 20px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.share-confirm-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #4a9eff66}.share-confirm-button:disabled{opacity:.5;cursor:not-allowed;background:#666}.share-confirm-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.share-confirm-button:hover:not(:disabled):before{left:100%}.share-image-button{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(145deg,#ff6b6b,#ff8e8e);border:2px solid #ffffff;border-radius:8px;padding:12px 20px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.share-image-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66}.share-image-button:disabled{opacity:.7;cursor:not-allowed;background:#666}.share-image-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.share-image-button:hover:not(:disabled):before{left:100%}@media (max-width: 768px){.share-modal{width:95%;max-height:90vh}.songs-grid{grid-template-columns:1fr;max-height:250px}.share-modal-actions{flex-direction:column}.share-cancel-button,.share-image-button,.share-confirm-button{width:100%}}.star-canvas{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;background-color:#000;margin:0;padding:0;display:block;box-sizing:border-box}.star-canvas canvas{display:block;width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain;touch-action:manipulation}@media (max-width: 768px){.star-canvas{height:100vh;height:100dvh}.star-canvas canvas{touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}}@media (max-width: 480px){.star-canvas{will-change:transform}}@media (max-width: 768px) and (orientation: landscape){.star-canvas{height:100vh;height:100dvh}}.star-canvas-textalive{position:fixed;top:0;left:0;width:100vw;height:100vh;overflow:hidden;margin:0;padding:0;box-sizing:border-box}.star-canvas-container{position:relative;width:100%;height:100%;margin:0;padding:0}.character-ending{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1000;pointer-events:none}.ending-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;transition:background 2s ease-in-out}.character-ending.thankyou .ending-overlay{background:#00000080}.ending-characters-display{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:80px;width:90vw;height:80vh;z-index:10}.character-ending.thankyou .ending-characters-display{z-index:5;opacity:.6}.ending-character-container{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.ending-character-silhouette{opacity:0;transform:scale(.8);animation:characterFadeIn 1.5s ease-out forwards}.ending-character-silhouette.visible{opacity:.9;transform:scale(1) translateY(0);animation:none}.character-stars{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.character-star{position:absolute;opacity:0;animation:starFloat 2s ease-out forwards;display:flex;justify-content:center;align-items:center}.character-svg-star{filter:drop-shadow(0 0 6px rgba(255,255,255,.4))}.character-star.visible .character-svg-star{filter:drop-shadow(0 0 8px rgba(255,255,255,.6))}.character-star:nth-child(1){top:10%;right:10%}.character-star:nth-child(2){bottom:20%;left:15%}.character-star:nth-child(3){top:30%;left:5%}.character-star.visible{opacity:1}.character-star.visible .character-svg-star{animation:starGlowScale 2s ease-in-out infinite alternate}@keyframes characterFadeIn{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:.9;transform:scale(1) translateY(0)}}.thank-you-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);animation:thankYouFadeIn 1s ease-out forwards;z-index:20;width:auto;height:auto;display:flex;justify-content:center;align-items:center}.ending-signboard{animation:retro-glow 2s ease-in-out infinite alternate;position:relative;max-width:500px;width:auto}.ending-thank-you{font-family:Courier New,monospace;font-size:4rem;font-weight:700;color:#0ff;text-align:center;text-shadow:0 0 20px #00ffff,0 0 40px #00ffff;margin-bottom:20px}.ending-for-playing{font-family:Courier New,monospace;font-size:2rem;font-weight:700;color:#f0f;text-align:center;text-shadow:0 0 15px #ff00ff,0 0 30px #ff00ff}@keyframes thankYouFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes retro-glow{0%{filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}to{filter:drop-shadow(0 0 20px rgba(255,255,255,.8))}}@keyframes starFloat{0%{opacity:0;transform:translateY(20px) scale(.5)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes starGlow{0%{text-shadow:0 0 10px rgba(255,215,0,.8);transform:scale(1)}to{text-shadow:0 0 20px rgba(255,215,0,1),0 0 30px rgba(255,255,255,.5);transform:scale(1.1)}}@keyframes starGlowScale{0%{transform:scale(1)}to{transform:scale(1.1)}}.overlay-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;text-shadow:0 0 10px rgba(255,255,255,.7);z-index:10}.title{font-size:3rem;margin-bottom:1rem;font-weight:700}.subtitle{font-size:1.5rem;opacity:.8;margin-bottom:2rem}.current-lyric{font-size:2rem;max-width:80vw;transition:all .5s ease;white-space:pre-wrap;word-break:keep-all}.chorus-lyric{font-size:2.5rem;color:#ff0;text-shadow:0 0 15px rgba(255,255,0,.7)}.finale-lyric{font-size:2.2rem;color:#ff69b4;text-shadow:0 0 20px rgba(255,105,180,.8);animation:finale-glow 2s infinite alternate}.retro-startup-screen{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);z-index:1000}.star-tap-highlight{background:linear-gradient(45deg,#ff6b6b33,#4ecdc433)!important;border:2px solid #ffd700!important;border-radius:10px!important;padding:10px!important;display:flex!important;align-items:center!important;gap:8px!important;animation:tap-highlight-glow 2s ease-in-out infinite alternate;transform:scale(1.05)}.tap-icon{font-size:18px;animation:tap-bounce 1.5s ease-in-out infinite}.star-icon{font-size:20px;animation:star-sparkle 2s ease-in-out infinite}.rule-text{font-weight:900!important;color:gold!important;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.tap-demo{margin-top:20px;padding:15px;background:#ffd7001a;border:2px dashed #ffd700;border-radius:12px;text-align:center;position:relative;overflow:hidden}.demo-star{font-size:32px;position:absolute;left:20%;top:50%;transform:translateY(-50%);animation:demo-star-move 3s linear infinite}.demo-finger{font-size:24px;position:absolute;right:30%;top:30%;animation:demo-finger-tap 3s ease-in-out infinite}.demo-text{font-family:Courier New,monospace;font-size:14px;font-weight:700;color:gold;text-shadow:1px 1px 2px rgba(0,0,0,.8);margin-top:10px;animation:demo-text-pulse 2s ease-in-out infinite alternate}@keyframes tap-highlight-glow{0%{box-shadow:0 0 10px #ffd70080}to{box-shadow:0 0 20px #ffd700cc,0 0 30px #ffd70066}}@keyframes tap-bounce{0%,50%,to{transform:translateY(0)}25%{transform:translateY(-5px)}75%{transform:translateY(-2px)}}@keyframes star-sparkle{0%,to{transform:scale(1) rotate(0);filter:brightness(1)}50%{transform:scale(1.2) rotate(180deg);filter:brightness(1.5)}}@keyframes demo-star-move{0%{left:-10%;opacity:0}10%{opacity:1}50%{left:50%;opacity:1}60%{opacity:.5;transform:translateY(-50%) scale(1.2)}70%{opacity:0;transform:translateY(-50%) scale(1.5)}to{left:110%;opacity:0}}@keyframes demo-finger-tap{0%,40%,to{transform:scale(1);opacity:.7}50%,70%{transform:scale(1.3);opacity:1}}@keyframes demo-text-pulse{0%{opacity:.8}to{opacity:1;text-shadow:1px 1px 2px rgba(0,0,0,.8),0 0 10px rgba(255,215,0,.6)}}.retro-signboard{position:relative;background:linear-gradient(145deg,#2a2a3e,#1f1f2e);border:4px solid #4a9eff;border-radius:20px;box-shadow:0 0 30px #4a9eff4d,inset 0 2px 4px #ffffff1a;padding:8px;max-width:480px;width:90%}.retro-border{background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:2px solid #6bb6ff;border-radius:15px;padding:30px;position:relative;overflow:hidden}.retro-border:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#4a9eff,#6bb6ff,#4a9eff);border-radius:15px;z-index:-1;animation:border-glow 3s ease-in-out infinite alternate}@keyframes border-glow{0%{opacity:.5}to{opacity:1}}.game-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:28px;font-weight:900;color:gold;text-align:center;margin-bottom:8px;text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3);letter-spacing:3px;text-transform:uppercase;animation:title-glow 2s ease-in-out infinite alternate}@keyframes title-glow{0%{text-shadow:2px 2px 0px #ff6b6b,4px 4px 0px #4ecdc4,6px 6px 10px rgba(0,0,0,.3)}to{text-shadow:2px 2px 0px #ff8e8e,4px 4px 0px #6ee8e8,6px 6px 20px rgba(0,0,0,.5)}}.game-subtitle{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:16px;font-weight:700;color:#a0c4ff;text-align:center;margin-bottom:25px;letter-spacing:2px}.rules-section{background:#1a1a2ecc;border:2px solid #6bb6ff;border-radius:12px;padding:20px;margin-bottom:25px;position:relative}.rules-title{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:900;color:gold;text-align:center;margin-bottom:15px;text-shadow:1px 1px 2px rgba(0,0,0,.5);letter-spacing:1px}.rules-list{display:flex;flex-direction:column;gap:8px}.rule-item{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:14px;font-weight:700;color:#fff;padding:6px 12px;background:#4a9eff1a;border-left:3px solid #4a9eff;border-radius:6px;transition:all .3s ease;letter-spacing:.5px}.rule-item:hover{background:#4a9eff33;transform:translate(5px)}.retro-loading{text-align:center;margin-top:20px}.loading-text{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:700;color:#a0c4ff;display:inline-block;margin-right:10px;letter-spacing:1px}.loading-dots{display:inline-block}.loading-dots span{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:18px;font-weight:700;color:#a0c4ff;animation:loading-dot 1.5s infinite}.loading-dots span:nth-child(2){animation-delay:.3s}.loading-dots span:nth-child(3){animation-delay:.6s}@keyframes loading-dot{0%,60%,to{opacity:.3}30%{opacity:1}}.retro-start-button{position:relative;font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:20px;font-weight:900;color:#fff;background:linear-gradient(145deg,#ff6b6b,#ff5252);border:3px solid #ffd700;border-radius:12px;padding:15px 40px;cursor:pointer;transition:all .3s ease;overflow:hidden;width:100%;text-align:center;letter-spacing:2px;text-transform:uppercase;box-shadow:0 4px 15px #ff6b6b4d,inset 0 2px 4px #fff3}.retro-start-button:hover{background:linear-gradient(145deg,#ff5252,#ff3030);transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66,inset 0 2px 4px #ffffff4d}.retro-start-button:active{transform:translateY(0);box-shadow:0 2px 10px #ff6b6b4d,inset 0 2px 4px #0003}.button-text{position:relative;z-index:2;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.button-glow{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(255,215,0,.3) 0%,transparent 70%);animation:button-pulse 2s ease-in-out infinite alternate;border-radius:9px}@keyframes button-pulse{0%{opacity:.5}to{opacity:1}}.retro-lyric-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:15;max-width:90vw;width:100%;display:flex;justify-content:center;align-items:center}.ripple-effect{position:absolute;width:100%;height:100%;pointer-events:none;z-index:-1;will-change:transform;transform:translateZ(0)}.ripple-wave-1{position:absolute;top:50%;left:50%;border:3px solid rgba(255,255,255,.4);border-radius:50%;transform:translate3d(-50%,-50%,0);pointer-events:none;will-change:width,height,opacity}.retro-lyric-container.chorus-mode:before{opacity:0!important;display:none}.retro-lyric-container.chorus-mode:after{opacity:0!important;display:none}.ripple-normal .ripple-wave-1{width:0;height:0;animation:ripple-wave 3s ease-out forwards;box-shadow:0 0 10px #ffffff4d;opacity:0}.ripple-chorus .ripple-wave-1{width:0;height:0;border:3px solid;border-image:linear-gradient(90deg,#96ceb4,#ffd93d,#ff6b6b) 1;animation:ripple-wave-chorus 4s ease-out forwards;box-shadow:0 0 20px #96ceb466;opacity:0}.retro-lyric-container:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border:4px solid rgba(255,255,255,.6);border-radius:50%;transform:translate(-50%,-50%);animation:ripple-wave 3s ease-out infinite;animation-play-state:var(--ripple-animation, paused);z-index:-1;pointer-events:none;box-shadow:0 0 20px #fff6,inset 0 0 20px #fff3;opacity:0}.retro-lyric-container:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border:3px solid rgba(255,255,255,.5);border-radius:50%;transform:translate(-50%,-50%);animation:ripple-wave 3s ease-out infinite 1s;animation-play-state:var(--ripple-animation, paused);z-index:-1;pointer-events:none;box-shadow:0 0 15px #ffffff4d,inset 0 0 15px #ffffff26;opacity:0}@keyframes ripple-wave{0%{width:0;height:0;opacity:1;border-width:6px;transform:translate3d(-50%,-50%,0)}15%{opacity:.9;border-width:5px;transform:translate3d(-50%,-50%,0)}30%{opacity:.8;border-width:4px;transform:translate3d(-50%,-50%,0)}50%{opacity:.6;border-width:3px;transform:translate3d(-50%,-50%,0)}70%{opacity:.4;border-width:2px;transform:translate3d(-50%,-50%,0)}85%{opacity:.3;border-width:2px;transform:translate3d(-50%,-50%,0)}to{width:120vmax;height:120vmax;opacity:.2;border-width:1px;transform:translate3d(-50%,-50%,0)}}@keyframes ripple-wave-chorus{0%{width:0;height:0;opacity:1;border-width:8px;transform:translate3d(-50%,-50%,0) scale(1) rotate(0)}15%{opacity:.9;border-width:6px;transform:translate3d(-50%,-50%,0) scale(1.1) rotate(54deg)}30%{opacity:.8;border-width:4px;transform:translate3d(-50%,-50%,0) scale(1.2) rotate(108deg)}50%{opacity:.6;border-width:3px;transform:translate3d(-50%,-50%,0) scale(1.15) rotate(180deg)}70%{opacity:.4;border-width:2px;transform:translate3d(-50%,-50%,0) scale(1.1) rotate(252deg)}85%{opacity:.3;border-width:2px;transform:translate3d(-50%,-50%,0) scale(1.05) rotate(306deg)}to{width:150vmax;height:150vmax;opacity:.2;border-width:1px;transform:translate3d(-50%,-50%,0) scale(1) rotate(360deg)}}.retro-lyric{font-family:Courier New,Consolas,Monaco,Lucida Console,monospace;font-size:2rem;font-weight:900;color:#fff;text-align:center;text-shadow:2px 2px 0px rgba(255,107,107,.8),4px 4px 0px rgba(78,205,196,.8),6px 6px 10px rgba(0,0,0,.5);letter-spacing:3px;white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word;text-transform:uppercase;animation:lyric-title-glow 2s ease-in-out infinite alternate;max-width:100%;box-sizing:border-box;padding:0 10px}@keyframes lyric-title-glow{0%{text-shadow:2px 2px 0px rgba(255,107,107,.8),4px 4px 0px rgba(78,205,196,.8),6px 6px 10px rgba(0,0,0,.5);color:#fff;transform:translateY(0)}50%{transform:translateY(-3px)}to{text-shadow:2px 2px 0px rgba(255,142,142,.9),4px 4px 0px rgba(110,232,232,.9),6px 6px 20px rgba(0,0,0,.7);color:#f5f5f5;transform:translateY(0)}}.retro-chorus-lyric{font-size:2.5rem;font-weight:900;color:#fff;text-shadow:3px 3px 0px rgba(255,107,107,.9),6px 6px 0px rgba(78,205,196,.9),9px 9px 15px rgba(0,0,0,.6);letter-spacing:4px;text-transform:uppercase;animation:chorus-title-glow 1.5s ease-in-out infinite alternate;max-width:100%;word-break:break-word;overflow-wrap:break-word;white-space:pre-wrap;box-sizing:border-box;padding:0 15px}@keyframes chorus-title-glow{0%{text-shadow:3px 3px 0px rgba(255,107,107,.9),6px 6px 0px rgba(78,205,196,.9),9px 9px 15px rgba(0,0,0,.6);transform:scale(1) translateY(0);color:#fff}50%{transform:scale(1.02) translateY(-5px)}to{text-shadow:3px 3px 0px rgba(255,142,142,1),6px 6px 0px rgba(110,232,232,1),9px 9px 25px rgba(0,0,0,.8);transform:scale(1.05) translateY(0);color:#f0f0f0}}.retro-finale-lyric{font-size:2.2rem;font-weight:900;color:#fff;text-shadow:2px 2px 0px rgba(255,105,180,.8),4px 4px 0px rgba(255,142,199,.8),6px 6px 12px rgba(255,105,180,.7);letter-spacing:3px;text-transform:uppercase;animation:finale-title-glow 2s ease-in-out infinite alternate;max-width:100%;word-break:break-word;overflow-wrap:break-word;white-space:pre-wrap;box-sizing:border-box;padding:0 12px}@keyframes finale-title-glow{0%{text-shadow:2px 2px 0px rgba(255,105,180,.8),4px 4px 0px rgba(255,142,199,.8),6px 6px 12px rgba(255,105,180,.7);transform:scale(1) translateY(0);color:#fff}50%{transform:scale(1.01) translateY(-4px)}to{text-shadow:2px 2px 0px rgba(255,142,199,.9),4px 4px 0px rgba(255,179,217,.9),6px 6px 20px rgba(255,105,180,.9);transform:scale(1.03) translateY(0);color:#f5f5f5}}.loading-message{font-size:2rem;color:#fffc;text-shadow:0 0 10px rgba(255,255,255,.5);animation:loading-pulse 1.5s infinite ease-in-out}.central-play-button{animation:button-glow 2s infinite ease-in-out}@keyframes loading-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}@keyframes button-glow{0%,to{box-shadow:0 4px 20px #4caf5066}50%{box-shadow:0 6px 30px #4caf50b3}}.control-panel{position:absolute;bottom:30px;left:50%;transform:translate(-50%);background:#000000b3;padding:20px;border-radius:10px;width:80%;max-width:500px;z-index:20}.playback-controls{display:flex;justify-content:space-between;margin-bottom:15px}.control-button{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-weight:700;transition:all .3s ease}.control-button:disabled{opacity:.5;cursor:not-allowed}.volume-control{display:flex;flex-direction:column;gap:8px;margin:15px 0;padding:10px;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.volume-label{font-size:14px;color:#ffffffe6;font-weight:700;text-align:center}.volume-slider{width:100%;height:6px;border-radius:3px;background:#fff3;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;transition:all .2s ease}.volume-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#90ee90;cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 0 8px #90ee9099}.volume-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#90ee90;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 0 8px #90ee9099}.volume-slider:disabled{opacity:.5;cursor:not-allowed}.volume-slider:disabled::-webkit-slider-thumb{cursor:not-allowed}.volume-slider:disabled::-moz-range-thumb{cursor:not-allowed}.play-button{background-color:#4caf50;color:#fff}.pause-button{background-color:#ff9800;color:#fff}.stop-button{background-color:#f44336;color:#fff}.status-display{display:flex;justify-content:space-between;margin-bottom:15px}.status-indicator{padding:5px 10px;border-radius:5px;font-weight:700}.status-playing{background-color:#4caf50;color:#fff}.status-stopped{background-color:#9e9e9e;color:#fff}.status-finale{background-color:#9c27b0;color:#fff;animation:finale-glow 2s infinite alternate}@keyframes finale-glow{0%{background-color:#9c27b0;box-shadow:0 0 10px #9c27b080}to{background-color:#e91e63;box-shadow:0 0 20px #e91e63cc}}.section-indicator{padding:5px 10px;border-radius:5px;font-weight:700;background-color:#2196f3;color:#fff;transition:all .3s ease}.chorus-active{background-color:#ff9800;animation:pulse 1s infinite alternate}.star-properties{display:grid;grid-template-columns:1fr 1fr;gap:10px;color:#fff}.property{display:flex;justify-content:space-between}.property-value{font-weight:700}.tap-counter{color:#90ee90;text-shadow:0 0 5px rgba(144,238,144,.7);animation:tap-glow .3s ease-in-out}@keyframes tap-glow{0%{transform:scale(1)}50%{transform:scale(1.2);color:#fff}to{transform:scale(1)}}@keyframes pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.retro-signboard{max-width:95%}.ending-characters-display{width:95vw;height:75vh;gap:40px}.game-title{font-size:24px}.game-subtitle{font-size:14px}.rule-item{font-size:13px}.retro-start-button{font-size:18px;padding:12px 30px}.retro-lyric-container{max-width:95vw;padding:0 2.5vw}.retro-lyric{font-size:1.5rem;letter-spacing:2px;padding:0 8px}.retro-chorus-lyric{font-size:1.8rem;letter-spacing:3px;padding:0 12px}.retro-finale-lyric{font-size:1.6rem;letter-spacing:2.5px;padding:0 10px}.title{font-size:2rem;top:20px}.subtitle{font-size:1.2rem;top:70px}.current-lyric{font-size:1.5rem;max-width:90vw;top:50%;transform:translateY(-50%)}.chorus-lyric{font-size:1.8rem;top:50%;transform:translateY(-50%)}.finale-lyric{font-size:1.6rem;top:50%;transform:translateY(-50%)}.loading-message{font-size:1.5rem;top:50%;transform:translateY(-50%)}.central-play-button{padding:15px 30px!important;font-size:20px!important}.control-panel{width:95%;padding:15px;bottom:20px;max-height:35vh;overflow-y:auto}.control-button{padding:8px 15px;font-size:.9rem;min-height:44px}.volume-control{margin:10px 0;padding:8px}.volume-label{font-size:12px}.volume-slider{height:8px}.volume-slider::-webkit-slider-thumb{width:20px;height:20px}.volume-slider::-moz-range-thumb{width:20px;height:20px}.star-properties{grid-template-columns:1fr;gap:8px;font-size:.9rem}}@media (max-width: 480px){.title{font-size:1.5rem}.ending-characters-display{width:98vw;height:70vh;gap:20px}.subtitle{font-size:1rem}.retro-lyric-container{max-width:98vw;padding:0 1vw}.retro-lyric{font-size:1.2rem;letter-spacing:1.5px;padding:0 6px}.retro-chorus-lyric{font-size:1.5rem;letter-spacing:2px;padding:0 8px}.retro-finale-lyric{font-size:1.3rem;letter-spacing:2px;padding:0 8px}.current-lyric{font-size:1.2rem}.chorus-lyric{font-size:1.5rem}.finale-lyric{font-size:1.3rem}.loading-message{font-size:1.2rem}.central-play-button{padding:12px 25px!important;font-size:18px!important}.control-panel{padding:10px;max-height:30vh}.playback-controls{flex-direction:column;gap:10px}.control-button{padding:12px;width:100%;min-height:48px}}@media (max-width: 768px) and (orientation: landscape){.retro-lyric-container{max-width:95vw;top:40%}.current-lyric,.chorus-lyric{top:40%;transform:translateY(-50%)}.control-panel{max-height:50vh}}@media (max-width: 320px){.status-display{flex-direction:column;gap:10px}.status-indicator,.section-indicator{text-align:center}}@media (min-width: 1200px){.retro-lyric{font-size:2.5rem;letter-spacing:4px}.retro-chorus-lyric{font-size:3.2rem;letter-spacing:5px}.retro-finale-lyric{font-size:2.8rem;letter-spacing:4px}.retro-lyric-container:before{width:400px;height:400px}.retro-lyric-container:after{width:300px;height:300px}@keyframes ripple-wave{0%{width:0;height:0;opacity:1}50%{opacity:.5}to{width:600px;height:600px;opacity:0}}}@media (min-width: 1600px){.retro-lyric{font-size:3rem;letter-spacing:5px}.retro-chorus-lyric{font-size:4rem;letter-spacing:6px}.retro-finale-lyric{font-size:3.5rem;letter-spacing:5px}.retro-lyric-container:before{width:500px;height:500px}.retro-lyric-container:after{width:400px;height:400px}@keyframes ripple-wave{0%{width:0;height:0;opacity:1}50%{opacity:.5}to{width:800px;height:800px;opacity:0}}}@media (min-width: 1920px){.retro-lyric{font-size:3.5rem;letter-spacing:6px}.retro-chorus-lyric{font-size:4.5rem;letter-spacing:7px}.retro-finale-lyric{font-size:4rem;letter-spacing:6px}.retro-lyric-container:before{width:600px;height:600px}.retro-lyric-container:after{width:500px;height:500px}@keyframes ripple-wave{0%{width:0;height:0;opacity:1}50%{opacity:.5}to{width:1000px;height:1000px;opacity:0}}}@keyframes phraseAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.star-overlay{pointer-events:none;z-index:10}.star-overlay .phrase-text{font-family:Hiragino Mincho ProN,Yu Mincho,YuMincho,"Noto Serif JP",serif;letter-spacing:.05em;text-shadow:1px 1px 2px rgba(0,0,0,.3)}@media (max-width: 768px){.star-overlay .phrase-text{font-size:24px;max-width:90%}}@media (max-width: 480px){.star-overlay .phrase-text{font-size:20px;max-width:85%}}@tailwind base;@tailwind components;@tailwind utilities;*{box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:0;padding:0;width:100vw;height:100vh;overflow:hidden;position:fixed;top:0;left:0;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}#root{width:100%;height:100%;overflow:hidden}#media{position:fixed;bottom:10px;right:10px;z-index:100}@keyframes beat-pulse{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.beat-active{animation:beat-pulse .3s ease-in-out}@media (max-width: 768px){html,body{height:100vh;height:100dvh;overscroll-behavior:none;-webkit-overflow-scrolling:touch}#root{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}#media{bottom:20px;right:20px;z-index:1000}}@media (max-width: 480px){#media{bottom:15px;right:15px;transform:scale(.9)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){html,body{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}
