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

/* ===== GAME SCREEN ===== */
.game-outer{height:100vh;height:100dvh;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 8px;padding-top:max(6px,env(safe-area-inset-top));display:flex;flex-wrap:wrap;gap:4px 8px;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)}

/* Mini stat bars */
.stat-bars{display:flex;gap:4px;align-items:center;cursor:pointer;padding:2px 0}
.mini-bar{position:relative;width:42px;height:8px;background:#1a1a1a;border-radius:4px;overflow:hidden}
.mini-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}
.hp-bar .mini-bar-fill{background:var(--red)}
.mp-bar .mini-bar-fill{background:var(--blue)}
.st-bar .mini-bar-fill{background:var(--purple)}
.mini-bar-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:7px;color:#fff;white-space:nowrap;text-shadow:0 0 3px rgba(0,0,0,.8);line-height:1}

/* 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;padding:1px 4px;border-radius:2px;transition:all .2s;-webkit-user-select:none;user-select:none}
.click-dir{color:var(--accent);background:rgba(78,204,163,.1)}
.click-dir:active{background:rgba(78,204,163,.25)}
.click-npc{color:var(--blue);background:rgba(78,168,222,.1)}
.click-npc:active{background:rgba(78,168,222,.25)}
.click-npc-merchant{color:var(--gold);background:rgba(212,160,60,.1)}
.click-npc-merchant:active{background:rgba(212,160,60,.25)}
.click-mob{color:var(--red);background:rgba(233,69,96,.1)}
.click-mob:active{background:rgba(233,69,96,.25)}
.click-mob.lv-high{color:#ff4444;background:rgba(255,68,68,.15)}
.click-mob.lv-mid{color:#e94560;background:rgba(233,69,96,.1)}
.click-mob.lv-low{color:#b05060;background:rgba(176,80,96,.08)}
.click-item{color:var(--gold);background:rgba(212,160,60,.1)}
.click-item:active{background:rgba(212,160,60,.25)}
.click-item.q-common{color:#b0a080}
.click-item.q-uncommon{color:#4caf50;background:rgba(76,175,80,.1)}
.click-item.q-rare{color:#2196f3;background:rgba(33,150,243,.1)}
.click-item.q-epic{color:#9c27b0;background:rgba(156,39,176,.1)}
.click-item.q-unique{color:#ff9800;background:rgba(255,152,0,.12)}
.click-harvest{color:#8bc34a;background:rgba(139,195,74,.1)}
.click-harvest:active{background:rgba(139,195,74,.25)}
.click-harvest.rare{color:#aed581;background:rgba(174,213,129,.12)}
.click-potion{color:var(--purple);background:rgba(168,130,220,.1)}
.click-potion:active{background:rgba(168,130,220,.25)}
.click-material{color:#6a8050;background:rgba(106,128,80,.08)}
.click-cmd{color:var(--blue);background:rgba(78,168,222,.08)}
.click-cmd:active{background:rgba(78,168,222,.2)}
.click-keyword{color:var(--purple);background:rgba(168,130,220,.08)}
.click-keyword:active{background:rgba(168,130,220,.2)}
.click-loot{color:var(--gold);background:rgba(212,160,60,.12);cursor:pointer}
.click-loot:active{background:rgba(212,160,60,.3)}

/* ===== OUTPUT WRAP ===== */
.output-wrap{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}

/* ===== CONTINUE BUTTON ===== */
.continue-btn{position:absolute;bottom:10px;right:10px;z-index:5;
  padding:7px 18px;background:rgba(5,5,7,0.92);
  border:1px solid var(--accent-dim);border-radius:2px;
  color:var(--accent);font-family:var(--font-mono);font-size:11px;letter-spacing:3px;
  cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;
  animation:continuePulse 2.5s ease-in-out infinite}
@keyframes continuePulse{0%,100%{box-shadow:0 0 0 0 rgba(78,204,163,0)}50%{box-shadow:0 0 10px 2px rgba(78,204,163,0.2)}}

/* ===== LOGOUT BUTTON ===== */
.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{display:inline-flex;flex-shrink:0}
.title-cycle-inner{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}

/* ===== 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)}

/* ===== ACTION CARD ===== */
.action-card{background:var(--bg2);border-top:1px solid var(--border);padding:6px 8px;flex-shrink:0;min-height:80px;max-height:35vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.action-card::-webkit-scrollbar{display:none}
.action-card-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 6px;border-bottom:1px solid var(--border);margin-bottom:6px}
.action-card-entity{font-family:var(--font-mono);font-size:13px;letter-spacing:1px;color:var(--text-bright)}
.action-card-close{background:none;border:1px solid var(--border);color:var(--text-dim);width:26px;height:26px;border-radius:2px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}
.action-card-close:active{border-color:var(--red-dim);color:var(--red)}
.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.action-grid.single-col{grid-template-columns:1fr}

