@font-face{font-family:PixelFallback;src:local("Courier New")}:root{--hud-bg: #070a0e;--gold: #ffd22f;--red: #ff4d55;--blue: #145df2;--white: #f3f3f0;--green: #18dc21}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0;overflow:hidden;background:#06080b;color:var(--white);font-family:PixelFallback,Courier New,monospace;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}#game-root{position:fixed;top:0;right:0;bottom:0;left:0}#intro-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#05080ce0,#05080cc2),url(./selhurst-background-BGS9GJrb.png) center / cover;color:var(--white);text-shadow:4px 4px 0 #000}.intro-panel{width:min(760px,92vw);border:5px solid #f5d349;background:#070a0eeb;padding:24px 34px;text-align:center;box-shadow:0 0 0 5px #123ed0}.intro-panel h1{margin:0;color:var(--red);font-size:56px;line-height:1}.intro-panel p{margin:14px 0 18px;color:var(--white);font-size:22px;font-weight:900;line-height:1.15}.controls-grid{display:grid;grid-template-columns:minmax(96px,.7fr) minmax(180px,1fr);gap:10px 18px;margin:0 auto 20px;max-width:520px;text-align:left;font-size:19px;font-weight:900}.controls-grid span{color:var(--gold)}.controls-grid strong{color:var(--white)}#start-game{pointer-events:auto;border:4px solid #f5d349;background:#164fca;color:#fff;padding:10px 18px;font:900 20px PixelFallback,Courier New,monospace;text-shadow:3px 3px 0 #000;cursor:pointer}.mobile-start-label{display:none}.sound-credit{margin:12px 0 0;font-size:11px;line-height:1.3;color:#cbd6e2;text-shadow:2px 2px 0 #000}.sound-credit a{pointer-events:auto;color:#ffd22f}#intro-screen.hidden{display:none}#orientation-lock{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:none;place-items:center;padding:24px;background:linear-gradient(180deg,#05080cf0,#05080cdb),url(./selhurst-background-BGS9GJrb.png) center / cover;color:var(--white);text-align:center;text-shadow:4px 4px 0 #000}.rotate-panel{width:min(520px,90vw);border:5px solid #f5d349;background:#070a0ef0;padding:24px;box-shadow:0 0 0 5px #123ed0}.rotate-title{color:var(--gold);font-size:32px;font-weight:900;line-height:1.05}.rotate-copy{margin-top:12px;font-size:18px;font-weight:900}#touch-controls{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;display:none;pointer-events:none}.touch-dpad,.touch-actions{position:absolute;bottom:max(18px,env(safe-area-inset-bottom));display:flex;align-items:flex-end;gap:12px}.touch-dpad{left:max(18px,env(safe-area-inset-left))}.touch-actions{right:max(18px,env(safe-area-inset-right))}.touch-button{pointer-events:auto;display:grid;place-items:center;width:72px;height:72px;border-radius:50%;border:4px solid rgba(255,255,255,.72);background:#070a0e8f;color:#fff;font:900 18px PixelFallback,Courier New,monospace;text-shadow:3px 3px 0 #000;box-shadow:inset 0 0 0 3px #123ed075,0 5px #0000006b;touch-action:none;cursor:pointer}.touch-button:active{transform:translateY(3px);box-shadow:inset 0 0 0 3px #123ed08c,0 2px #0000006b}.touch-move{font-size:30px}.touch-kick{width:92px;height:92px;border-color:#ffd22fe6;background:#d51f3394}.touch-jump{border-color:#82c4ffe6}.touch-special{border-color:#ffd22fcc;background:#145df294}#hud{pointer-events:none;position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-rows:150px 1fr 96px;color:var(--white);text-shadow:4px 4px 0 #000}.top-hud,.bottom-hud{display:grid;align-items:center;background:linear-gradient(180deg,#080b10,#10151e);border-color:#26303a}.top-hud{grid-row:1;grid-template-columns:minmax(360px,1fr) 120px 220px minmax(340px,1fr) 340px;gap:24px;padding:14px 28px;border-bottom:4px solid #123ed0}.bottom-hud{grid-row:3;grid-template-columns:1fr 360px 220px;gap:28px;padding:14px 64px;border-top:4px solid #423620}.player-panel,.objective{display:flex;align-items:center;gap:18px}.portrait{width:136px;height:136px;border:3px solid #607f9a;background:#111821;display:grid;place-items:center}.portrait-face{width:116px;height:116px;background-image:url(./jp-boom-sprites-CiyXp3kx.png);background-size:768px 512px;background-position:-33px -40px;image-rendering:pixelated;filter:drop-shadow(4px 4px 0 #000)}.player-copy{min-width:280px}.label{font-size:30px;font-weight:900;line-height:1;letter-spacing:0}.red{color:var(--red)}.gold{color:var(--gold)}.name,.objective-text{margin-top:8px;font-size:32px;font-weight:900;line-height:1}.health-shell{width:min(390px,42vw);height:29px;margin-top:12px;border:4px solid #8af277;background:#082414;padding:3px}.health-fill{width:100%;height:100%;background:repeating-linear-gradient(90deg,#ffffff2e 0,#ffffff2e 8px,#00000029 8px,#00000029 14px),linear-gradient(90deg,#e22b36 0 33.33%,#ff9820 33.33% 66.66%,var(--green) 66.66% 100%);clip-path:inset(0 0 0 0);transition:clip-path .1s linear;box-shadow:inset 0 -4px #0000003d,inset 0 3px #ffffff29}.timer-panel,.score-panel,.site-logo-panel,.special-panel,.lives{text-align:center}.site-logo-panel{display:grid;place-items:center;min-width:0}.site-logo{display:block;width:auto;height:86px;max-width:100%;object-fit:contain;image-rendering:auto;filter:drop-shadow(3px 3px 0 #000)}.timer{font-size:64px;font-weight:900;line-height:1}.score{margin-top:4px;font-size:38px;font-weight:900;line-height:1}.coin-row{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:30px;font-weight:900}.coin{width:30px;height:30px;display:inline-block;border-radius:50%;background-image:url(./football-pickup-DrkIUf2c.png);background-size:cover;image-rendering:pixelated;filter:drop-shadow(2px 2px 0 #000)}.flag-icon{width:54px;height:74px;border-left:5px solid #e7e7e7;background:linear-gradient(135deg,#c91e35 0,#c91e35 50%,#164fca 50%,#164fca);clip-path:polygon(0 0,100% 12%,100% 56%,0 46%)}.special-meter{margin-top:10px;display:grid;grid-template-columns:repeat(5,1fr);width:340px;height:34px;border:4px solid #d9d9d5;background:#14171d}.special-meter span{border-right:3px solid #d9d9d5;background:transparent}.special-meter span:last-child{border-right:0}.special-meter .filled{background:linear-gradient(180deg,#147cff,#093ad9)}.special-meter.ready{border-color:var(--gold);box-shadow:0 0 10px #ffd22f94;animation:special-ready-pulse .82s steps(2,end) infinite}.special-meter.ready .filled{background:linear-gradient(180deg,#39b7ff,#145df2)}@keyframes special-ready-pulse{50%{box-shadow:0 0 18px #ffd22fdb;filter:brightness(1.18)}}@media(prefers-reduced-motion:reduce){.special-meter.ready{animation:none}}.lives{display:flex;align-items:center;justify-content:center;gap:18px;font-size:34px;font-weight:900}.eagle-mark{display:block;width:48px;height:48px;color:transparent;background-image:url(./jp-boom-sprites-CiyXp3kx.png);background-size:318px 212px;background-position:-14px -12px;border-radius:50%;image-rendering:pixelated;filter:drop-shadow(3px 3px 0 #000)}.center-banner{position:absolute;left:50%;top:47%;transform:translate(-50%,-50%);max-width:82vw;padding:20px 34px;border:5px solid #f5d349;background:#06080be0;color:#fff;font-size:42px;font-weight:900;text-align:center}.hidden{display:none}#game-over-screen,#victory-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;display:grid;place-items:center;padding:24px;color:var(--white);text-align:center;text-shadow:4px 4px 0 #000}#game-over-screen{background:#04060abd}#victory-screen{background:transparent;pointer-events:none}#game-over-screen.hidden,#victory-screen.hidden{display:none}.game-over-panel,.victory-panel{width:min(560px,88vw);border:5px solid #f5d349;background:#070a0ef0;padding:30px;box-shadow:0 0 0 5px #123ed0}.victory-panel{pointer-events:auto;background:#070a0ec7}.game-over-panel h2,.victory-panel h2{margin:0;color:var(--red);font-size:52px;line-height:1}.victory-panel h2{color:var(--gold)}.game-over-panel p,.victory-panel p{margin:16px 0 22px;font-size:22px;font-weight:900}#restart-game,#share-game,#play-again{pointer-events:auto;border:4px solid #f5d349;background:#164fca;color:#fff;padding:12px 22px;font:900 22px PixelFallback,Courier New,monospace;text-shadow:3px 3px 0 #000;cursor:pointer}.victory-actions{display:flex;justify-content:center;gap:14px;margin-top:28px;flex-wrap:wrap}#share-game{background:#d51f33}@media(max-width:900px){#hud{grid-template-rows:118px 1fr 104px}.top-hud{grid-template-columns:minmax(0,1fr) 54px 86px;gap:10px;padding:10px 12px}.bottom-hud{grid-template-columns:minmax(0,1fr);gap:0;padding:10px 14px}.portrait,.score-panel,.lives{display:none}.player-copy{min-width:0}.label{font-size:17px}.name,.objective-text{font-size:17px;line-height:1.08}.timer{font-size:42px}.score,.coin-row{font-size:20px}.special-meter{width:172px;height:32px}.health-shell{width:210px}.flag-icon{width:36px;height:50px}.objective{gap:8px;min-width:0}.objective>div{min-width:0}.center-banner{padding:16px 24px;font-size:34px}.intro-panel{padding:24px 20px}.intro-panel h1{font-size:44px}.intro-panel p{font-size:20px}.controls-grid{grid-template-columns:1fr;gap:4px;font-size:18px;text-align:center}#start-game{font-size:18px}.sound-credit{font-size:11px}}@media(pointer:coarse)and (orientation:portrait){#orientation-lock{display:grid}}@media(pointer:coarse)and (orientation:landscape){#touch-controls{display:block}}@media(orientation:landscape)and (max-height:520px),(pointer:coarse)and (orientation:landscape){#intro-screen{align-items:stretch;padding:max(6px,env(safe-area-inset-top)) 10px max(6px,env(safe-area-inset-bottom));overflow:hidden}.intro-panel{align-self:stretch;display:grid;grid-template-rows:auto auto 1fr auto;align-content:stretch;justify-items:center;width:min(700px,84vw);height:calc(100dvh - max(6px,env(safe-area-inset-top)) - max(6px,env(safe-area-inset-bottom)));max-height:calc(100dvh - max(6px,env(safe-area-inset-top)) - max(6px,env(safe-area-inset-bottom)));overflow:hidden;padding:clamp(8px,2dvh,14px) clamp(16px,4vw,24px);border-width:4px;box-shadow:0 0 0 4px #123ed0}.intro-panel h1{font-size:clamp(30px,10dvh,48px);line-height:.95}.intro-panel p{margin:clamp(5px,1.4dvh,8px) 0 clamp(8px,2dvh,12px);font-size:clamp(12px,3.8dvh,16px);line-height:1.12}.controls-grid{display:none}#start-game{align-self:center;display:grid;place-items:center;width:clamp(88px,26dvh,132px);height:clamp(88px,26dvh,132px);min-width:0;padding:0;border-width:4px;border-radius:50%;font-size:0;line-height:1}.desktop-start-label{display:none}.mobile-start-label{display:block;width:0;height:0;margin-left:clamp(5px,1.5dvh,8px);border-top:clamp(18px,5.8dvh,29px) solid transparent;border-bottom:clamp(18px,5.8dvh,29px) solid transparent;border-left:clamp(29px,9dvh,46px) solid #ffffff;color:transparent;filter:drop-shadow(3px 3px 0 #000)}.sound-credit{align-self:end;margin-top:clamp(5px,1.3dvh,8px);font-size:clamp(7px,2.1dvh,9px);line-height:1.15}.sound-credit a{pointer-events:none}#hud{display:block;text-shadow:2px 2px 0 #000}.top-hud{position:absolute;top:max(8px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));display:grid;grid-template-columns:clamp(220px,34vw,310px) minmax(92px,1fr) 76px 100px 104px;gap:8px;min-height:64px;padding:7px 10px;border:2px solid rgba(18,62,208,.72);background:linear-gradient(180deg,#080b10bd,#0a0e1485)}.bottom-hud{position:absolute;top:0;right:0;bottom:0;left:0;display:block;padding:0;border:0;background:transparent}.portrait,.lives{display:none}.player-panel{gap:0;min-width:0}.player-copy{min-width:0}.label{font-size:13px;line-height:1}.name{margin-top:2px;font-size:15px;line-height:1}.health-shell{width:min(220px,34vw);height:17px;margin-top:6px;border-width:2px;padding:2px}.health-fill{background:repeating-linear-gradient(90deg,#ffffff2e 0,#ffffff2e 8px,#00000029 8px,#00000029 13px),linear-gradient(90deg,#e22b36 0 33.33%,#ff9820 33.33% 66.66%,var(--green) 66.66% 100%)}.timer-panel{display:flex;align-items:center;justify-content:flex-end;gap:6px;text-align:right}.site-logo-panel{width:auto;height:100%;min-width:0;overflow:visible;justify-self:center}.timer{font-size:36px;line-height:.9}.score-panel{display:grid;align-content:center;justify-items:end;text-align:right}.site-logo{width:auto;height:54px;max-width:100%;max-height:calc(100% - 6px);filter:drop-shadow(2px 2px 0 #000)}.score{margin-top:1px;font-size:15px}.coin-row{margin-top:2px;gap:6px;font-size:15px}.coin{width:18px;height:18px}.special-panel{display:grid;align-content:center;justify-items:stretch;min-width:0;text-align:center}#special-label{font-size:10px;line-height:1;white-space:nowrap}.special-meter{width:100%;height:16px;margin-top:4px;border-width:2px}.special-meter span{border-right-width:2px}.objective{position:absolute;top:max(82px,calc(env(safe-area-inset-top) + 82px));left:max(10px,env(safe-area-inset-left));max-width:min(520px,calc(100vw - 20px));display:flex;gap:0;padding:5px 8px;border:2px solid rgba(245,211,73,.5);background:#070a0e6b}.objective .label,.flag-icon{display:none}.objective-text{margin-top:0;font-size:14px;line-height:1.05;white-space:nowrap}.center-banner{top:44%;padding:10px 16px;border-width:3px;font-size:22px}.touch-dpad,.touch-actions{bottom:max(10px,env(safe-area-inset-bottom));gap:14px}.touch-button{width:72px;height:72px;border-radius:50%;border-width:3px;font-size:16px;background:#070a0e6b;box-shadow:inset 0 0 0 2px #123ed075,0 4px #00000057}.touch-move{font-size:30px}.touch-jump{font-size:13px}.touch-special{font-size:12px}.touch-kick{width:84px;height:84px;border-radius:50%}}@media(pointer:coarse)and (orientation:landscape)and (max-height:520px){.top-hud{grid-template-columns:clamp(210px,32vw,300px) minmax(72px,1fr) 72px 96px 100px;gap:7px}.site-logo-panel{width:auto}.site-logo{width:auto;height:50px;max-height:calc(100% - 6px)}.touch-dpad,.touch-actions{bottom:max(12px,env(safe-area-inset-bottom));gap:16px}.touch-button{width:78px;height:78px;border-radius:50%;font-size:16px}.touch-move{font-size:32px}.touch-jump{font-size:13px}.touch-special{font-size:12px}.touch-kick{width:88px;height:88px;border-radius:50%}}@media(hover:hover)and (pointer:fine)and (min-width:901px){#hud{display:block;text-shadow:3px 3px 0 #000}.top-hud{position:absolute;top:18px;left:28px;right:28px;display:grid;grid-template-columns:minmax(300px,1fr) 96px 150px 190px 190px;gap:18px;min-height:86px;padding:10px 16px;border:3px solid rgba(18,62,208,.72);background:linear-gradient(180deg,#080b10c7,#0a0e148f)}.bottom-hud{position:absolute;top:0;right:0;bottom:0;left:0;display:block;padding:0;border:0;background:transparent}.portrait,.lives{display:none}.player-panel{gap:0;min-width:0}.player-copy{min-width:0}.label{font-size:18px;line-height:1}.name{margin-top:4px;font-size:22px;line-height:1}.health-shell{width:min(340px,30vw);height:22px;margin-top:8px;border-width:3px;padding:2px}.timer-panel{display:flex;align-items:center;justify-content:flex-end;gap:8px;text-align:right}.timer{font-size:52px;line-height:.9}.score-panel{display:grid;align-content:center;justify-items:end;text-align:right}.site-logo{height:68px}.score{margin-top:2px;font-size:22px}.coin-row{margin-top:3px;gap:8px;font-size:20px}.coin{width:22px;height:22px}.special-panel{display:grid;align-content:center;justify-items:stretch;min-width:0;text-align:center}#special-label{font-size:15px;line-height:1;white-space:nowrap}.special-meter{width:100%;height:22px;margin-top:6px;border-width:3px}.special-meter span{border-right-width:2px}.objective{position:absolute;top:120px;left:28px;max-width:min(640px,calc(100vw - 56px));display:flex;gap:0;padding:7px 12px;border:3px solid rgba(245,211,73,.5);background:#070a0e7a}.objective .label,.flag-icon{display:none}.objective-text{margin-top:0;font-size:20px;line-height:1.05;white-space:nowrap}}
