:root{
  --bg:#05060a;
  --ink:#eaf4ff;
  --muted:#8fa3bf;
  --accent:#f0c419;
  --accent-2:#4fd1c5;
  --line:rgba(120,180,255,.22);
  --hud-bg:rgba(8,14,26,.92);
  --hud-glow:rgba(79,209,197,.5);
  --px:'Press Start 2P',monospace;
  --hud:'Electrolize',sans-serif;
  --mono:'Space Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--ink);font-family:var(--hud);-webkit-font-smoothing:antialiased}
body{position:fixed;inset:0;touch-action:none;-webkit-user-select:none;user-select:none}
a{color:inherit}
button{font-family:inherit;cursor:pointer}

/* ===== GAME CANVAS ===== */
#game{position:fixed;inset:0;z-index:1}
#game canvas{display:block}

/* ===== INTRO ===== */
#intro{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 800px at 50% 30%,#0c1430,#05060a 70%);overflow:hidden;text-align:center}
#intro.hide{opacity:0;pointer-events:none;transition:opacity .6s ease}
.intro-grid{position:absolute;inset:0;opacity:.25;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(circle at 50% 45%,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(circle at 50% 45%,#000 30%,transparent 75%)}
.intro-scan{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 2px,transparent 2px 4px);mix-blend-mode:overlay}
.intro-inner{position:relative;z-index:2;padding:30px;max-width:680px}
.intro-badge{font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;color:var(--accent-2);margin-bottom:30px}
.intro-title{font-family:var(--px);font-size:clamp(2.2rem,9vw,5rem);line-height:1;color:var(--accent);
  text-shadow:0 0 18px rgba(240,196,25,.5),4px 4px 0 #7a5c00;letter-spacing:.02em}
.intro-tag{font-family:var(--px);font-size:clamp(.55rem,2.2vw,.8rem);letter-spacing:.2em;margin-top:22px;color:var(--ink)}
.intro-desc{color:var(--muted);margin-top:26px;font-size:1.02rem;line-height:1.7}
#launch-btn{margin-top:38px;font-family:var(--px);font-size:1rem;color:#05060a;background:var(--accent);
  border:0;padding:20px 40px;letter-spacing:.06em;box-shadow:0 0 0 3px #05060a,0 0 0 6px var(--accent),0 0 30px rgba(240,196,25,.5);
  transition:transform .15s,box-shadow .2s}
#launch-btn:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 0 0 3px #05060a,0 0 0 6px var(--accent),0 10px 40px rgba(240,196,25,.7)}
#launch-btn:active{transform:translateY(0)}
.intro-controls{margin-top:34px;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;color:var(--muted)}
.intro-controls span{display:block;margin-top:6px}
.ctrl-mob{display:none}
#skip-link{display:inline-block;margin-top:30px;font-family:var(--mono);font-size:.72rem;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line);opacity:.7}
#skip-link:hover{opacity:1;color:var(--accent-2)}

/* ===== ON-SCREEN HINT ===== */
#hint{position:fixed;left:50%;bottom:max(26px,env(safe-area-inset-bottom));transform:translateX(-50%);z-index:20;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;color:var(--accent);
  background:var(--hud-bg);border:1px solid var(--line);padding:11px 18px;
  opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap;text-shadow:0 0 8px var(--hud-glow)}
#hint.show{opacity:1}
/* mobile: move the dock hint to the TOP, centered, just below the minimap */
@media (max-width:600px), (pointer:coarse){
  #hint{
    top:calc(max(16px,env(safe-area-inset-top)) + min(92px,30vw) + 14px);
    bottom:auto;
    max-width:none;
    white-space:nowrap;text-align:center;
    font-size:clamp(.6rem,3.1vw,.78rem);letter-spacing:.1em;line-height:1.2;padding:10px 16px;
  }
}

/* ===== HUD PANEL ===== */
#hud{position:fixed;inset:0;z-index:40;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(2,4,10,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
#hud.open{display:flex;animation:hudIn .25s ease}
@keyframes hudIn{from{opacity:0}to{opacity:1}}
.hud-window{position:relative;width:min(680px,94vw);max-height:88vh;display:flex;flex-direction:column;
  background:var(--hud-bg);border:1px solid var(--line);
  box-shadow:0 0 0 1px rgba(0,0,0,.6),0 0 60px rgba(79,209,197,.18),inset 0 0 40px rgba(79,209,197,.04)}
.hud-window.in{animation:winPop .3s cubic-bezier(.2,.8,.2,1)}
@keyframes winPop{from{transform:scale(.94) translateY(10px);opacity:0}to{transform:none;opacity:1}}
.hud-corner{position:absolute;width:16px;height:16px;border:2px solid var(--accent-2);z-index:3}
.hud-corner.tl{top:6px;left:6px;border-right:0;border-bottom:0}
.hud-corner.tr{top:6px;right:6px;border-left:0;border-bottom:0}
.hud-corner.bl{bottom:6px;left:6px;border-right:0;border-top:0}
.hud-corner.br{bottom:6px;right:6px;border-left:0;border-top:0}
.hud-bar{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(79,209,197,.08),transparent)}
.hud-id{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--accent-2)}
.hud-readout{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;color:var(--muted);margin-left:auto}
#hud-close{width:30px;height:30px;background:transparent;border:1px solid var(--line);color:var(--ink);font-size:.9rem;transition:.2s}
#hud-close:hover{border-color:var(--accent);color:var(--accent)}
.hud-content{padding:26px 30px;overflow-y:auto;scrollbar-width:thin}
.hud-content::-webkit-scrollbar{width:8px}.hud-content::-webkit-scrollbar-thumb{background:var(--line)}
.hud-content h2{font-family:var(--px);font-size:clamp(1rem,3.6vw,1.5rem);line-height:1.3;color:var(--accent);
  text-shadow:0 0 14px rgba(240,196,25,.4);margin-bottom:14px}
