/* ===== Aetheria Game Screen Styles ===== */

/* ===== GAME SCREEN ===== */
.game-outer{height:100vh;height:100dvh;padding-top:env(safe-area-inset-top,0px);background:var(--bg)}
.game-container{display:flex;flex-direction:column;height:100%;max-width:900px;margin:0 auto;width:100%}
.status-bar{background:var(--bg2);border-bottom:1px solid var(--border);padding:6px 12px;padding-top:max(6px,env(safe-area-inset-top));display:flex;flex-wrap:wrap;gap:6px 12px;font-size:13px;flex-shrink:0;align-items:center}
.hp{color:var(--red)} .mp{color:var(--blue)} .gold{color:var(--gold)}
.xp{color:var(--accent)} .stamina-info{color:var(--purple)}
.room-info{color:var(--text-dim);margin-left:auto;display:none}
.bar{display:inline-block;width:70px;height:6px;background:#1a1a1a;border-radius:3px;vertical-align:middle;margin-left:4px}
.bar-fill{height:100%;border-radius:3px;transition:width .3s}
.hp .bar-fill{background:var(--red)} .mp .bar-fill{background:var(--blue)} .stamina-info .bar-fill{background:var(--purple)}

/* Output area */
.output{flex:1;overflow-y:auto;padding:12px 16px;line-height:1.7;font-size:17px;
  -webkit-user-select:text;user-select:text;-webkit-overflow-scrolling:touch}
.line{margin-bottom:1px;white-space:pre-wrap;word-wrap:break-word}
.room-name{color:var(--gold);font-weight:bold;font-size:15px}
.room-desc{color:#a0a0a0} .exits{color:var(--accent)} .npc{color:#e07050} .error{color:var(--red)}
.combat,.combat-hit{color:#ff6b6b} .combat-miss{color:#555}
.combat-kill{color:var(--gold);font-weight:bold} .combat-hurt{color:var(--red)}
.combat-dodge{color:var(--accent)} .combat-status{color:#666;font-size:13px}
.heal{color:var(--accent)} .loot{color:var(--gold)}
.chat{color:#7fdbff}
.levelup{color:#ffd700;font-weight:bold;font-size:15px;text-shadow:0 0 8px rgba(255,215,0,0.6),0 0 16px rgba(255,215,0,0.3);animation:celebrate 1.5s ease-out}
.title-new{color:#00e5ff;font-weight:bold;font-size:15px;text-shadow:0 0 8px rgba(0,229,255,0.6),0 0 16px rgba(0,229,255,0.3);animation:celebrate 1.5s ease-out}
.title-evolve{color:#e040fb;font-weight:bold;font-size:15px;text-shadow:0 0 8px rgba(224,64,251,0.6),0 0 16px rgba(224,64,251,0.3);animation:celebrate 1.5s ease-out}
.title-change{color:var(--accent);font-style:italic}
@keyframes celebrate{0%{opacity:0;transform:scale(0.8)}30%{opacity:1;transform:scale(1.05)}50%{text-shadow:0 0 15px rgba(255,215,0,0.9),0 0 30px rgba(255,215,0,0.5)}100%{transform:scale(1);text-shadow:none}}
.death{color:var(--red);font-weight:bold} .script{color:var(--purple)}
.npc-talk{color:var(--blue)} .npc-keywords{color:var(--text-dim)} .say{color:var(--text-bright)} .move{color:var(--accent);font-style:italic}
.bard-soul{color:#d4a850;font-style:italic;line-height:1.9;white-space:pre-line;border-left:2px solid #8b6914;padding-left:10px;margin:4px 0}
.bard-hint{color:#8a7040;font-size:12px;white-space:pre-line}
.stats,.help,.inventory,.shop{color:var(--text)} .quest{color:var(--red)}
.xp-msg{color:var(--accent)} .info{color:var(--text-dim)} .flee{color:var(--accent)}
.flee-fail{color:var(--red)} .equip{color:var(--accent)}
.cmd{color:var(--accent)} .welcome{color:var(--red)}
.quest-story{color:#c8a86e;font-style:italic;line-height:1.8}
.quest-complete{color:var(--gold);font-weight:bold}
.quest-hint{color:var(--green)} .quest-branch{color:var(--gold)} .quest-choice{color:#e0c070}
.quest-desc{color:#a0a0a0;font-style:italic} .quest-progress{color:var(--red)}
.quest-done{color:var(--text-dim)}
.harvest{color:#8bc34a} .craft{color:var(--purple)} .magic{color:var(--blue)}
.recipe-list{color:var(--purple)}

/* ===== CLICKABLE INTERACTIVE TEXT ===== */
.clickable{cursor:pointer;border-bottom:1px dashed;padding:0 1px;transition:all .2s;-webkit-user-select:none;user-select:none}
.clickable:hover,.clickable:active{filter:brightness(1.4)}
.click-dir{color:var(--accent);border-bottom-color:var(--accent-dim)}
.click-dir:active{background:rgba(78,204,163,.15)}
.click-npc{color:#e07050;border-bottom-color:#e0705066}
.click-npc:active{background:rgba(224,112,80,.15)}
.click-mob{color:var(--red);border-bottom-color:var(--red-dim)}
.click-mob:active{background:rgba(233,69,96,.15)}
.click-item{color:var(--gold);border-bottom-color:var(--gold)}
.click-item:active{background:rgba(212,160,60,.15)}
.click-cmd{color:var(--blue);border-bottom-color:var(--blue)}
.click-cmd:active{background:rgba(78,168,222,.15)}
.click-keyword{color:var(--purple);border-bottom-color:var(--purple)}
.click-keyword:active{background:rgba(168,130,220,.15)}

/* ===== QUICK ACTIONS ===== */
.quick-actions{display:none}
.qa-btn{padding:6px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:3px;
  color:var(--text-dim);font-family:var(--font-mono);font-size:12px;letter-spacing:1px;
  cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation}
.qa-btn:hover,.qa-btn:active{border-color:var(--accent-dim);color:var(--accent);background:rgba(78,204,163,.06)}
.qa-btn.qa-combat{border-color:var(--red-dim);color:var(--red)}
.qa-btn.qa-combat:hover,.qa-btn.qa-combat:active{border-color:var(--red);background:rgba(233,69,96,.08)}
.qa-btn.qa-stance-toggle{border-color:var(--accent-dim);color:var(--accent)}
.qa-btn.qa-stance-toggle:hover,.qa-btn.qa-stance-toggle.qa-active{border-color:var(--accent);background:rgba(78,204,163,.12)}
.qa-btn.qa-stance{border-color:#555;color:#aaa;font-size:12px}
.qa-btn.qa-stance.qa-stance-current{border-color:var(--gold);color:var(--gold);background:rgba(212,160,60,.1)}
.qa-btn.qa-magic{border-color:#4e5fa8;color:var(--blue)}
.qa-btn.qa-magic:hover,.qa-btn.qa-magic:active{border-color:var(--blue);background:rgba(78,168,222,.08)}
.qa-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;margin:0 2px}

/* ===== BOTTOM CONTROLS: DPAD + 3 ROWS ===== */
.bottom-controls{background:var(--bg2);border-top:1px solid var(--border);padding:6px 10px;flex-shrink:0;
  display:grid;grid-template-columns:auto 1fr;gap:0 10px;align-items:stretch}
.dpad-area{grid-row:1/4;display:grid;grid-template-columns:36px 36px 36px;grid-template-rows:36px 36px 36px;gap:2px;align-self:center}
.ctrl-row{display:flex;gap:5px;align-items:center;overflow-x:auto;min-height:34px;-webkit-overflow-scrolling:touch}
.ctrl-row::-webkit-scrollbar{display:none}
.ctrl-row1{border-bottom:1px solid var(--border);padding-bottom:4px}
.ctrl-row2{padding:2px 0}
.ctrl-row3{border-top:1px solid var(--border);padding-top:4px}
.dpad{display:contents}
.dpad-btn{background:var(--bg3);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);
  font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.dpad-btn:hover,.dpad-btn:active{border-color:var(--accent-dim);color:var(--accent);background:rgba(78,204,163,.08)}
.dpad-btn:active{transform:scale(.92)}
.dpad-btn.dpad-center{font-size:11px;letter-spacing:1px;color:var(--text-dim)}
.dpad-btn.dpad-empty{visibility:hidden;border:none;background:none}
.dpad-btn.dpad-disabled{opacity:.2;pointer-events:none}
.input-section{display:contents}
.input-bar{display:flex;gap:6px;align-items:center}
.input-bar .prompt{color:var(--accent);line-height:38px;font-size:16px;flex-shrink:0}
.input-bar input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text-bright);
  padding:10px 12px;border-radius:2px;font-family:var(--font-mono);font-size:15px;outline:none;min-width:0}
.input-bar input:focus{border-color:var(--accent-dim)}
.input-hint{font-size:10px;color:#333;text-align:center;letter-spacing:1px;display:none}
.logout-btn{background:none;border:1px solid #2a2a2a;color:#555;padding:2px 10px;border-radius:2px;
  cursor:pointer;font-size:12px;margin-left:8px;font-family:var(--font-mono);letter-spacing:1px}
.logout-btn:hover{color:var(--red);border-color:var(--red-dim)}

/* ===== STATUS BAR TWO-ROW LAYOUT ===== */
.status-row1{display:flex;align-items:center;gap:10px;width:100%;padding-bottom:4px;border-bottom:1px solid var(--border)}
.status-row2{display:flex;align-items:center;gap:14px;width:100%;padding-top:4px;flex-wrap:wrap}
.player-title{font-family:var(--font-body);font-size:12px;color:var(--purple);letter-spacing:1px;
  padding:1px 8px;border:1px solid rgba(176,124,216,.25);border-radius:2px;flex-shrink:0}
.title-cycle{position:relative;min-width:60px;max-width:200px;height:20px;flex-shrink:0;overflow:hidden}
.title-cycle-inner{position:absolute;left:0;top:0;white-space:nowrap;
  transition:opacity .5s ease,transform .5s ease}
.title-cycle-inner.fade-out{opacity:0;transform:translateY(-8px)}
.title-cycle-inner.fade-in{opacity:1;transform:translateY(0)}
.title-tag{font-family:var(--font-body);font-size:11px;color:var(--purple);letter-spacing:0.5px;
  padding:1px 6px;border:1px solid rgba(176,124,216,.2);border-radius:2px;white-space:nowrap;flex-shrink:0}
.title-tag.title-new-flash{animation:titleFlash 2s ease-out;border-color:rgba(0,229,255,.6)}
@keyframes titleFlash{0%{color:#00e5ff;text-shadow:0 0 8px rgba(0,229,255,.8);border-color:rgba(0,229,255,.8)}
  50%{color:#00e5ff;text-shadow:0 0 4px rgba(0,229,255,.4);border-color:rgba(0,229,255,.5)}
  100%{color:var(--purple);text-shadow:none;border-color:rgba(176,124,216,.2)}}
.player-name{font-family:var(--font-display);font-size:14px;color:var(--text-bright);letter-spacing:2px;flex-shrink:0}
.player-lv{font-size:12px;color:var(--accent);letter-spacing:1px;flex-shrink:0}
.player-xp{font-size:11px;color:var(--text-dim);flex-shrink:0}
.status-row1 .logout-btn{margin-left:auto}
.room-info-r2{color:var(--text-dim);margin-left:auto;font-size:12px;letter-spacing:1px;flex-shrink:0;display:flex}

/* ===== EQUIP PANEL OVERLAY ===== */
.equip-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:center;justify-content:center;
  animation:fadeIn .2s ease}
.equip-panel{background:var(--bg2);border:1px solid var(--border);border-radius:4px;width:90%;max-width:460px;
  max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.equip-panel-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}
.equip-panel-header h3{font-family:var(--font-display);font-size:14px;color:var(--text-bright);letter-spacing:3px;flex:1}
.equip-panel-close{background:none;border:1px solid var(--border);color:var(--text-dim);width:28px;height:28px;
  border-radius:2px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.equip-panel-close:hover{border-color:var(--red-dim);color:var(--red)}
.equip-panel-body{flex:1;overflow-y:auto;padding:12px 16px}
.equip-section{margin-bottom:16px}
.equip-section-title{font-size:11px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px;
  padding-bottom:4px;border-bottom:1px solid var(--border)}
.equip-slot{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-bottom:4px;background:var(--bg3);
  border:1px solid var(--border);border-radius:2px;cursor:pointer;transition:all .2s}
.equip-slot:hover{border-color:var(--accent-dim);background:rgba(78,204,163,.04)}
.equip-slot-label{font-size:11px;color:var(--text-dim);width:50px;flex-shrink:0;letter-spacing:1px}
.equip-slot-item{font-size:13px;color:var(--text-bright);flex:1}
.equip-slot-empty{font-size:12px;color:#333;font-style:italic}
.equip-slot-action{font-size:10px;color:var(--accent-dim);letter-spacing:1px;flex-shrink:0}
.equip-inv-item{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-bottom:4px;background:var(--bg3);
  border:1px solid var(--border);border-radius:2px;cursor:pointer;transition:all .2s}
.equip-inv-item:hover{border-color:var(--gold);background:rgba(212,160,60,.06)}
.equip-inv-item .item-name{font-size:13px;color:var(--gold);flex:1}
.equip-inv-item .item-action{font-size:10px;color:var(--gold);letter-spacing:1px;flex-shrink:0}
.equip-loading{text-align:center;color:var(--text-dim);padding:20px;font-size:12px}
.equip-raw{font-size:12px;line-height:1.6;color:var(--text);white-space:pre-wrap;padding:8px 0}

/* ===== MAP OVERLAY ===== */
.map-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:800;display:flex;align-items:center;justify-content:center}
.map-panel{background:var(--bg2);border:1px solid var(--border);border-radius:4px;width:96vw;max-width:620px;max-height:92vh;display:flex;flex-direction:column}
.map-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.map-panel-header h3{font-family:var(--font-display);font-size:18px;letter-spacing:2px;color:var(--text-bright);margin:0}
.map-floor-nav{display:flex;align-items:center;gap:8px}
.map-floor-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);width:30px;height:30px;border-radius:2px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}
.map-floor-btn:hover:not(:disabled){border-color:var(--accent-dim);color:var(--accent)}
.map-floor-btn:disabled{opacity:.2;cursor:default}
.map-floor-label{font-size:15px;color:var(--text-dim);min-width:50px;text-align:center}
.map-panel-close{background:none;border:none;color:var(--text-dim);font-size:26px;cursor:pointer;padding:0 4px}
.map-panel-close:hover{color:var(--text)}
.map-body{padding:12px;overflow:auto;flex:1}
.map-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);gap:4px;aspect-ratio:1;max-width:480px;margin:0 auto}
.map-cell{position:relative;border:1px solid transparent;border-radius:2px;display:flex;align-items:center;justify-content:center;min-height:0;aspect-ratio:1;font-size:13px;text-align:center;padding:3px;overflow:hidden;word-break:break-all;line-height:1.2}
.map-cell.visited{border-color:var(--accent-dim);background:rgba(78,204,163,.06);color:var(--text)}
.map-cell.known{border:1px dashed #333;background:rgba(255,255,255,.02);color:var(--text-dim);font-size:12px}
.map-cell.current{border-color:var(--accent);background:rgba(78,204,163,.15);color:var(--text-bright);box-shadow:0 0 6px rgba(78,204,163,.3)}
.map-cell.current::after{content:'★';position:absolute;top:2px;right:4px;font-size:11px;color:var(--accent)}
.map-cell.empty{border-color:transparent}
.map-conn{position:absolute;background:var(--accent-dim);z-index:1;pointer-events:none;opacity:.4}
.map-conn-h{width:3px;height:1px;left:50%;top:-2px;transform:translateX(-50%)}
.map-conn-v{width:1px;height:3px;top:50%;left:-2px;transform:translateY(-50%)}
.map-legend{display:flex;gap:14px;justify-content:center;padding:0 0 10px;font-size:13px;color:var(--text-dim)}
.map-legend span{display:flex;align-items:center;gap:5px}
.map-legend-box{width:14px;height:14px;border-radius:1px;display:inline-block}
.map-legend-visited{border:1px solid var(--accent-dim);background:rgba(78,204,163,.06)}
.map-legend-known{border:1px dashed #333;background:rgba(255,255,255,.02)}
.map-legend-current{border:1px solid var(--accent);background:rgba(78,204,163,.15)}

/* ===== GAME MOBILE RESPONSIVE ===== */
@media(max-width:600px){
  .status-bar{font-size:11px;gap:3px 8px;padding:5px 8px}
  .player-title{font-size:10px;padding:1px 5px}
  .title-cycle{max-width:120px}
  .title-tag{font-size:10px;padding:1px 4px}
  .player-name{font-size:11px}
  .room-info-r2{display:none}
  .output{font-size:14px;padding:8px 10px;line-height:1.6}
  .quick-actions{padding:5px 8px;gap:5px}
  .qa-btn{padding:7px 11px;font-size:11px}
  .bottom-controls{padding:6px 8px;gap:6px}
  .dpad-area{grid-template-columns:32px 32px 32px;grid-template-rows:32px 32px 32px}
  .dpad-btn{font-size:12px}
  .input-bar input{padding:8px 10px;font-size:14px}
  .input-hint{display:block}
  .room-info{display:none}
}
@media(max-width:380px){
  .dpad-area{grid-template-columns:28px 28px 28px;grid-template-rows:28px 28px 28px}
}