/* ===== ACTION BUTTONS ===== */
.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)}
.action-btn{padding:10px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-family:var(--font-mono);font-size:13px;letter-spacing:1px;cursor:pointer;transition:all .2s;white-space:nowrap;text-align:left;min-height:44px;display:flex;align-items:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.action-btn:active{border-color:var(--accent-dim);color:var(--accent);background:rgba(78,204,163,.08);transform:scale(.96)}
.action-btn.btn-combat{border-color:var(--red-dim);color:var(--red)}
.action-btn.btn-combat:active{border-color:var(--red);background:rgba(233,69,96,.1)}
.action-btn.btn-dir{border-color:var(--accent-dim);color:var(--accent)}
.action-btn.btn-npc{border-color:rgba(78,168,222,.3);color:var(--blue)}
.action-btn.btn-harvest{border-color:rgba(139,195,74,.3);color:#8bc34a}
.action-btn.btn-gold{border-color:rgba(212,160,60,.3);color:var(--gold)}
.action-btn.btn-magic{border-color:rgba(168,130,220,.3);color:var(--purple)}
.action-btn.btn-danger{border-color:var(--red-dim);color:var(--red)}
.action-btn.btn-flash{animation:btnFlash 1.5s ease-in-out infinite}
@keyframes btnFlash{0%,100%{opacity:1}50%{opacity:.5;border-color:var(--red)}}

/* ===== COMBAT QUICK BAR ===== */
.combat-quickbar{display:flex;gap:5px;overflow-x:auto;padding:4px 0;border-top:1px solid var(--border);margin-top:4px;-webkit-overflow-scrolling:touch}
.combat-quickbar::-webkit-scrollbar{display:none}

/* ===== BOTTOM CONTROLS ===== */
.bottom-controls{background:var(--bg2);border-top:1px solid var(--border);padding:6px 10px;flex-shrink:0;display:flex;flex-direction:column;gap:4px;padding-bottom:max(6px,env(safe-area-inset-bottom))}

/* ===== SYSTEM BAR ===== */
.system-bar{display:flex;background:var(--bg);border-top:1px solid var(--border);flex-shrink:0;padding-bottom:max(4px,env(safe-area-inset-bottom))}
.system-bar-btn{flex:1;background:none;border:none;color:var(--text-dim);font-family:var(--font-mono);font-size:11px;letter-spacing:1px;padding:8px 0;cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:color .2s}
.system-bar-btn:active{color:var(--accent)}
.system-bar-btn.active{color:var(--accent);border-top:2px solid var(--accent)}

/* ===== GENERIC OVERLAY PANEL ===== */
.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:100;display:flex;flex-direction:column;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.panel-container{flex:1;display:flex;flex-direction:column;max-width:520px;width:100%;margin:0 auto;padding-top:max(8px,env(safe-area-inset-top))}
.panel-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.panel-title{font-family:var(--font-display);font-size:15px;color:var(--text-bright);letter-spacing:3px;flex:1}
.panel-close{background:none;border:1px solid var(--border);color:var(--text-dim);width:32px;height:32px;border-radius:2px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.panel-close:active{border-color:var(--red-dim);color:var(--red)}
.panel-body{flex:1;overflow-y:auto;padding:12px 16px;background:var(--bg);-webkit-overflow-scrolling:touch}

/* ===== BAG OVERLAY ===== */
.bag-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg2);overflow-x:auto;flex-shrink:0}
.bag-tabs::-webkit-scrollbar{display:none}
.bag-tab{padding:8px 14px;font-family:var(--font-mono);font-size:11px;letter-spacing:1px;color:var(--text-dim);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;flex-shrink:0}
.bag-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.bag-item{display:flex;align-items:center;gap:8px;padding:10px 8px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .15s}
.bag-item:active{background:rgba(78,204,163,.04)}
.bag-item-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center}
.bag-item-name{flex:1;font-size:13px;color:var(--text)}
.bag-item-qty{font-size:12px;color:var(--text-dim);flex-shrink:0}
.bag-item-equipped{font-size:10px;color:var(--gold);border:1px solid rgba(212,160,60,.3);padding:1px 6px;border-radius:2px;letter-spacing:1px;flex-shrink:0}
.bag-item-detail{padding:8px 8px 12px 36px;border-bottom:1px solid rgba(255,255,255,.05);background:var(--bg2);font-size:12px;color:var(--text-dim);line-height:1.8}
.bag-item-detail .bag-actions{display:flex;gap:6px;margin-top:8px}
.bag-action-btn{padding:6px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:2px;color:var(--text-dim);font-family:var(--font-mono);font-size:11px;letter-spacing:1px;cursor:pointer}
.bag-action-btn:active{border-color:var(--accent-dim);color:var(--accent)}
.bag-action-btn.btn-danger:active{border-color:var(--red-dim);color:var(--red)}

