.stage{
  position:relative;width:100%;height:min(74vh,720px);min-height:480px;
  overflow:hidden;touch-action:manipulation;isolation:isolate;
  border-radius:20px;border:1px solid var(--line);margin:6px 0 22px;
}
.sky{position:absolute;inset:0;z-index:0;background:
  radial-gradient(120% 60% at 20% -10%, rgba(255,248,231,.18), transparent 55%),
  radial-gradient(120% 60% at 80% -10%, rgba(255,248,231,.18), transparent 55%),
  linear-gradient(180deg,#0a0e27 0%, #1a1448 38%, #1a2150 60%)}
.flood{position:absolute;top:-4%;width:34%;height:46%;z-index:1;
  background:radial-gradient(closest-side, rgba(255,248,231,.5), rgba(255,248,231,.06) 60%, transparent 75%);
  filter:blur(2px);opacity:0;pointer-events:none}
.flood.l{left:-6%}.flood.r{right:-6%}
.lit .flood{animation:powerOn 1.1s ease forwards}
.lit .flood.r{animation-delay:.15s}
@keyframes powerOn{0%{opacity:0}12%{opacity:.9}18%{opacity:.2}26%{opacity:1}34%{opacity:.4}100%{opacity:1}}
.stands{position:absolute;top:0;left:0;right:0;height:26%;z-index:2;
  background:repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 2px, transparent 2px 5px),
  linear-gradient(180deg,#0d1330,#0d1330 70%,rgba(13,19,48,0));
  -webkit-mask-image:linear-gradient(180deg,#000 60%,transparent);mask-image:linear-gradient(180deg,#000 60%,transparent);opacity:.9}
.stands::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.22) 1px, transparent 1px);background-size:7px 7px;opacity:.5}
.pitch{position:absolute;left:0;right:0;bottom:0;top:20%;z-index:3;
  background:repeating-linear-gradient(180deg,var(--pitch-far) 0 18px,var(--stripe) 18px 36px);background-blend-mode:multiply}
.pitch::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,30,18,.55) 0%, rgba(8,30,18,.05) 30%, rgba(60,200,120,.10) 78%, rgba(120,255,170,.16) 100%)}
.pitch::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 55% at 50% 8%, rgba(255,248,231,.2), transparent 60%)}

.goal{position:absolute;z-index:5;left:50%;top:11%;transform:translateX(-50%);width:min(82vw,400px);aspect-ratio:16/9}
.net{position:absolute;inset:0;background:
  repeating-linear-gradient(45deg, rgba(255,255,255,.16) 0 1px, transparent 1px 11px),
  repeating-linear-gradient(-45deg, rgba(255,255,255,.16) 0 1px, transparent 1px 11px),
  linear-gradient(180deg, rgba(6,12,30,.55), rgba(6,12,30,.78));
  border-radius:6px 6px 2px 2px;box-shadow:inset 0 8px 22px rgba(0,0,0,.5);
  transition:transform .18s ease, filter .18s ease;transform-origin:center 30%}
