*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;background:#000;display:flex;align-items:center;justify-content:center;font-family:"Press Start 2P",monospace;color:#fff;overflow:hidden;-webkit-user-select:none;user-select:none}.game-wrapper{position:relative;width:800px;height:560px;transform-origin:center center}.game-container{position:relative;width:800px;height:560px;background:#000;overflow:hidden}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.blink{animation:blink 1s step-end infinite}@keyframes jitter{0%,to{transform:translate(0)}10%{transform:translate(-.5px,-.5px)}20%{transform:translate(.5px,.5px)}30%{transform:translate(-.5px,.5px)}40%{transform:translate(.5px,-.5px)}50%{transform:translate(-.5px,-.5px)}60%{transform:translate(.5px,.5px)}70%{transform:translate(-.5px,.5px)}80%{transform:translate(.5px,-.5px)}90%{transform:translate(-.5px,-.5px)}}.title-screen{gap:16px;background:#000}.title-stars{color:#ff69b4;font-size:10px;letter-spacing:4px}.title-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin:10px 0}.title-mtt{font-size:24px;color:#ff69b4;letter-spacing:2px}.title-divider{color:#fff;font-size:10px}.title-sub{font-size:14px;color:#fff;letter-spacing:4px}.title-hearts{display:flex;gap:16px;align-items:center}.title-heart{width:28px;height:28px;image-rendering:pixelated}.title-press{font-size:10px;color:#fff;letter-spacing:2px;margin-top:20px}.title-credit{font-size:7px;color:#555;position:absolute;bottom:20px;display:flex;align-items:center;gap:5px}.title-sound-icon{position:absolute;bottom:16px;left:16px;width:32px;image-rendering:pixelated}.title-credit-heart{width:10px;height:10px;image-rendering:pixelated}.name-screen{gap:20px}.name-title{font-size:14px;color:#ff69b4;margin-bottom:8px}.name-subtitle{font-size:7px;color:#888;margin-bottom:24px}.name-input{background:#000;border:3px solid #fff;color:#fff;font-family:"Press Start 2P",monospace;font-size:14px;padding:10px 16px;text-align:center;outline:none;width:280px;letter-spacing:2px}.name-input:focus{border-color:#ff69b4}.name-confirm{font-size:8px;color:#aaa;margin-top:16px}.name-message{font-size:10px;color:#ff6b6b;margin-top:8px;text-align:center}.game-screen{flex-direction:column;justify-content:flex-start;background:#000}.hud{width:100%;height:44px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #444;flex-shrink:0}.hud-left{display:flex;align-items:center;gap:12px}.player-name-hud{font-size:8px;color:#fff}.player-lv{font-size:8px;color:#ff0}.hud-center{display:flex;align-items:center;gap:8px}.hud-label{font-size:8px;color:#fff}.hp-bar-outer{width:140px;height:14px;border:2px solid #fff;background:#000;position:relative;overflow:hidden}.hp-bar-inner{height:100%;background:#00c000;transition:width .3s ease,background-color .3s ease}.hp-text{font-size:8px;color:#fff;white-space:nowrap}.hud-right{font-size:8px;color:#aaa}.main-area{display:flex;flex-direction:row;flex:1;width:100%;overflow:hidden}.mettaton-panel{width:190px;flex-shrink:0;border-right:2px solid #444;display:flex;flex-direction:column;align-items:center;padding:12px 0 10px;gap:12px;overflow:hidden}.mtt-sprite-img{width:150px;height:auto;image-rendering:pixelated}.panel-section{display:flex;flex-direction:column;align-items:center;gap:5px;width:100%;padding:0 14px}.panel-label{font-size:7px;color:#aaa;letter-spacing:2px}.ratings-bar-outer{width:100%;height:10px;border:2px solid #fff;background:#000;overflow:hidden}.ratings-bar-inner{height:100%;background:#ff69b4;transition:width .4s ease}.ratings-text{font-size:9px;color:#ff69b4}.score-text{font-size:13px;color:#ff0}.battle-section{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 20px;gap:10px;position:relative}.timer-container{display:flex;align-items:center;gap:8px;width:100%}.timer-bar-outer{flex:1;height:10px;border:2px solid #fff;background:#000;overflow:hidden}.timer-bar-inner{height:100%;background:#00c0ff;transition:width .25s linear,background-color .3s ease}.timer-text{font-size:8px;color:#aaa;width:20px;text-align:right}.battle-box-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.battle-box{position:relative;width:540px;height:260px;border:3px solid #fff;background:#000;overflow:hidden}.heart{position:absolute;width:20px;height:20px;image-rendering:pixelated;z-index:10;pointer-events:none}.answer-box{position:absolute;width:230px;height:82px;border:2px solid #fff;background:#fff;color:#000;display:flex;flex-direction:row;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;transition:none}.answer-box.selected{background:#000;color:#fff;border-color:#fff}.answer-box.correct{background:#040;color:#0f0;border-color:#0f0}.answer-box.wrong{background:#400;color:#f44;border-color:#f44}.answer-letter{font-size:12px;font-family:"Press Start 2P",monospace;flex-shrink:0;width:22px}.answer-text{font-size:7px;font-family:"Press Start 2P",monospace;line-height:1.6;word-break:break-word;animation:jitter .1s infinite}.battle-flash{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;z-index:20;transition:opacity .05s ease}.battle-flash.red{background:#f006;opacity:1}.battle-flash.green{background:#00ff644d;opacity:1}.battle-flash.fade{opacity:0;transition:opacity .35s ease}@keyframes scorePopup{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-40px)}}.score-popup{position:absolute;font-size:14px;font-family:"Press Start 2P",monospace;pointer-events:none;z-index:30;animation:scorePopup 1s ease forwards}.score-popup.correct{color:#0f0}.score-popup.wrong{color:#f44}.dialogue-area{width:100%;border-top:2px solid #444;flex-shrink:0}.dialogue-box{width:100%;height:118px;background:#000;border-top:2px solid #fff;padding:10px 16px;position:relative;display:flex;flex-direction:column;gap:8px}.dialogue-speaker{font-size:8px;color:#ff69b4;letter-spacing:1px}.dialogue-text{font-size:8px;color:#fff;line-height:1.8;flex:1;white-space:pre-wrap}.dialogue-continue{position:absolute;bottom:8px;right:14px;font-size:10px;color:#fff}.hidden{visibility:hidden}.cursor{animation:blink .7s step-end infinite;color:#fff}.gameover-screen{gap:20px;background:#000}@keyframes soulAppear{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}@keyframes gameOverReveal{0%{opacity:0;letter-spacing:30px}to{opacity:1;letter-spacing:4px}}.gameover-explosion{width:300px;height:200px;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gameover-soul-img{width:40px;height:40px;image-rendering:pixelated;animation:soulAppear .3s ease forwards}.gameover-canvas{position:absolute;top:0;left:0}.gameover-title{font-size:28px;color:#fff;letter-spacing:2px;animation:gameOverReveal 1s ease 1.5s both}.gameover-lines{display:flex;flex-direction:column;align-items:center;gap:10px}.gameover-line{font-size:8px;color:#aaa}.gameover-press{font-size:8px;color:#fff;margin-top:10px}.final-screen{gap:14px;background:#000}@keyframes finalReveal{0%{opacity:0;transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.final-stars{font-size:12px;color:#ff69b4;letter-spacing:4px;animation:finalReveal .6s ease}.final-title{font-size:22px;color:#fff;letter-spacing:4px;animation:finalReveal .6s ease .2s both}.final-divider{font-size:8px;color:#444}.final-stats{display:flex;flex-direction:column;gap:12px;width:380px;animation:finalReveal .6s ease .4s both}.final-stat-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #333;padding-bottom:8px}.final-label{font-size:9px;color:#aaa}.final-value{font-size:13px;color:#ff0}.final-value.pink{color:#ff69b4}.final-value.green{color:#0f0}.final-value.red{color:#f44}.final-message{font-size:8px;color:#ff69b4;text-align:center;max-width:500px;line-height:1.8;animation:finalReveal .6s ease .6s both}.final-press{font-size:8px;color:#aaa;margin-top:6px}.dpad-overlay{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:none;flex-direction:column;align-items:center;gap:2px;z-index:100;pointer-events:auto}@media(pointer:coarse){.dpad-overlay{display:flex}}.dpad-row{display:flex;gap:2px}.dpad-btn{width:48px;height:48px;background:#ffffff26;border:2px solid rgba(255,255,255,.4);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;font-family:"Press Start 2P",monospace}.dpad-btn:active{background:#ffffff4d}.dpad-confirm{position:fixed;bottom:20px;right:20px;width:60px;height:60px;background:#ff69b44d;border:2px solid #ff69b4;border-radius:50%;color:#ff69b4;font-size:10px;display:none;align-items:center;justify-content:center;z-index:100;cursor:pointer;font-family:"Press Start 2P",monospace;touch-action:none;-webkit-tap-highlight-color:transparent}.invite-screen{background:#000}.invite-image{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;pointer-events:none}@media(pointer:coarse){.dpad-confirm{display:flex}}
