.player-kbd-input {
  display: none !important;
}

.player-shell {
  position: relative;
}

.player-shell {
  /* Keep each page's intended sizing, but cap it to the real visual viewport height. */
  max-height: var(--dos-overlay-vh, 100vh) !important;
}

.player-shell .player-host {
  width: 100% !important;
  height: 100% !important;
}

.player-shell .player-host > div,
.player-shell .player-host .dosbox-container {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
}

.player-shell .player-host canvas {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  display: block !important;
  image-rendering: pixelated;
}

/* Gold editor: always preserve full frame without cropping. */
#goldPlayerOverlay .player-shell .player-host > div,
#goldPlayerOverlay .player-shell .player-host .dosbox-container,
#goldPlayerOverlay .player-shell .player-host canvas {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
}

#goldPlayerOverlay .player-shell .player-host .dosbox-container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

#goldPlayerOverlay .player-shell .player-host canvas {
  object-fit: contain !important;
  display: block !important;
}

.player-controls-main,
.player-controls-dpad {
  display: grid;
  gap: 6px;
}

.player-kbd-drawer {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 28;
  padding: 8px;
  border-top: 1px solid rgba(180, 210, 255, 0.26);
  background: rgba(5, 11, 18, 0.96);
  box-shadow: 0 -14px 28px rgba(0, 0, 0, 0.36);
  transform: translateY(calc(100% + 10px));
  transition: transform 0.24s ease;
  max-height: min(48vh, 360px);
  overflow-y: auto;
}

.player-kbd-drawer.open {
  transform: translateY(0);
}

.player-kbd-row {
  display: flex;
  gap: 6px;
  margin-bottom: 6px;
}

.player-kbd-row:last-child {
  margin-bottom: 0;
}

.player-kbd-key {
  flex: 1 1 0;
  min-height: 34px;
  border: 1px solid rgba(210, 228, 248, 0.24);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.11);
  color: #f4fbff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1;
  cursor: pointer;
  user-select: none;
  touch-action: manipulation;
}

.player-kbd-key:hover {
  background: rgba(255, 255, 255, 0.18);
}

.player-kbd-key.active {
  background: rgba(102, 255, 179, 0.36);
  border-color: rgba(102, 255, 179, 0.6);
  color: #ecfff3;
}

.player-kbd-key.w2 {
  flex: 2 1 0;
}

.player-kbd-key.w3 {
  flex: 3 1 0;
}

.player-kbd-key.w4 {
  flex: 4 1 0;
}

.player-fullscreen-btn {
  display: inline-block;
}

@media (max-width: 900px) {
  .player-fullscreen-btn {
    display: none !important;
  }

  .player-shell .player-controls {
    position: absolute !important;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 26;
    display: flex !important;
    justify-content: space-between;
    align-items: flex-end;
    gap: 10px;
    padding: 8px;
    border: 0 !important;
    background: linear-gradient(to top, rgba(4, 10, 16, 0.92), rgba(4, 10, 16, 0.12)) !important;
    pointer-events: auto;
  }

  .player-shell .player-controls-main,
  .player-shell .player-controls-dpad {
    display: grid;
    gap: 6px;
  }

  .player-shell .player-controls-main {
    max-width: min(56vw, 300px);
  }

  .player-shell .player-controls-dpad {
    justify-items: end;
    margin-left: auto;
  }

  .player-shell .player-controls-main .player-control-row {
    display: flex;
    gap: 6px;
  }

  .player-shell .player-controls-main .player-key-btn {
    min-width: 52px;
  }

  .player-shell .player-controls-dpad .dpad-grid {
    grid-template-columns: repeat(3, 56px);
    grid-template-rows: repeat(3, 48px);
  }

  .player-shell .player-controls-dpad .player-key-btn {
    min-width: 56px;
  }

  .player-kbd-drawer {
    max-height: 42vh;
  }

  .player-kbd-key {
    min-height: 36px;
    font-size: 10px;
  }
}

@media (max-width: 900px) and (orientation: portrait) {
  .player-shell .player-host canvas {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: none !important;
  }
}

@media (max-width: 900px) and (orientation: landscape) {
  .player-shell .player-controls {
    padding: 8px 12px;
  }

  .player-shell .player-controls-main {
    max-width: min(36vw, 260px);
    justify-items: start;
  }

  .player-shell .player-controls-dpad {
    max-width: min(32vw, 220px);
    justify-items: end;
  }
}

/* Gold editor: keep controls in flow on mobile so they do not cover/crop game bottom. */
@media (max-width: 900px) {
  #goldPlayerOverlay .player-shell {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }

  #goldPlayerOverlay .player-shell .player-host {
    min-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  #goldPlayerOverlay .player-shell .player-controls {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    z-index: auto !important;
    border-top: 1px solid rgba(180, 210, 255, 0.26) !important;
    background: rgba(4, 10, 16, 0.9) !important;
  }

}
