/* PLUNDR game UI */
html,body{height:100%;overflow:hidden}
#game3d{position:fixed;inset:0;background:linear-gradient(180deg,#3A2440 0%,#8a3d4a 26%,var(--coral) 40%,var(--gold) 52%,#f8d488 57%,#1c4258 60%,var(--navy2) 78%,var(--deep) 100%)}
#game3d canvas{width:100%;height:100%;display:block}

/* loading */
#loader{position:fixed;inset:0;z-index:60;background:var(--deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .5s}
#loader img{width:110px;height:110px;animation:bobble 2.4s ease-in-out infinite}
@keyframes bobble{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}
#loader .bar{width:min(320px,70vw);height:10px;border:1px solid var(--line);border-radius:99px;overflow:hidden}
#loader .bar i{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--gold-d),var(--gold));transition:width .2s}
#loader p{font-family:var(--dispn);letter-spacing:.1em;font-size:.85rem;color:rgba(243,233,210,.7)}

/* HUD */
.hud{position:fixed;z-index:20;font-family:var(--dispn);letter-spacing:.04em;pointer-events:none}
.hud *{pointer-events:auto}
#hudTL{top:14px;left:14px;display:flex;flex-direction:column;gap:8px}
.hpwrap{display:flex;align-items:center;gap:10px;background:rgba(7,18,30,.72);border:1px solid var(--line);border-radius:12px;padding:8px 12px}
.hpbar{width:150px;height:12px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}
.hpbar i{display:block;height:100%;width:100%;background:linear-gradient(90deg,#4caf7d,var(--teal));transition:width .2s}
.hpbar.low i{background:linear-gradient(90deg,#a33,var(--coral))}
.stat{display:flex;align-items:center;gap:8px;background:rgba(7,18,30,.72);border:1px solid var(--line);border-radius:12px;padding:8px 12px;font-size:.95rem}
.stat img{width:20px;height:20px}
.stat b{color:var(--gold);font-family:var(--disp);font-weight:400}
#hudTR{top:14px;right:14px;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
#hudTR .hrow{display:flex;gap:10px;align-items:center}
#mini{background:rgba(7,18,30,.72);border:1px solid var(--line);border-radius:14px;display:block}
.hbtn{background:rgba(7,18,30,.8);color:var(--parch);border:1px solid var(--line);border-radius:12px;padding:10px 14px;cursor:pointer;font-family:var(--dispn);letter-spacing:.05em;font-size:.9rem}
.hbtn:hover{border-color:var(--gold);color:var(--gold)}
#compass{display:flex;align-items:center;gap:8px;background:rgba(7,18,30,.72);border:1px solid var(--line);border-radius:12px;padding:8px 12px;font-size:.85rem}
#compArrow{display:inline-block;color:var(--gold);font-family:var(--disp);transition:transform .2s linear}

#prompt{position:fixed;left:50%;top:64%;transform:translateX(-50%);z-index:20;background:rgba(7,18,30,.85);border:1px solid var(--gold);color:var(--gold);font-family:var(--disp);padding:12px 22px;border-radius:14px;letter-spacing:.06em;display:none}
#toast{position:fixed;left:50%;top:12%;transform:translateX(-50%);z-index:24;background:rgba(7,18,30,.9);border:1px solid var(--line);color:var(--parch);font-family:var(--dispn);padding:10px 20px;border-radius:12px;display:none;max-width:80vw;text-align:center}

/* reload */
#reload{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);width:180px;height:10px;border:1px solid var(--line);border-radius:99px;overflow:hidden;background:rgba(7,18,30,.7);z-index:20}
#reload i{display:block;height:100%;width:100%;background:linear-gradient(90deg,var(--gold-d),var(--gold))}
#reload.ready i{background:var(--teal)}

/* damage flash */
#dmg{position:fixed;inset:0;z-index:15;pointer-events:none;box-shadow:inset 0 0 120px 40px rgba(232,96,76,.0);transition:box-shadow .1s}
#dmg.hit{box-shadow:inset 0 0 140px 60px rgba(232,96,76,.55)}

/* chat */
#chat{position:fixed;right:14px;bottom:14px;width:min(360px,92vw);z-index:30;background:rgba(7,18,30,.94);border:1px solid var(--line);border-radius:18px;display:none;flex-direction:column;max-height:min(520px,72vh)}
#chat.open{display:flex}
#chat .tabs{display:flex;border-bottom:1px solid var(--line)}
#chat .tabs button{flex:1;background:none;border:none;color:rgba(243,233,210,.6);font-family:var(--dispn);letter-spacing:.05em;padding:12px 6px;cursor:pointer;border-bottom:2px solid transparent;font-size:.85rem}
#chat .tabs button.on{color:var(--gold);border-bottom-color:var(--gold)}
#chat .tabs img{width:26px;height:26px;display:block;margin:0 auto 4px}
#chatLog{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;min-height:160px}
.msg{max-width:86%;padding:9px 13px;border-radius:14px;font-size:.9rem;line-height:1.45}
.msg.you{align-self:flex-end;background:rgba(53,196,169,.16);border:1px solid rgba(53,196,169,.4)}
.msg.crew{align-self:flex-start;background:var(--navy2);border:1px solid var(--line)}
.msg.crew b{color:var(--gold);font-family:var(--dispn);font-weight:400;letter-spacing:.06em;display:block;margin-bottom:3px;font-size:.75rem;text-transform:uppercase}
#chatForm{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
#chatIn{flex:1;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;color:var(--parch);padding:10px 12px;font-family:var(--body);font-size:.9rem;outline:none}
#chatIn:focus{border-color:var(--teal)}
#chatSend{background:linear-gradient(180deg,var(--gold),var(--gold-d));border:none;border-radius:10px;padding:0 16px;font-family:var(--disp);color:var(--deep);cursor:pointer}

/* port panel */
#port{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:32;width:min(560px,94vw);max-height:86vh;overflow-y:auto;background:rgba(7,18,30,.96);border:1px solid var(--gold);border-radius:20px;padding:26px;display:none}
#port.open{display:block}
#port h2{font-size:1.4rem}
#port .row{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
#lb{width:100%;margin-top:14px;border-collapse:collapse;font-size:.9rem}
#lb th{font-family:var(--dispn);letter-spacing:.08em;color:var(--teal);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line);font-weight:400;font-size:.75rem;text-transform:uppercase}
#lb td{padding:8px 10px;border-bottom:1px solid rgba(245,185,66,.08)}
#lb td.sc{color:var(--gold);font-family:var(--dispn)}

/* game over */
#over{position:fixed;inset:0;z-index:40;background:rgba(7,18,30,.88);display:none;align-items:center;justify-content:center;padding:20px}
#over.open{display:flex}
#over .panel{background:var(--navy2);border:1px solid var(--coral);border-radius:22px;padding:36px;max-width:480px;width:100%;text-align:center}
#over h2{color:var(--coral)}
#over .nums{display:flex;gap:14px;justify-content:center;margin:20px 0}
#over .nums .cell{background:rgba(7,18,30,.7);border:1px solid var(--line);border-radius:14px;padding:14px 20px}
#over .nums .num{font-family:var(--disp);font-size:1.6rem;color:var(--gold)}
#over .nums .lab{font-family:var(--dispn);font-size:.72rem;letter-spacing:.1em;color:rgba(243,233,210,.6)}
#nameIn{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:12px;color:var(--parch);padding:13px 14px;font-family:var(--dispn);letter-spacing:.06em;font-size:1rem;outline:none;text-align:center;margin:8px 0 14px}
#nameIn:focus{border-color:var(--gold)}
#overMsg{font-size:.85rem;color:rgba(243,233,210,.65);min-height:1.2em;margin-bottom:10px}

/* touch controls */
#touch{display:none;position:fixed;inset:auto 0 0 0;z-index:22;pointer-events:none}
#touch .tc{position:fixed;bottom:20px;pointer-events:auto;user-select:none;-webkit-user-select:none;touch-action:none}
#touch button{width:64px;height:64px;border-radius:18px;border:1px solid var(--line);background:rgba(7,18,30,.75);color:var(--parch);font-family:var(--disp);font-size:1.2rem}
#touch button:active{border-color:var(--gold);color:var(--gold)}
#tcL{left:16px;display:grid;grid-template-columns:64px 64px;gap:10px}
#tcR{right:16px;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
#tcFire{width:84px!important;height:84px!important;border-radius:50%!important;border-color:var(--coral)!important;color:var(--coral)!important}
@media (hover:none) and (pointer:coarse){#touch{display:block}#reload{bottom:120px}}

@media(max-width:640px){
  #mini{width:104px;height:104px}
  .hpbar{width:100px}
  #hudTR .hbtn{padding:8px 10px;font-size:.8rem}
  #chat{right:8px;bottom:8px}
}