.hud-sub{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--accent-2);margin-bottom:22px}
.hud-body{color:var(--muted);font-size:1rem;line-height:1.65}
.hud-body p{margin-bottom:16px}
.hud-body strong,.hud-body b{color:var(--ink)}
.hud-shot{display:block;width:100%;height:auto;border:1px solid var(--line);margin-bottom:16px;image-rendering:auto}
.avatar{width:100%;height:auto;object-fit:cover}
.hud-footline{display:flex;justify-content:space-between;padding:11px 18px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;color:var(--muted)}

/* HUD content bits */
.hud-list{list-style:none;margin-top:6px}
.hud-list li{padding:9px 0 9px 22px;position:relative;border-bottom:1px solid rgba(120,180,255,.1)}
.hud-list li::before{content:"▸";position:absolute;left:0;color:var(--accent)}
.hud-crew{display:flex;gap:16px;flex-wrap:wrap;margin:18px 0}
.crew{display:flex;align-items:center;gap:12px;border:1px solid var(--accent);padding:12px 16px;flex:1;min-width:200px}
.crew-av{width:42px;height:auto;display:grid;place-items:center;font-family:var(--px);font-size:.8rem;color:#05060a;background:var(--accent-2)}
.crew-name{font-family:var(--hud);font-size:1.05rem;color:var(--ink)}
.crew-role{font-family:var(--mono);font-size:.62rem;color:var(--muted);letter-spacing:.02em;margin-top:3px}
.hud-game{border:1px solid var(--line);padding:18px;margin-bottom:16px;background:rgba(79,209,197,.03)}
.hud-game-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.hud-game-head h3{font-family:var(--hud);font-size:1.3rem;letter-spacing:.02em;color:var(--ink);text-transform:uppercase}
.hud-tag{font-family:var(--mono);font-size:.56rem;letter-spacing:.12em;color:var(--accent);border:1px solid var(--accent);padding:4px 8px}
.hud-meta{font-family:var(--mono);font-size:.66rem;color:var(--muted);letter-spacing:.04em;margin-bottom:10px}
.hud-link{display:inline-block;margin-top:10px;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:4px;text-decoration:none}
.hud-link:hover{color:var(--ink)}
.hud-soon{display:flex;gap:18px;align-items:flex-start;border:1px dashed var(--line);padding:22px;margin-top:14px}
.hud-soon-ico{font-size:2.4rem;color:var(--accent);line-height:1}
.hud-soon-h{font-family:var(--px);font-size:.8rem;color:var(--ink);margin-bottom:10px;line-height:1.5}
.hud-mail{display:inline-block;font-family:var(--mono);font-size:1.05rem;color:var(--accent);margin:6px 0 18px;word-break:break-all;text-decoration:none;border-bottom:1px solid var(--accent)}
.hud-form{display:flex;flex-direction:column;gap:12px}
.hud-form input,.hud-form textarea{background:rgba(2,6,14,.7);border:1px solid var(--line);color:var(--ink);
  font-family:var(--mono);font-size:.84rem;padding:12px 14px;letter-spacing:.04em}
.hud-form input:focus,.hud-form textarea:focus{outline:none;border-color:var(--accent-2)}
.hud-form textarea{resize:vertical}
.hud-form .hp{position:absolute;left:-9999px}
.hud-form button{margin-top:4px;font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;color:#05060a;background:var(--accent-2);border:0;padding:14px}
.hud-form button:hover{background:var(--accent)}
#hud-form-status{display:none;font-family:var(--mono);font-size:.74rem;padding:10px 12px;border:1px solid var(--line)}
#hud-form-status.show{display:block}
#hud-form-status.ok{color:#9fe3ad;border-color:rgba(123,216,143,.5)}
#hud-form-status.err{color:#f0a0a0;border-color:rgba(232,90,90,.5)}
.hud-socials{display:flex;gap:18px;margin-top:20px}
.hud-socials a{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:3px}
.hud-socials a:hover{color:var(--accent-2)}

/* ===== MOBILE CONTROLS ===== */
#touch-ui{position:fixed;inset:0;z-index:25;pointer-events:none;display:none}
#joystick{position:absolute;left:max(26px,env(safe-area-inset-left));bottom:max(34px,env(safe-area-inset-bottom));
  width:130px;height:130px;pointer-events:auto;touch-action:none}
#joy-base{position:absolute;inset:0;border-radius:50%;border:2px solid var(--line);background:rgba(8,14,26,.45)}
#joy-knob{position:absolute;left:50%;top:50%;width:56px;height:56px;margin:-28px 0 0 -28px;border-radius:50%;
  background:rgba(79,209,197,.35);border:2px solid var(--accent-2);box-shadow:0 0 18px var(--hud-glow)}
