/* ============================================================
   THE CADET GALAXY — piloted hub
   ============================================================ */
:root{
  --cyan:#34e7ff; --purple:#9b5cff; --pink:#ff5cc8; --gold:#ffd34d;
  --bg:#04010c; --ink:#eef0ff;
  --glass:rgba(12,8,32,.6); --line:rgba(155,92,255,.3);
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);font-family:'Segoe UI',system-ui,sans-serif;overflow:hidden}
#gal-canvas{position:fixed;inset:0;width:100%;height:100%;display:block;touch-action:none;cursor:grab}
#gal-canvas:active{cursor:grabbing}
kbd{
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.2);border-radius:5px;
  padding:2px 7px;font-family:inherit;font-size:.85em;
}

/* ---- Top bar ---- */
#gal-top{
  position:fixed;top:0;left:0;right:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 20px;pointer-events:none;
  background:linear-gradient(180deg, rgba(4,1,12,.72), transparent);
}
#gal-top > *{pointer-events:auto}
.gal-back{color:var(--ink);text-decoration:none;font-size:12px;letter-spacing:.14em;font-weight:700;opacity:.85}
.gal-back:hover{opacity:1}
.gal-brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.18em;font-size:13px}
.gal-brand img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 0 8px var(--cyan))}
.gal-mute{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:var(--glass);color:var(--ink);cursor:pointer;font-size:14px;
}