.crossbar,.post{position:absolute;background:linear-gradient(180deg,#fff,#c9cee6);box-shadow:0 0 10px rgba(255,255,255,.45)}
.crossbar{top:-6px;left:-6px;right:-6px;height:9px;border-radius:5px}
.post{top:-6px;width:9px;bottom:-2px;border-radius:5px}
.post.left{left:-6px}.post.right{right:-6px}
.keeper{position:absolute;z-index:6;left:50%;bottom:-2px;width:20%;transform:translateX(-50%);transform-origin:50% 90%;
  transition:transform .5s cubic-bezier(.2,.9,.25,1.2);filter:drop-shadow(0 6px 8px rgba(0,0,0,.5))}
.keeper svg{display:block;width:100%;height:auto}
.zones{position:absolute;inset:0;z-index:7;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}
.zone{position:relative;outline:none}
.zone .target{position:absolute;top:50%;left:50%;width:34px;height:34px;transform:translate(-50%,-50%);border-radius:50%;
  border:2px dashed rgba(255,255,255,.5);opacity:0;transition:opacity .25s, transform .25s}
.aiming .zone .target{opacity:.55}
.zone:active .target{opacity:1;transform:translate(-50%,-50%) scale(1.18);border-color:var(--gold)}
.goalFlash{position:absolute;inset:-8px;z-index:8;border-radius:8px;background:radial-gradient(circle, rgba(255,255,255,.85), transparent 60%);opacity:0;pointer-events:none}
.goalFlash.fire{animation:flash .55s ease-out}
@keyframes flash{0%{opacity:0;transform:scale(.6)}30%{opacity:.9}100%{opacity:0;transform:scale(1.25)}}
.net.bulge{transform:scaleX(1.04) scaleY(1.08) translateY(6px);filter:brightness(1.6)}

.spot{position:absolute;z-index:4;left:50%;bottom:13%;width:46px;height:14px;transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(closest-side, rgba(255,255,255,.85), rgba(255,255,255,0))}
.ball{position:absolute;z-index:9;left:50%;bottom:11%;width:50px;height:50px;transform:translateX(-50%);
  --tx:0px;--ty:0px;--ts:1;filter:drop-shadow(0 8px 6px rgba(0,0,0,.45))}
.ball svg{display:block;width:100%;height:100%}
.ball.shoot{animation:shoot .62s cubic-bezier(.2,.5,.4,1) forwards}
@keyframes shoot{
  0%{transform:translateX(-50%) translate(0,0) scale(1) rotate(0)}
  50%{transform:translateX(-50%) translate(calc(var(--tx)/2), calc(var(--ty) - 26px)) scale(calc((1 + var(--ts))/2)) rotate(360deg)}
  100%{transform:translateX(-50%) translate(var(--tx), var(--ty)) scale(var(--ts)) rotate(680deg)}
}

.hud{position:absolute;z-index:12;top:14px;left:50%;transform:translateX(-50%);width:calc(100% - 28px);max-width:440px;
  display:flex;align-items:center;justify-content:space-between;gap:10px}
.board{background:linear-gradient(180deg,#0c1124,#070b18);border:1px solid rgba(92,240,138,.25);border-radius:12px;padding:8px 14px;
  box-shadow:0 6px 20px rgba(0,0,0,.4), inset 0 0 16px rgba(92,240,138,.06)}
.bd-label{font-size:9px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase}
.bd-score{font-family:'JetBrains Mono',monospace;font-size:26px;line-height:1;color:var(--led);text-shadow:0 0 10px rgba(92,240,138,.6)}
.bd-score small{color:var(--led-dim);text-shadow:none}
.iconbtn{width:42px;height:42px;flex:none;border-radius:12px;background:linear-gradient(180deg,#0c1124,#070b18);
  border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;font-size:18px;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.iconbtn:active{transform:scale(.94)}

.toast{position:absolute;z-index:13;top:30%;left:50%;transform:translate(-50%,-50%) scale(.7);
  font-family:'Anton',sans-serif;letter-spacing:.04em;text-transform:uppercase;font-size:clamp(40px,13vw,64px);
  opacity:0;pointer-events:none;text-align:center;text-shadow:0 6px 0 rgba(0,0,0,.35)}
.toast.goal{color:var(--led)}.toast.save{color:#ff5d6c}
.toast.show{animation:toast 1s ease forwards}
@keyframes toast{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}
  70%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-60%) scale(1)}}

.prompt{position:absolute;z-index:11;bottom:18px;left:50%;transform:translateX(-50%);text-align:center;width:90%}
.prompt h2{font-family:'Anton',sans-serif;font-size:clamp(20px,6vw,30px);letter-spacing:.01em;line-height:.98;text-transform:uppercase;text-shadow:0 3px 0 rgba(0,0,0,.4)}
.prompt p{margin-top:6px;font-size:13px;color:#dfe4ff;font-weight:500}
.prompt .pill{display:inline-block;margin-top:10px;padding:4px 14px;border-radius:99px;
  background:rgba(255,200,61,.14);border:1px solid rgba(255,200,61,.4);color:var(--gold);font-size:12px;font-weight:700;letter-spacing:.04em;animation:ppulse 1.6s ease-in-out infinite}
@keyframes ppulse{50%{transform:scale(1.06);box-shadow:0 0 0 6px rgba(255,200,61,.07)}}

.win{position:absolute;inset:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:28px;
  background:radial-gradient(80% 60% at 50% 30%, rgba(20,26,58,.7), rgba(10,14,39,.94));backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transform:translateY(16px);transition:opacity .4s, transform .4s, visibility .4s;text-align:center}
.win.show{opacity:1;visibility:visible;transform:none}
.trophy{font-size:60px;filter:drop-shadow(0 8px 14px rgba(255,200,61,.4));animation:bob 2.4s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-8px)}}
.win .kicker{font-size:11px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase;margin-top:8px}
.win h2{font-family:'Anton',sans-serif;font-size:clamp(32px,11vw,50px);text-transform:uppercase;line-height:.96}
.win p{color:#cfd6ff;font-size:14px;max-width:320px;margin-top:4px;line-height:1.5}
.win .wbtns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:20px}
.confetti{position:absolute;top:-12px;width:9px;height:14px;z-index:19;will-change:transform;border-radius:2px}
