/* HYPHSWORLD Vault Mobile Lock Fix
   Keeps the Lobby/Vault page inside the phone viewport without deleting the existing style system. */

html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

body.vault-page {
  min-width: 0;
  max-width: 100vw;
  touch-action: pan-y;
}

body.vault-page * {
  max-width: 100%;
}

.vault-header,
.vault-main,
.vault-stage,
.vault-intro,
.live-pad,
.console-card,
.gate-arcade,
.gate-arcade-card,
.scan-window {
  min-width: 0;
}

.vault-logo,
.vault-nav,
.vault-nav a,
.duo-card,
.gate-game-panel,
.console-card,
.input-shell,
.input-shell input,
.access-core,
.scan-window,
.scan-visual {
  min-width: 0;
}

.vault-logo strong,
.vault-intro h1,
.console-copy h2,
.gate-arcade h2,
.gate-game-panel h3,
.duo-card strong {
  overflow-wrap: anywhere;
  word-break: normal;
}

@media (max-width: 900px) {
  .vault-header {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    gap: 14px;
    padding: 16px 14px 10px;
  }

  .vault-logo {
    width: 100%;
  }

  .vault-logo span {
    font-size: 10px;
    letter-spacing: .16em;
  }

  .vault-logo strong {
    font-size: clamp(38px, 13vw, 56px);
    line-height: .82;
  }

  .vault-nav {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 2px 10px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .vault-nav::-webkit-scrollbar {
    display: none;
  }

  .vault-nav a {
    flex: 0 0 auto;
    white-space: nowrap;
    padding: 10px 14px;
    font-size: 14px;
  }

  .vault-main {
    width: 100%;
    padding: 10px 14px 44px;
  }

  .vault-stage,
  .console-card,
  .gate-game-grid,
  .gate-arcade-head,
  .scan-window {
    display: grid;
    grid-template-columns: 1fr !important;
    width: 100%;
  }

  .vault-stage {
    gap: 18px;
  }

  .vault-intro,
  .live-pad,
  .console-card,
  .gate-arcade-card {
    width: 100%;
    border-radius: 24px;
  }

  .vault-intro {
    padding: 22px 18px;
  }

  .vault-intro h1 {
    font-size: clamp(54px, 18vw, 88px);
    line-height: .78;
    text-shadow: 4px 4px 0 var(--pink), 8px 8px 0 rgba(32,247,255,.45);
  }

  .lead {
    font-size: 17px;
    line-height: 1.42;
  }

  .duo-strip {
    gap: 12px;
  }

  .duo-card {
    grid-template-columns: 72px minmax(0, 1fr);
    min-height: 98px;
    gap: 12px;
    padding: 12px;
    border-radius: 22px;
  }

  .duo-card img {
    width: 72px;
    height: 72px;
    border-radius: 20px;
  }

  .duo-card strong {
    font-size: clamp(22px, 8vw, 34px);
    line-height: .94;
  }

  .duo-card span {
    font-size: 14px;
    line-height: 1.28;
  }

  .live-pad {
    padding: 14px;
  }

  .pad-topper {
    grid-template-columns: 12px 1fr 12px;
    gap: 8px;
    font-size: 11px;
    letter-spacing: .10em;
  }

  .access-core {
    min-height: 390px;
    border-radius: 24px;
  }

  .readout-grid {
    grid-template-columns: 1fr;
  }

  .console-divider {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .console-divider span {
    display: none;
  }

  .console-card {
    gap: 18px;
    padding: 20px 16px;
  }

  .console-copy h2 {
    font-size: clamp(42px, 15vw, 72px);
  }

  .button-row {
    width: 100%;
  }

  .scan-button,
  .clear-button,
  .manual-enter,
  .gate-game-btn,
  .gate-track-btn {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .scan-window {
    max-height: 92vh;
    padding: 12px;
    border-radius: 24px;
  }

  .scan-visual {
    min-height: 430px;
  }

  .scan-copy {
    padding: 16px 8px 8px;
  }
}

@media (max-width: 420px) {
  .vault-header {
    padding-left: 12px;
    padding-right: 12px;
  }

  .vault-main {
    padding-left: 12px;
    padding-right: 12px;
  }

  .vault-logo strong {
    font-size: clamp(36px, 12.5vw, 48px);
  }

  .vault-intro h1 {
    font-size: clamp(48px, 16.8vw, 74px);
  }

  .duo-card {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .duo-card img {
    width: 64px;
    height: 64px;
  }

  .duo-card strong {
    font-size: clamp(20px, 7.2vw, 28px);
  }

  .access-core {
    min-height: 350px;
  }

  .body-target {
    transform: translate(-50%, -50%) scale(.86);
  }
}