/* ---- HUD ---- */
.gal-hud{position:fixed;left:20px;bottom:20px;z-index:20;display:flex;flex-direction:column;gap:10px}
.gal-compass{
  display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:14px;
  background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--line);
}
.gal-arrow{
  display:inline-block;font-size:20px;color:var(--cyan);
  transition:transform .12s linear;filter:drop-shadow(0 0 8px var(--cyan));
}
.gal-compass-txt b{display:block;font-size:13px;letter-spacing:.06em}
.gal-compass-txt small{color:#9aa0c8;font-size:10.5px;letter-spacing:.14em}
.gal-speed{
  position:relative;height:10px;border-radius:99px;overflow:hidden;
  background:rgba(255,255,255,.06);border:1px solid var(--line);width:210px;
}
.gal-speed i{
  position:absolute;inset:0;width:0%;
  background:linear-gradient(90deg,var(--cyan),var(--purple),var(--pink));
  transition:width .1s linear;display:block;
}
.gal-speed span{
  position:absolute;right:-34px;top:50%;transform:translateY(-50%);
  font-size:10px;color:#9aa0c8;letter-spacing:.1em;
}

/* ---- Dock prompt ---- */
.gal-dock{
  position:fixed;left:50%;bottom:110px;transform:translateX(-50%);z-index:22;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:14px 26px;border-radius:14px;text-align:center;
  background:var(--glass);backdrop-filter:blur(14px);
  border:1px solid var(--cyan);box-shadow:0 0 34px rgba(52,231,255,.35);
  animation:dockpulse 1.6s ease-in-out infinite;
}
@keyframes dockpulse{0%,100%{box-shadow:0 0 22px rgba(52,231,255,.25)}50%{box-shadow:0 0 44px rgba(52,231,255,.5)}}
.gal-dock b{font-size:15px;letter-spacing:.08em}
.gal-dock span{font-size:11px;letter-spacing:.18em;color:#bfeeff}

/* ---- Jail popup ---- */
.gal-jail{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:40;
  max-width:380px;width:88vw;padding:26px 24px;border-radius:16px;text-align:center;
  background:rgba(20,4,10,.92);backdrop-filter:blur(14px);
  border:1px solid rgba(255,80,80,.5);box-shadow:0 0 60px rgba(255,60,60,.35);
}
.gal-jail h3{margin:0 0 10px;letter-spacing:.1em}
.gal-jail p{margin:0;color:#e8c8c8;line-height:1.55;font-size:14px}
.gal-jail button{
  position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;
  border:none;background:rgba(255,255,255,.1);color:#fff;cursor:pointer;
}

/* ---- Touch controls ---- */
.gal-touch{position:fixed;right:18px;bottom:18px;z-index:22;display:flex;gap:10px}
.gal-touch-btn{
  padding:16px 22px;border-radius:99px;border:1px solid var(--line);
  background:var(--glass);backdrop-filter:blur(10px);color:var(--ink);
  font-size:12px;font-weight:800;letter-spacing:.14em;cursor:pointer;
}
.gal-touch-btn.dock{border-color:var(--cyan);color:#bfeeff}

/* ---- Entry gate ---- */
.gal-gate{
  position:fixed;inset:0;z-index:50;display:grid;place-items:center;text-align:center;
  background:radial-gradient(circle at 50% 38%, rgba(20,8,48,.72), rgba(4,1,12,.94));
  backdrop-filter:blur(6px);transition:opacity .8s ease;
}
.gal-gate.hide{opacity:0;pointer-events:none}
.gal-gate-inner{max-width:560px;padding:0 24px;animation:galrise .9s cubic-bezier(.2,.8,.2,1) both}
@keyframes galrise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.gal-gate-logo{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 0 22px var(--cyan));margin-bottom:6px}
.gal-eyebrow{font-size:12px;letter-spacing:.32em;color:var(--cyan);margin:0 0 6px;font-weight:700}
.gal-gate-title{
  font-size:clamp(40px,8.5vw,80px);line-height:.95;margin:0 0 14px;font-weight:900;letter-spacing:.02em;
  background:linear-gradient(135deg,#fff,var(--cyan) 40%,var(--purple) 75%,var(--pink));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 30px rgba(155,92,255,.5));
}
.gal-gate-sub{font-size:15px;opacity:.82;margin:0 auto 20px;max-width:420px;line-height:1.55}
.gal-keys{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  font-size:11.5px;letter-spacing:.08em;color:#bfc6f2;margin-bottom:26px;
}
.gal-launch{
  font-size:15px;font-weight:800;letter-spacing:.16em;color:#06121a;
  padding:16px 40px;border:none;border-radius:40px;cursor:pointer;
  background:linear-gradient(135deg,var(--cyan),var(--purple) 60%,var(--pink));
  box-shadow:0 0 40px rgba(52,231,255,.55);transition:transform .2s,box-shadow .2s;
}
.gal-launch:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 0 60px rgba(255,92,200,.6)}

/* ---- hull pips + paint button ---- */
.gal-hull{display:flex;gap:6px;padding:2px 4px}
.gal-hull i{
  width:26px;height:10px;border-radius:4px;display:block;
  background:linear-gradient(90deg,#7dff9a,#34e7ff);
  box-shadow:0 0 10px rgba(125,255,154,.5);transition:all .3s;
}
.gal-hull i.off{background:rgba(255,255,255,.12);box-shadow:none}
.gal-shardbox{
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  padding:8px 14px;border-radius:12px;
  background:var(--glass);backdrop-filter:blur(10px);
  border:1px solid rgba(255,223,110,.4);color:#ffe9b0;
  font-size:11px;font-weight:800;letter-spacing:.12em;
  transition:transform .15s, box-shadow .2s;
}
.gal-shardbox.pop{transform:scale(1.12);box-shadow:0 0 24px rgba(255,223,110,.6)}
.gal-shardbox b{color:#ffdf6e;font-size:13px}
.gal-btnrow{display:flex;gap:8px;flex-wrap:wrap}
.gal-paint{
  padding:9px 14px;border-radius:12px;cursor:pointer;
  background:var(--glass);backdrop-filter:blur(10px);
  border:1px solid var(--line);color:var(--ink);
  font-size:10.5px;font-weight:800;letter-spacing:.12em;transition:transform .15s;
}
.gal-paint:hover{transform:translateY(-1px)}

/* ---- settings panel ---- */
.gal-settings{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:48;
  width:min(340px,88vw);padding:22px;border-radius:16px;
  background:rgba(10,6,28,.94);backdrop-filter:blur(16px);
  border:1px solid var(--line);box-shadow:0 20px 70px rgba(0,0,0,.6);
}
.gal-settings h4{margin:0 0 16px;letter-spacing:.14em;font-size:13px}
.gal-settings label{display:flex;align-items:center;gap:10px;font-size:12.5px;margin-bottom:14px}
.gal-settings label input[type=range]{flex:1;accent-color:var(--cyan)}
.gal-settings label b{width:36px;text-align:right;font-size:11px;color:var(--cyan)}
.gal-settings .row{gap:8px}
.gal-settings button{
  width:100%;padding:11px;border:none;border-radius:99px;cursor:pointer;
  background:linear-gradient(90deg,var(--cyan),var(--purple));color:#06121a;
  font-weight:800;letter-spacing:.14em;font-size:12px;
}
.gal-touch-btn.fire{border-color:#ff5c5c;color:#ffc2c2}

/* ---- raider warning + hit flash ---- */
.gal-warn{
  position:fixed;top:64px;left:50%;transform:translateX(-50%);z-index:26;
  padding:10px 22px;border-radius:12px;
  background:rgba(40,4,12,.85);backdrop-filter:blur(8px);
  border:1px solid #ff3355;color:#ffb3c2;
  font-size:12px;font-weight:800;letter-spacing:.14em;
  animation:warnblink 1s ease-in-out infinite;
}
@keyframes warnblink{0%,100%{box-shadow:0 0 14px rgba(255,51,85,.4)}50%{box-shadow:0 0 40px rgba(255,51,85,.8)}}
#gal-flash{
  position:fixed;inset:0;z-index:45;pointer-events:none;opacity:0;
  background:radial-gradient(circle, transparent 40%, rgba(255,40,70,.45));
  transition:opacity .12s;
}
#gal-flash.on{opacity:1}

/* ---- Brig free button ---- */
.gal-free{
  margin-top:16px;padding:12px 22px;border:none;border-radius:99px;cursor:pointer;
  background:linear-gradient(90deg,#ffd34d,#ff5cc8);color:#2a1200;
  font-size:12px;font-weight:800;letter-spacing:.12em;
  box-shadow:0 0 24px rgba(255,211,77,.4);transition:transform .15s;
}
.gal-free:hover:not(:disabled){transform:translateY(-2px) scale(1.03)}
.gal-free:disabled{filter:grayscale(.5);cursor:default}

/* ---- NFT radio dash ---- */
.gal-player{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:24;
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:14px;
  background:var(--glass);backdrop-filter:blur(14px);
  border:1px solid var(--line);box-shadow:0 10px 40px rgba(0,0,0,.5);
  max-width:min(520px,92vw);
}
.gp-btn{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  background:rgba(255,255,255,.04);color:var(--ink);font-size:13px;cursor:pointer;
  display:grid;place-items:center;transition:background .2s;
}
.gp-btn:hover{background:rgba(255,255,255,.1)}
.gp-play{
  background:linear-gradient(135deg,var(--cyan),var(--purple));border:none;color:#06121a;
  font-size:15px;box-shadow:0 0 14px rgba(52,231,255,.45);
}
.gp-meta{
  display:flex;flex-direction:column;align-items:flex-start;gap:1px;
  background:none;border:none;color:var(--ink);cursor:pointer;text-align:left;
  min-width:130px;max-width:200px;padding:0 4px;overflow:hidden;
}
#gp-title{font-weight:700;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.gp-sub{font-size:8.5px;letter-spacing:.16em;opacity:.55;white-space:nowrap}
.gp-vol{width:70px;accent-color:var(--cyan);cursor:pointer}
.gp-list{
  position:absolute;bottom:56px;left:50%;transform:translateX(-50%);
  width:min(360px,90vw);max-height:42vh;overflow-y:auto;
  background:rgba(8,5,22,.94);backdrop-filter:blur(16px);
  border:1px solid var(--line);border-radius:14px;padding:6px;
  box-shadow:0 16px 60px rgba(0,0,0,.6);
}
.gp-row{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 12px;border:none;border-radius:8px;background:none;color:var(--ink);
  cursor:pointer;text-align:left;font-size:12.5px;transition:background .15s;
}
.gp-row:hover{background:rgba(155,92,255,.16)}
.gp-row.on{background:linear-gradient(90deg,rgba(52,231,255,.2),rgba(155,92,255,.16))}
.gp-row span{font-size:10px;opacity:.5;width:18px}
.gp-row b{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}

@media (max-width:560px){
  .gp-meta{min-width:90px}
  .gp-vol{display:none}
}

/* live chain ticker */
.chain-ticker{
  position:fixed;right:18px;top:70px;z-index:30;display:flex;flex-direction:column;gap:8px;
  pointer-events:none;max-width:min(320px,78vw);
}
.chain-toast{
  padding:11px 16px;border-radius:12px;font-size:12.5px;font-weight:600;letter-spacing:.04em;
  background:rgba(10,6,28,.88);backdrop-filter:blur(12px);
  border:1px solid var(--cyan);box-shadow:0 8px 30px rgba(0,0,0,.5);
  opacity:0;transform:translateX(16px);transition:all .4s cubic-bezier(.2,.8,.2,1);
}
.chain-toast.in{opacity:1;transform:none}

@media (max-width:560px){
  .gal-brand span{display:none}
  .gal-keys{display:none}
  .gal-speed{width:150px}
}