/* ===== STATS OVERLAY ===== */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:2px;padding:10px 12px}
.stat-label{font-size:10px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}
.stat-value{font-size:16px;color:var(--text-bright);font-family:var(--font-mono)}
.stat-bar{height:4px;background:rgba(255,255,255,.05);border-radius:2px;margin-top:6px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:2px;transition:width .3s}

/* ===== SOCIAL OVERLAY ===== */
.social-input-group{display:flex;gap:6px;margin-bottom:12px}
.social-mode-btn{padding:6px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:2px;color:var(--text-dim);font-family:var(--font-mono);font-size:11px;cursor:pointer;flex-shrink:0}
.social-mode-btn.active{border-color:var(--accent-dim);color:var(--accent)}
.social-input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text-bright);padding:8px 10px;border-radius:2px;font-family:var(--font-mono);font-size:14px;outline:none;min-width:0}
.social-input:focus{border-color:var(--accent-dim)}
.social-send-btn{padding:8px 16px;background:var(--bg3);border:1px solid var(--accent-dim);border-radius:2px;color:var(--accent);font-family:var(--font-mono);font-size:12px;cursor:pointer;flex-shrink:0}
.social-player-list{margin-top:12px}
.social-player{padding:8px;font-size:13px;color:var(--text);border-bottom:1px solid rgba(255,255,255,.03)}
.social-player-you{color:var(--accent)}
.social-player-here{color:var(--gold)}

/* ===== MORE MENU OVERLAY ===== */
.more-menu-item{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text);font-size:14px;cursor:pointer;transition:background .15s}
.more-menu-item:active{background:rgba(78,204,163,.04)}
.more-menu-item.danger{color:var(--red)}

/* ===== DESKTOP TEXT INPUT ===== */
.desktop-input{display:flex;gap:6px;align-items:center;padding:6px 10px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.desktop-input .prompt{color:var(--accent);font-size:16px;flex-shrink:0}
.desktop-input input{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text-bright);padding:8px 10px;border-radius:2px;font-family:var(--font-mono);font-size:15px;outline:none;min-width:0}
.desktop-input input:focus{border-color:var(--accent-dim)}

/* ===== GAME MOBILE RESPONSIVE ===== */
@media(max-width:600px){
  /* Status Bar mobile styles */
  .status-bar{
    display:flex;flex-direction:row;flex-wrap:nowrap;
    align-items:center;gap:0 7px;
    padding:4px 8px;
    padding-top:max(4px,env(safe-area-inset-top));
    font-size:11px;overflow-x:auto;
  }
  .status-bar::-webkit-scrollbar{display:none}
  .title-cycle{max-width:80px;height:16px;flex-shrink:0}
  .title-tag{font-size:10px;padding:1px 4px}
  .player-title{font-size:10px;padding:1px 4px;flex-shrink:0}
  .player-name{font-size:11px;letter-spacing:0.5px;flex-shrink:0}
  .player-lv{font-size:10px;flex-shrink:0}
  .hp,.mp,.stamina-info,.gold{font-size:10px;flex-shrink:0}
  .room-info-r2{display:none}
  .logout-btn{margin-left:auto;flex-shrink:0;font-size:11px;padding:2px 7px}

  /* Output */
  .output{font-size:15px;padding:8px 10px;line-height:1.65}

  /* Action Card */
  .action-card{padding:5px 8px;min-height:70px}
  .action-grid{gap:4px}
  .action-btn{padding:8px 10px;font-size:12px;min-height:42px}

  /* System Bar */
  .system-bar-btn{font-size:10px;padding:7px 0}

  /* Desktop input hidden on mobile */
  .desktop-input{display:none}
}

/* ===== LANDSCAPE MEDIA QUERY ===== */
@media(max-height:500px) and (orientation:landscape){
  .status-bar{padding:3px 10px;font-size:11px;flex-direction:row;flex-wrap:nowrap;gap:0 10px;align-items:center}
  .room-info-r2{display:none}
  .output{font-size:13px;line-height:1.5;padding:5px 10px}
  .bottom-controls{padding:3px 8px;gap:0 6px}
}
