/* NEON STRIKE v2 — MAPI GAMES — Portrait Mobile */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --cyan:#00ffff;--pink:#ff0066;--orange:#ff6600;
  --yellow:#ffff00;--purple:#cc00ff;--green:#00ff88;--dark:#00000f
}
html,body{
  width:100%;height:100%;overflow:hidden;
  background:var(--dark);font-family:'Orbitron',monospace;
  touch-action:none
}
#gameCanvas{position:fixed;inset:0;display:block}

/* ── HUD ── */
#hud{
  position:fixed;top:0;left:0;width:100%;
  display:flex;justify-content:space-between;
  padding:10px 16px 12px;
  background:linear-gradient(to bottom,rgba(0,0,16,.92) 0%,transparent 100%);
  z-index:10;pointer-events:none
}
.hb{display:flex;flex-direction:column;gap:1px}
.hb.c{align-items:center}.hb.r{align-items:flex-end}
.hl{font-size:8px;letter-spacing:3px;color:rgba(0,200,220,.5)}
.hv{font-size:17px;font-weight:700;letter-spacing:2px;
    color:var(--cyan);text-shadow:0 0 8px var(--cyan),0 0 18px #0af}
.wave{color:var(--orange);text-shadow:0 0 8px var(--orange),0 0 18px #f40}
.lives{color:var(--pink);text-shadow:0 0 8px var(--pink);font-size:12px;letter-spacing:5px}

/* ── POWER-UP BAR ── */
#powerbar{
  position:fixed;top:58px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:8px;
  background:rgba(0,0,20,.75);border:1px solid rgba(0,255,255,.15);
  padding:4px 12px;border-radius:20px;z-index:10;pointer-events:none;
  transition:opacity .3s
}
#pwLabel{font-size:7px;letter-spacing:3px;color:rgba(0,200,220,.5)}
#pwName{font-size:11px;letter-spacing:2px;color:var(--yellow);
        text-shadow:0 0 6px var(--yellow);min-width:90px;text-align:center}
#pwTimer{width:70px;height:5px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}
#pwFill{height:100%;width:100%;background:var(--yellow);
        box-shadow:0 0 6px var(--yellow);transition:width .1s linear}

/* ── BOSS HP BAR ── */
#bossbar{
  position:fixed;top:96px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:8px;
  background:rgba(20,0,0,.8);border:1px solid rgba(255,0,102,.3);
  padding:5px 14px;border-radius:20px;z-index:10;pointer-events:none;
  animation:bossBarPulse 1s ease-in-out infinite
}
#bossbar.hidden{display:none}
@keyframes bossBarPulse{0%,100%{border-color:rgba(255,0,102,.3)}50%{border-color:rgba(255,0,102,.7)}}
#bossLabel{font-size:9px;letter-spacing:3px;color:var(--pink);text-shadow:0 0 6px var(--pink)}
#bossHpWrap{width:120px;height:7px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}
#bossHpFill{height:100%;width:100%;background:linear-gradient(to right,var(--pink),var(--orange));
             box-shadow:0 0 8px var(--pink);transition:width .2s ease}
#bossHpNum{font-size:9px;letter-spacing:1px;color:var(--orange);min-width:32px;text-align:right}

/* ── SCREEN OVERLAY ── */
#screen{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center,rgba(0,6,28,.95) 0%,rgba(0,0,15,.98) 100%);
  z-index:20;opacity:0;pointer-events:none;transition:opacity .35s
}
#screen.active{opacity:1;pointer-events:all}
#screen-inner{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  border:1px solid rgba(0,255,255,.18);padding:36px 44px;position:relative;
  max-width:340px;width:90%
}
#screen-inner::before,#screen-inner::after{
  content:'';position:absolute;width:16px;height:16px;
  border-color:var(--cyan);border-style:solid;opacity:.65
}
#screen-inner::before{top:-1px;left:-1px;border-width:2px 0 0 2px}
#screen-inner::after{bottom:-1px;right:-1px;border-width:0 2px 2px 0}
#brand{font-size:8px;letter-spacing:5px;color:rgba(255,0,102,.6)}
#title{
  font-size:clamp(38px,12vw,72px);font-weight:900;
  line-height:1;letter-spacing:6px;text-align:center;color:var(--cyan);
  text-shadow:0 0 10px var(--cyan),0 0 30px #0af,0 0 70px #05f,0 0 120px #03c;
  animation:pulse 2.4s ease-in-out infinite
}
#sub{font-size:9px;letter-spacing:7px;color:rgba(255,0,102,.7);text-shadow:0 0 8px var(--pink)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.65}}
#keys{font-size:10px;letter-spacing:1px;color:rgba(160,200,255,.6);text-align:center;line-height:1.8}
.kb{display:inline-block;border:1px solid rgba(0,255,255,.35);padding:1px 6px;
    color:var(--cyan);font-size:10px;background:rgba(0,255,255,.05)}
