*{margin:0;padding:0;box-sizing:border-box}html{height:100%;width:100%;overflow:hidden;touch-action:none;position:fixed;inset:0}body{height:100vh;width:100vw;background:#000;display:flex;justify-content:center;align-items:center;overflow:hidden;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;position:fixed;inset:0}#app{width:100%;height:100%;position:relative;overflow:hidden;touch-action:none;-webkit-overflow-scrolling:touch}@media screen and (max-width:1279px){#app{display:flex;align-items:center;justify-content:center}}#gameCanvas{display:block;margin:0 auto;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media screen and (min-width:1280px){#gameCanvas{width:100%;height:100%}}@media screen and (max-width:1279px){#gameCanvas{max-width:100vw;max-height:100vh;image-rendering:auto}}@media screen and (max-width:1024px)and (orientation:portrait){#app{transform:rotate(90deg);transform-origin:center center;position:absolute;width:100vh;height:100vw;top:0;left:0;margin-left:calc((100vw - 100vh)/2);margin-top:calc((100vh - 100vw)/2)}body{overflow:hidden}}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:20px}.game-over-screen{display:none;position:fixed;top:0;left:0;width:100%;height:100%;transform:none;background-color:#000000d9;flex-direction:column;align-items:center;justify-content:center;gap:20px;z-index:20;padding:20px}.start-screen{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:20px;touch-action:pan-y pan-x;-webkit-overflow-scrolling:touch}.scroll-container{position:relative;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;overflow-x:hidden;background:linear-gradient(to bottom,#1a1a1a,#0a0a0a 10%,#000,#0a0a0a 90%,#1a1a1a);border-radius:10px;box-shadow:0 10px 40px #000c,inset 0 2px 5px #ffffff0d,inset 0 -2px 5px #00000080;border:3px solid #333;touch-action:pan-y;-webkit-overflow-scrolling:touch}.scroll-top{position:relative;height:30px;background:linear-gradient(to bottom,#2a2a2a,#1a1a1a);border-bottom:2px solid #333;border-radius:10px 10px 0 0;box-shadow:inset 0 -5px 10px #00000080}.scroll-top:before,.scroll-top:after{content:"";position:absolute;top:50%;width:40px;height:3px;background:#444;transform:translateY(-50%)}.scroll-top:before{left:20px}.scroll-top:after{right:20px}.scroll-bottom{position:relative;height:30px;background:linear-gradient(to top,#2a2a2a,#1a1a1a);border-top:2px solid #333;border-radius:0 0 10px 10px;box-shadow:inset 0 5px 10px #00000080}.scroll-bottom:before,.scroll-bottom:after{content:"";position:absolute;bottom:50%;width:40px;height:3px;background:#444;transform:translateY(50%)}.scroll-bottom:before{left:20px}.scroll-bottom:after{right:20px}.scroll-content{padding:20px;background:repeating-linear-gradient(0deg,transparent,transparent 29px,rgba(255,255,255,.02) 29px,rgba(255,255,255,.02) 30px),radial-gradient(ellipse at 10% 20%,rgba(255,255,255,.01) 0%,transparent 50%),radial-gradient(ellipse at 90% 80%,rgba(255,255,255,.01) 0%,transparent 50%)}.text-shadow{text-shadow:2px 2px 0 #000}.title-roasted{color:#fff;font-family:Helvetica}.title-main{color:#cf3000;font-family:"Jersey 10",serif;font-size:80px;margin:0;text-align:center}.subtitle-main{color:#fff;font-family:"Jacquard 24",serif;font-weight:400;font-style:normal;font-size:40px;padding:20px 10px;line-height:1.2;margin:0;text-align:center}.subtitle-container{display:flex;align-items:center;gap:10px;justify-content:center}.survivor-image{width:200px;height:auto;image-rendering:pixelated}.loading-container{width:400px;max-width:80%;margin:auto}.loading-text{font-family:"Micro 5",serif;font-size:36px;color:#fff;margin-bottom:15px;text-align:center}.progress-bar{width:100%;height:30px;background-color:#fff3;border:2px solid white;border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#cf3000,#ff6432);width:0%;transition:width .3s ease}.loading-percent{font-family:"Micro 5",serif;font-size:24px;color:#fff;margin-top:10px;text-align:center}.buttons-container{display:flex;flex-direction:column;gap:15px;margin-top:30px;align-items:center}.btn{padding:10px 20px;font-size:24px;cursor:pointer;border:none;border-radius:10px;font-family:"Micro 5",serif;transition:transform .2s,opacity .2s;min-width:200px}.btn:hover{transform:scale(1.05)}.btn:active{transform:scale(.95)}.btn-play{font-family:"Micro 5",serif;font-size:36px}.btn-play-red{background-color:#cf3000;color:#fff;font-size:36px}.btn-settings{background-color:#2f2f2f;color:#fff}.btn-info{background-color:#fff;color:#000}.btn-back{background-color:#cf3000;color:#fff;margin-top:30px;display:block;margin-left:auto;margin-right:auto}.btn-exit{background-color:#2f2f2f;color:#fff;font-size:24px}.game-over-tip{font-family:"Micro 5",serif;font-size:24px;color:#fff;margin-top:15px;max-width:600px;text-align:center;padding:10px 15px;line-height:1.3;display:block!important;min-height:30px;opacity:1;visibility:visible;background-color:#00000080;border-radius:10px;border:1px solid rgba(255,255,255,.2)}.hidden{display:none!important}.page-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000f2;display:flex;align-items:center;justify-content:center;z-index:11}.overlay-content{background-color:#1e1e1ee6;padding:20px;border-radius:10px;max-width:800px;max-height:90vh;overflow-y:auto;overflow-x:hidden;border:3px solid rgb(207,48,0);touch-action:pan-y;-webkit-overflow-scrolling:touch}.overlay-title{font-family:"Jersey 10",serif;font-size:60px;color:#cf3000;margin-bottom:20px;text-shadow:2px 2px 0 #000;text-align:center}.gore-section{margin:20px 0 30px;padding:20px;background:#96000033;border:2px solid rgb(207,48,0);border-radius:10px;text-align:center}.gore-label{display:flex;align-items:center;justify-content:center;gap:15px;color:#fff;font-family:"Micro 5",serif;font-size:32px;cursor:pointer}.gore-checkbox{width:30px;height:30px;cursor:pointer;accent-color:rgb(207,48,0)}.sound-mixer{margin:30px 0;padding:20px;background:#0000004d;border-radius:10px;display:flex;flex-direction:column;gap:15px}.sound-label{display:flex;align-items:center;gap:15px;color:#fff;font-family:"Micro 5",serif;font-size:24px;cursor:pointer}.volume-slider{flex:1;height:8px;background:#ffffff4d;border-radius:5px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#cf3000;border-radius:50%;cursor:pointer}.volume-slider::-moz-range-thumb{width:20px;height:20px;background:#cf3000;border-radius:50%;cursor:pointer;border:none}#volumeValue,#masterVolumeValue,#bgMusicVolumeValue,#retroSfxVolumeValue,#cheekySfxVolumeValue,#impactSfxVolumeValue,#buttTrumpetVolumeValue{min-width:50px;text-align:right}.mute-label{display:flex;align-items:center;gap:10px;color:#fff;font-family:"Micro 5",serif;font-size:24px;cursor:pointer}.settings-actions{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding:0 10px}.btn-reset{background-color:#06c;color:#fff;font-family:"Micro 5",serif;font-size:18px;padding:10px 20px;border:1px solid #666;border-radius:5px;cursor:pointer;min-width:auto}.btn-reset:hover{background-color:#0052a3}.mute-checkbox{width:20px;height:20px;cursor:pointer}.instructions{color:#fff;text-align:left;font-family:Arial,sans-serif;line-height:1.6}.instructions h3{font-family:"Micro 5",serif;font-size:28px;color:#cf3000;margin-top:25px;margin-bottom:15px}.instructions p{font-size:16px;margin:8px 0;display:flex;align-items:center;gap:10px}.instructions strong{color:#ffc864}.powerup-icon{width:32px;height:32px;object-fit:contain;vertical-align:middle;image-rendering:pixelated}.shield-icon{display:inline-block;background-image:url(../assets/shield.png);background-size:400% 200%;background-position:0 100%;background-repeat:no-repeat;image-rendering:pixelated}.leaderboard-content{text-align:center;padding:20px}.coming-soon{font-family:"Jersey 10",serif;font-size:60px;color:#fff;margin-bottom:20px}.coming-soon-subtitle{align-items:center;gap:15px}.high-score-value{font-family:"Jersey 10",serif;font-size:80px;color:#fff;margin:0;line-height:1;text-shadow:4px 4px 0 #000}.high-score-label{font-family:"Micro 5",serif;font-size:32px;color:#ffc864;margin-top:10px}.input-container{margin:10px 0;display:flex;justify-content:center;align-items:center;gap:15px;width:100%}.name-input{background-color:#000;color:#fff;border:4px solid rgb(207,48,0);font-family:"Jersey 10",serif;font-size:54px;width:250px;text-align:center;text-transform:uppercase;padding:5px 10px;border-radius:10px;outline:none;letter-spacing:5px}.name-input::placeholder{color:#333}.name-input:focus{border-color:#ff6432;box-shadow:0 0 20px #cf300080}#submitScoreButton{min-width:auto;padding:10px 20px;font-size:32px;height:74px;display:flex;align-items:center;justify-content:center;margin-top:0}.input-hint{font-family:"Micro 5",serif;font-size:20px;color:#888;margin-bottom:20px}.leaderboard-list{display:flex;flex-direction:column;gap:10px;width:100%;max-width:600px;margin:0 auto}.leaderboard-row{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background-color:#00000080;border:1px solid rgba(255,255,255,.1);border-radius:5px;font-family:"Micro 5",serif;font-size:32px;color:#fff}.leaderboard-row.top-rank{background-color:#cf30004d;border-color:#cf3000;color:#ffc864}.rank-cell{width:50px;text-align:left;color:#888}.top-rank .rank-cell{color:#ffc864}.name-cell{flex:1;text-align:left;padding-left:20px;letter-spacing:2px}.device-cell{width:40px;text-align:center;font-size:24px}.score-cell{text-align:right;font-family:"Jersey 10",serif;font-size:40px}.high-score-content{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;width:100%}.mobile-controls{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5;display:none;touch-action:none}.mobile-controls.force-visible{display:block!important}.mobile-controls.force-hidden{display:none!important}@media screen and (max-width:1279px){.mobile-controls{display:block!important}}@media screen and (max-height:1279px){.mobile-controls{display:block!important}}@media screen and (min-width:1280px)and (min-height:1280px){.mobile-controls{display:none!important}}@media screen and (max-width:1024px)and (orientation:portrait){.mobile-controls{display:block!important;position:fixed;z-index:15}}.joystick{position:absolute;left:30px;bottom:30px;width:120px;height:120px;border-radius:50%;background:#00000080;border:3px solid rgba(255,255,255,.3);pointer-events:auto;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #00000080;touch-action:manipulation}.joystick:before{content:"← →";position:absolute;color:#fff6;font-size:24px;font-weight:700;pointer-events:none;z-index:1}.joystick-handle{width:50px;height:50px;border-radius:50%;background:#cf3000cc;border:2px solid rgba(255,255,255,.5);pointer-events:none;transition:transform .1s ease-out;box-shadow:0 2px 5px #0000004d}.joystick:active .joystick-handle{background:#ff6432e6}.mobile-buttons{position:absolute;right:30px;bottom:30px;display:flex;flex-direction:column;gap:20px;pointer-events:auto}.mobile-button{width:80px;height:80px;border-radius:50%;border:3px solid rgba(255,255,255,.3);background:#00000080;color:#fff;font-size:36px;font-weight:700;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #00000080;transition:all .1s ease;font-family:"Micro 5",serif;pointer-events:auto;touch-action:manipulation}.mobile-button:active{transform:scale(.9);background:#cf3000cc;border-color:#fff9}.jump-button{background:#00960099}.jump-button:active{background:#00c800e6}.glide-button{background:#0064c899}.glide-button:active{background:#0096ffe6}@media screen and (min-width:1280px){.mobile-controls{display:none!important}}
