*{margin:0;padding:0;box-sizing:border-box}#pwa-banner{position:fixed;left:50%;bottom:calc(10px + env(safe-area-inset-bottom));transform:translate(-50%,140%);width:min(440px,calc(100% - 20px));z-index:1000;transition:transform .32s ease}#pwa-banner.pwa-banner-show{transform:translate(-50%)}.pwa-banner-inner{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:2px solid #f4d34a;background:linear-gradient(145deg,#1c2640,#10141f);box-shadow:0 8px 28px #0000008c;color:#f0f0e8;font-size:13px;line-height:1.25}.pwa-banner-icon{font-size:20px}.pwa-banner-text{flex:1}.pwa-banner-actions{display:flex;align-items:center;gap:6px}.pwa-banner-install{border:none;border-radius:8px;padding:8px 12px;font-weight:800;font-size:12px;letter-spacing:.04em;color:#10141f;background:#f4d34a;cursor:pointer}.pwa-banner-install:active{background:#e0bc2c}.pwa-banner-close{border:none;border-radius:8px;width:30px;height:30px;font-size:13px;color:#aeb8d8;background:#ffffff14;cursor:pointer}.pwa-banner-close:active{background:#ffffff29}html,body{height:100%;overflow:hidden;background:radial-gradient(circle at 50% 20%,#1c2333,#10141f 70%);font-family:system-ui,sans-serif;-webkit-user-select:none;user-select:none;touch-action:none}#app{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:max(8px,env(safe-area-inset-top)) 10px max(8px,env(safe-area-inset-bottom))}#console-shell{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}#console-top{display:none}#screen-frame{position:relative;border:4px solid #2a3142;border-radius:10px;box-shadow:0 0 0 2px #0a0d14,0 18px 50px #0009,inset 0 0 18px #000000a6;background:#000;line-height:0}#game-canvas{image-rendering:pixelated;image-rendering:crisp-edges;display:block;background:#000}#touch-ui{display:none;width:100%;max-width:560px;justify-content:space-between;align-items:center;padding:0 14px 8px}body.touch #touch-ui{display:flex}body.touch #app{justify-content:flex-start;gap:0;padding:max(6px,env(safe-area-inset-top)) 6px max(6px,env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 8%,rgba(255,232,168,.08),transparent 28%),linear-gradient(180deg,#171d31,#0c1020)}body.touch #console-shell{position:relative;min-height:0;max-width:640px;justify-content:flex-start;gap:10px;padding:12px 10px 16px;border:2px solid rgba(255,255,255,.08);border-radius:26px 26px 42px 42px;background:linear-gradient(145deg,#3b446cf2,#161b30fa 48%,#0c0f1cfa),repeating-linear-gradient(135deg,transparent 0 18px,rgba(255,255,255,.025) 18px 20px);box-shadow:inset 0 2px #ffffff24,inset 0 -12px 24px #00000047,0 22px 60px #00000080;overflow:hidden}body.touch #console-shell:after{content:"";position:absolute;right:18px;bottom:16px;width:92px;height:42px;opacity:.32;background:repeating-linear-gradient(135deg,transparent 0 8px,rgba(200,210,238,.45) 8px 10px);transform:skew(-14deg);pointer-events:none}body.touch #console-top{width:min(100%,570px);min-height:26px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 8px;color:#e8c84a;font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 2px 0 rgba(0,0,0,.45)}.console-brand{font-style:italic}.console-power{display:inline-flex;align-items:center;gap:5px;color:#aeb8d8;font-size:10px;letter-spacing:.12em}.console-power i{width:8px;height:8px;display:inline-block;border-radius:50%;background:#f05a5a;box-shadow:0 0 9px #f05a5ad9}body.touch #screen-frame{border:8px solid #171b2b;border-bottom-width:14px;border-radius:16px 16px 24px 24px;box-shadow:0 0 0 2px #dee6ff29,0 10px 28px #0000007a,inset 0 0 0 2px #ffffff14}body.touch #screen-frame:after{content:"Politicmon";position:absolute;left:14px;bottom:-13px;color:#e8c84acc;font-size:8px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}body.touch #touch-ui{margin-top:clamp(10px,3vh,22px)}#touch-move{display:flex;flex-direction:column;align-items:center;gap:10px}#touch-dpad{position:relative;width:132px;height:132px}#touch-stick{position:relative;width:132px;height:132px;touch-action:none;align-items:center;justify-content:center}#touch-stick-base{position:absolute;width:100px;height:100px;border-radius:50%;border:2px solid #39415a;background:radial-gradient(circle at 50% 36%,rgba(255,255,255,.07),transparent 62%),#1c2333;box-shadow:inset 0 3px 9px #0000008c}#touch-stick-base:before,#touch-stick-base:after{content:"";position:absolute;background:#aeb8d82e}#touch-stick-base:before{left:50%;top:14px;width:2px;height:72px;transform:translate(-1px)}#touch-stick-base:after{top:50%;left:14px;height:2px;width:72px;transform:translateY(-1px)}#touch-stick-cap{position:relative;width:52px;height:52px;border-radius:50%;border:2px solid #5a3946;background:radial-gradient(circle at 50% 34%,#6a5868,#2e2330 72%);box-shadow:0 3px 6px #0000008c;pointer-events:none;transition:transform .06s linear}#touch-stick,body.ctrl-stick #touch-dpad{display:none}body.ctrl-stick #touch-stick{display:flex}.dpad-btn{position:absolute;width:46px;height:46px;border:2px solid #39415a;border-radius:8px;background:#232a3d;color:#aeb8d8;font-size:16px;touch-action:none}.dpad-btn:active{background:#39415a}.dpad-up{top:0;left:43px}.dpad-down{bottom:0;left:43px}.dpad-left{left:0;top:43px}.dpad-right{right:0;top:43px}#touch-buttons{display:flex;align-items:flex-end;gap:14px}.ab-btn{width:58px;height:58px;border-radius:50%;border:2px solid #5a3946;background:#3d2330;color:#e8aebe;font-size:20px;font-weight:700;touch-action:none}.a-btn{margin-bottom:26px}.ab-btn:active{background:#5a3946}.start-btn{height:26px;padding:0 14px;border-radius:13px;border:2px solid #39415a;background:#232a3d;color:#aeb8d8;font-size:10px;letter-spacing:1px;align-self:center;margin-left:4px;touch-action:none}.start-btn:active{background:#39415a}@media(max-width:480px){body.touch #console-shell{gap:8px;padding:10px 7px 12px;border-radius:20px 20px 34px 34px}body.touch #console-top{min-height:22px;font-size:11px}body.touch #screen-frame{border-width:6px;border-bottom-width:12px;border-radius:13px 13px 20px 20px}#touch-ui{max-width:100%;padding:0 8px max(4px,env(safe-area-inset-bottom))}#touch-dpad{width:116px;height:116px}.dpad-btn{width:42px;height:42px}.dpad-up,.dpad-down{left:37px}.dpad-left,.dpad-right{top:37px}#touch-buttons{gap:10px}.ab-btn{width:54px;height:54px}.a-btn{margin-bottom:18px}}
