/* ── Tablet (≤ 1380px) ── */
@media (max-width: 1380px) {
  .play-grid {
    grid-template-columns: minmax(260px, 300px) minmax(0, 1fr) minmax(260px, 300px);
  }
}

/* ── Small Desktop / Large Tablet (≤ 1180px) ── */
@media (max-width: 1180px) {
  .play-grid {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 4px 0;
  }

  body.mode-lobby .play-grid {
    display: flex;
    flex-direction: column;
    overflow: visible;
  }

  .play-column {
    height: auto;
    max-height: none;
  }

  body.mode-lobby .play-column-left,
  body.mode-lobby .play-column-center,
  body.mode-lobby .play-column-right {
    height: auto !important;
    overflow: visible !important;
  }

  .play-column-right {
    order: 3;
  }

  .play-column-left {
    order: 1;
  }

  .play-column-center {
    order: 2;
  }

  .hybrid-phase-masthead,
  .hybrid-stage-head,
  .hybrid-chat-head {
    grid-template-columns: 1fr;
    display: grid;
  }

  .hybrid-chat-head-note,
  .hybrid-stage-hint {
    text-align: left;
  }

  #play-view {
    height: auto;
    max-height: none;
    overflow-y: auto;
  }

  body.mode-lobby #play-view,
  body.mode-game #play-view {
    height: auto;
    max-height: none;
  }

  body.mode-lobby .shell,
  body.mode-game .shell {
    height: auto;
    overflow: auto;
  }
}

/* ── Tablet Portrait (≤ 900px) ── */
@media (max-width: 900px) {
  .play-topbar {
    flex-wrap: wrap;
    gap: 6px;
  }

  .topbar-block-room {
    flex: 1 1 100%;
  }

  .play-grid {
    width: 100%;
    padding: 4px 6px;
  }

  .legacy-panel {
    border-radius: 8px;
  }

  .hybrid-stage-player {
    padding: 8px 10px;
  }

  /* Stack the action panel vertically */
  .legacy-center-board {
    padding: 10px;
  }

  /* Modal adjustments */
  .modal-content,
  #modal-creation .modal-content {
    max-width: calc(100vw - 24px);
    max-height: calc(100vh - 40px);
    margin: 20px auto;
  }
}

@media (max-width: 1100px) {
  .header-inner {
    gap: 12px;
  }

  .header-stats {
    max-width: calc(100% - 210px);
    gap: 6px;
  }

  .header-chip {
    padding: 6px 10px;
    font-size: 0.76rem;
  }
}

@media (max-width: 780px) {
  .header-inner {
    flex-direction: row;
    align-items: center;
  }

  .header-stats {
    max-width: calc(100% - 190px);
  }

  .header-support-link {
    right: 12px;
  }
}

/* ── Mobile (≤ 640px) ── */
@media (max-width: 640px) {
  /* Header compact */
  .site-header {
    padding: 6px 10px;
  }

  .header-inner {
    gap: 8px;
  }

  .header-logo {
    width: 28px;
    height: 28px;
  }

  .header-title {
    font-size: 1rem;
  }

  .header-kicker {
    font-size: 0.7rem;
  }

  .header-stats {
    display: none;
  }

  .header-support-link {
    right: 10px;
    font-size: 0.68rem;
    padding: 6px 9px;
  }

  /* Play view adjustments */
  .play-grid {
    padding: 2px 4px;
    gap: 3px;
  }

  .play-topbar {
    padding: 6px 8px;
    min-height: auto;
  }

  .topbar-block-room h2 {
    font-size: 0.85rem;
  }

  /* Chat mobile-friendly */
  .chat-form {
    padding: 6px 8px;
  }

  .chat-input-field {
    font-size: 16px; /* prevents iOS zoom */
  }

  .chat-bubble {
    max-width: 95%;
    padding: 6px 10px;
    font-size: 0.85rem;
  }

  .chat-tabs {
    gap: 2px;
    flex-wrap: wrap;
  }

  .chat-tab {
    font-size: 0.7rem;
    padding: 4px 6px;
  }

  /* Players grid: 2 columns on mobile */
  .hybrid-stage-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 4px;
  }

  .hybrid-stage-player {
    padding: 6px 8px;
    font-size: 0.8rem;
  }

  .hybrid-stage-player-name {
    font-size: 0.8rem;
  }

  /* Action buttons bigger for touch */
  .action-btn,
  .btn-primary,
  .btn-secondary {
    min-height: 44px;
    padding: 10px 16px;
    font-size: 0.9rem;
  }

  /* Role panel compact */
  .hybrid-role-meta {
    padding: 8px 10px;
  }

  /* Composition cards smaller */
  .archive-role-card {
    padding: 4px;
  }

  .archive-role-card img {
    max-width: 50px;
  }

  /* Victory overlay */
  .victory-overlay {
    padding: 20px 16px;
  }

  .victory-title {
    font-size: 1.4rem;
  }

  /* Creation modal */
  .creation-role-catalog {
    grid-template-columns: repeat(2, 1fr);
  }

  .creation-settings-row {
    flex-direction: column;
    gap: 6px;
  }

  /* Emoji picker */
  .emoji-picker {
    max-width: calc(100vw - 20px);
  }

  .emoji-btn {
    min-width: 32px;
    min-height: 32px;
    font-size: 1.1rem;
  }
}

/* ── Small Mobile (≤ 400px) ── */
@media (max-width: 400px) {
  .header-brand-copy {
    display: none;
  }

  .hybrid-stage-grid {
    grid-template-columns: 1fr;
  }

  .play-topbar {
    padding: 4px 6px;
  }

  .creation-role-catalog {
    grid-template-columns: 1fr;
  }

  .landing-camp-section {
    padding: 15px 8px;
  }

  .camp-card-img-wrap {
    width: 70px;
    height: 100px;
  }
}

/* ── Touch Device Enhancements ── */
@media (hover: none) and (pointer: coarse) {
  /* Ensure minimum touch target size */
  button,
  .chat-tab,
  .action-btn,
  .emoji-btn,
  a[role="button"] {
    min-height: 44px;
    min-width: 44px;
  }

  /* Disable hover effects that don't work on touch */
  .hybrid-stage-player:hover {
    transform: none;
  }

  /* Larger scrollbars on touch */
  ::-webkit-scrollbar {
    width: 6px;
  }
}

/* ── Landscape Mobile ── */
@media (max-height: 500px) and (orientation: landscape) {
  .site-header {
    padding: 2px 10px;
  }

  .header-logo {
    width: 24px;
    height: 24px;
  }

  #play-view {
    --play-shell-min-height: calc(100vh - 40px);
  }

  .play-topbar {
    padding: 2px 8px;
    min-height: 32px;
  }
}
