/* Survivor Arena - Responsive & Accessibility */

/* ============================================================
   20. RESPONSIVE BREAKPOINTS
   ============================================================ */

/* Tablets and small screens */
@media (max-width: 768px) {
  .menu-panel {
    padding: 28px 20px;
  }

  .character-grid {
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 12px;
  }

  .character-portrait {
    width: 56px;
    height: 56px;
    font-size: 1.5rem;
  }

  .upgrades-grid {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
  }

  .upgrade-choices {
    flex-direction: column;
    align-items: center;
  }

  .upgrade-choice {
    max-width: 320px;
    width: 100%;
    flex-direction: row;
    padding: 16px;
    gap: 14px;
  }

  .upgrade-choice-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    font-size: 1.4rem;
  }

  .upgrade-choice-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
    text-align: left;
  }

  .upgrade-choice-name {
    text-align: left;
    font-size: 0.8rem;
  }

  .upgrade-choice-desc {
    text-align: left;
    font-size: 0.7rem;
  }

  #hud-minimap,
  .hud-minimap {
    width: 110px;
    height: 110px;
    bottom: 10px;
    right: 10px;
  }

  #hud-leaderboard,
  .hud-leaderboard {
    min-width: 150px;
    max-width: 170px;
    font-size: 0.65rem;
    padding: 8px 10px;
  }

  .weapon-icon {
    width: 42px;
    height: 42px;
    font-size: 1.1rem;
  }

  #hud-health-container,
  .health-bar-container,
  #health-bar-container {
    width: 220px;
    height: 20px;
  }

  #hud-xp-container,
  .xp-bar-container,
  #xp-bar-container {
    width: 220px;
    height: 14px;
  }

  #hud-kills,
  .hud-kills {
    right: auto;
    top: auto;
    bottom: 70px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.8rem;
    padding: 5px 14px;
  }

  .death-container {
    padding: 32px 24px;
  }

  .death-buttons {
    flex-direction: column;
  }

  #hud-timer,
  .hud-timer {
    font-size: 0.9rem;
    padding: 5px 16px;
  }
}

/* Very small screens (phones) */
@media (max-width: 480px) {
  .menu-content {
    gap: 20px;
    padding: 24px 12px;
  }

  .menu-panel {
    padding: 20px 16px;
    border-radius: var(--radius-lg);
  }

  .game-title {
    font-size: 1.8rem;
  }

  .menu-btn {
    padding: 12px 20px;
    font-size: 0.8rem;
  }

  .character-grid {
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 8px;
  }

  .character-card {
    padding: 12px 8px;
    gap: 6px;
  }

  .character-portrait {
    width: 44px;
    height: 44px;
    font-size: 1.2rem;
  }

  .character-name {
    font-size: 0.65rem;
  }

  .character-passive {
    font-size: 0.6rem;
  }

  .levelup-container {
    padding: 16px;
    gap: 20px;
  }

  .levelup-title {
    font-size: 1.2rem;
  }

  .upgrade-choice {
    padding: 12px;
    gap: 10px;
  }

  #hud-minimap,
  .hud-minimap {
    width: 85px;
    height: 85px;
    bottom: 8px;
    right: 8px;
  }

  #hud-leaderboard,
  .hud-leaderboard {
    display: none;
  }

  #hud-health-container,
  .health-bar-container,
  #health-bar-container {
    width: 180px;
    height: 18px;
  }

  #hud-xp-container,
  .xp-bar-container,
  #xp-bar-container {
    width: 180px;
    height: 12px;
  }

  .weapon-icon {
    width: 38px;
    height: 38px;
    font-size: 1rem;
  }

  #hud-timer,
  .hud-timer {
    font-size: 0.8rem;
    padding: 4px 12px;
  }

  .pause-container,
  .death-container {
    padding: 24px 16px;
    width: 95%;
  }
}

/* Landscape orientation on phones */
@media (max-height: 480px) and (orientation: landscape) {
  .menu-screen {
    justify-content: flex-start;
    padding-top: 8px;
  }

  .menu-content {
    gap: 12px;
    padding: 8px 16px;
  }

  .game-title {
    font-size: 1.4rem;
    margin-bottom: 0;
  }

  .menu-btn {
    padding: 10px 20px;
  }

  .levelup-container {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    padding: 8px;
    gap: 12px;
  }

  .levelup-title {
    width: 100%;
    font-size: 1rem;
  }

  .upgrade-choices {
    gap: 10px;
  }

  .upgrade-choice {
    padding: 12px;
    max-width: 180px;
  }
}


/* ============================================================
   21. REDUCED MOTION PREFERENCE
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