#dock-btn{position:absolute;right:max(26px,env(safe-area-inset-right));bottom:max(46px,env(safe-area-inset-bottom));
  width:96px;height:96px;border-radius:50%;pointer-events:auto;
  font-family:var(--px);font-size:.62rem;color:#05060a;background:var(--accent);border:0;letter-spacing:.04em;
  box-shadow:0 0 0 3px #05060a,0 0 0 5px var(--accent),0 0 22px rgba(240,196,25,.5);opacity:.45;transition:opacity .2s,transform .1s}
#dock-btn.active{opacity:1}
#dock-btn:active{transform:scale(.94)}

/* ===== MUTE ===== */
#mute-btn{position:fixed;top:max(16px,env(safe-area-inset-top));right:max(16px,env(safe-area-inset-right));z-index:30;
  width:42px;height:42px;background:var(--hud-bg);border:1px solid var(--line);color:var(--accent-2);font-size:1.1rem;transition:.2s}
#mute-btn:hover{border-color:var(--accent-2)}
#mute-btn.muted{color:var(--muted);opacity:.6}

/* ===== STATIC FALLBACK ===== */
.static-fallback,#fallback{position:fixed;inset:0;z-index:60;background:var(--bg);color:var(--ink);
  overflow-y:auto;padding:40px 22px;font-family:var(--hud)}
#fallback[hidden]{display:none}
#fallback h1{font-family:var(--px);font-size:1.4rem;color:var(--accent);margin-bottom:20px}
#fallback h2{font-family:var(--hud);text-transform:uppercase;letter-spacing:.04em;color:var(--accent-2);margin:28px 0 10px;font-size:1.4rem}
#fallback .fb-wrap{max-width:760px;margin:0 auto}
#fallback p{color:var(--muted);line-height:1.6;margin-bottom:12px}
#fallback a{color:var(--accent)}
#fallback .fb-back{display:inline-block;margin-bottom:24px;font-family:var(--mono);font-size:.8rem;border:1px solid var(--line);padding:10px 16px;text-decoration:none}

/* ===== RESPONSIVE ===== */
@media (max-width:820px), (pointer:coarse){
  .ctrl-desk{display:none}
  .ctrl-mob{display:block}
}
@media (prefers-reduced-motion:reduce){
  .hud-window.in{animation:none}
  #intro.hide{transition:none}
}