.touch-hint{display:block;font-size:9px;margin-top:4px;opacity:.4}
#startBtn{
  font-family:'Orbitron',monospace;font-size:15px;font-weight:700;
  letter-spacing:4px;color:#00000f;background:var(--cyan);border:none;cursor:pointer;
  padding:12px 38px;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%);
  box-shadow:0 0 20px rgba(0,255,255,.5),0 0 40px rgba(0,255,255,.2);
  transition:all .2s;animation:blink 1.2s ease-in-out infinite
}
#startBtn:hover,#startBtn:active{background:#fff;box-shadow:0 0 36px rgba(0,255,255,.9);animation:none}
@keyframes blink{0%,80%,100%{opacity:1}90%{opacity:.4}}
#hiBlock{font-size:10px;letter-spacing:3px;color:rgba(255,200,0,.55)}
#hiEl{color:var(--yellow);text-shadow:0 0 6px var(--yellow)}

/* ── BIG MESSAGE ── */
#bigMsg{
  position:fixed;top:42%;left:50%;transform:translate(-50%,-50%);
  font-size:clamp(22px,6vw,44px);font-weight:900;letter-spacing:5px;text-align:center;
  color:var(--orange);
  text-shadow:0 0 10px var(--orange),0 0 28px #f40,0 0 55px #f20;
  z-index:15;pointer-events:none;display:none;line-height:1.3
}
#bigMsg.show{display:block;animation:msgAnim 2.8s ease forwards}
@keyframes msgAnim{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}
  18%{opacity:1;transform:translate(-50%,-50%) scale(1.06)}
  72%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}
}

/* ── TOUCH CONTROLS ── */
#touchControls{
  display:none;
  position:fixed;bottom:0;left:0;width:100%;height:160px;
  z-index:11;pointer-events:none
}
@media (pointer:coarse){
  #touchControls{display:flex;align-items:center;justify-content:space-between;padding:0 30px 24px}
}
#joystickZone{
  width:110px;height:110px;
  display:flex;align-items:center;justify-content:center;
  pointer-events:all;position:relative
}
#joystickBase{
  width:90px;height:90px;border-radius:50%;
  border:2px solid rgba(0,255,255,.25);
  background:rgba(0,255,255,.05);
  display:flex;align-items:center;justify-content:center;
  position:relative
}
#joystickKnob{
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,255,255,.3);
  border:2px solid var(--cyan);
  box-shadow:0 0 10px var(--cyan);
  position:absolute;
  transition:transform .05s
}
#fireBtn{
  width:90px;height:90px;border-radius:50%;
  border:2px solid rgba(255,0,102,.4);
  background:rgba(255,0,102,.12);
  box-shadow:0 0 14px rgba(255,0,102,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:30px;pointer-events:all;cursor:pointer;
  user-select:none;-webkit-user-select:none
}
#fireBtn:active{background:rgba(255,0,102,.35);box-shadow:0 0 24px rgba(255,0,102,.6)}

/* Scanlines */
body::after{
  content:'';position:fixed;inset:0;
  background:repeating-linear-gradient(to bottom,transparent 0,transparent 2px,rgba(0,0,0,.07) 2px,rgba(0,0,0,.07) 4px);
  pointer-events:none;z-index:100
}
