/**
 * QuickScoreBet — capa responsive global (móvil y tablet)
 * Carga después de global.css. Cambios conservadores: no tocar SVG de iconos
 * ni la geometría del modal de jugador (solo ajustes de tamaño).
 */

:root {
  --responsive-content-pad-x: max(1rem, env(safe-area-inset-left, 0px));
  --responsive-content-pad-x-end: max(1rem, env(safe-area-inset-right, 0px));
}

/* Flash (estilos movidos desde base.html) */
.container-flash {
  width: 100%;
  max-width: 720px;
  margin: 0.75rem auto 0;
  padding-left: 1rem;
  padding-right: 1rem;
  box-sizing: border-box;
}

.container-flash .alert {
  margin: 0 0 0.5rem;
}

.container-flash .alert:last-child {
  margin-bottom: 0;
}

/*
 * Solo medios raster / vídeo: NO aplicar max-width:100% a todos los svg
 * (rompe iconos inline en nav, botones y controles).
 */
img,
video,
canvas {
  max-width: 100%;
  height: auto;
}

pre,
code {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* =============================================================================
   Móvil pequeño (hasta 479px) — solo lo que evita cortes y mejora tacto
   ============================================================================= */
@media (max-width: 479px) {
  /* Evita que flex hijos desborden el ancho del viewport */
  .main {
    min-width: 0;
    padding-left: var(--responsive-content-pad-x);
    padding-right: var(--responsive-content-pad-x-end);
  }

  .container-flash {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left: var(--responsive-content-pad-x);
    padding-right: var(--responsive-content-pad-x-end);
  }

  .hero {
    padding: 1.25rem 0;
  }

  .card {
    padding: 1rem;
  }

  .filter-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
  }

  .filter-group {
    width: 100%;
    justify-content: space-between;
  }

  .filter-select {
    flex: 1;
    min-width: 0;
  }

  .la-liga-header {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .player-search-wrap {
    flex-direction: column;
    align-items: stretch;
  }

  .player-search-wrap .search-input {
    min-width: 0;
    width: 100%;
    font-size: 1rem;
  }

  .player-detail-grid {
    grid-template-columns: 1fr;
  }

  /*
   * Modal jugador: misma lógica que global (centrado), solo afinar altura/ancho
   * para móviles — sin cambiar left/top/transform (evita cortes y animaciones rotas).
   */
  .player-modal-dialog {
    width: min(100vw - 1rem, 92vw);
    max-width: 900px;
    max-height: min(90dvh, 90vh);
    margin-left: auto;
    margin-right: auto;
  }

  .player-modal-body {
    padding: 1rem 1rem 1.75rem;
  }

  .footer-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
  }

  .footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.75rem;
  }

  .table th,
  .table td {
    padding: 0.5rem 0.65rem;
    font-size: 0.8125rem;
  }
}

/* =============================================================================
   Móvil ancho / tablet estrecha (480px – 767px)
   ============================================================================= */
@media (min-width: 480px) and (max-width: 767px) {
  .main {
    min-width: 0;
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }

  .player-modal-dialog {
    width: min(94vw, 900px);
    max-height: min(88dvh, 88vh);
  }

  .footer-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
  }
}

/* =============================================================================
   Tablet (768px – 1023px)
   ============================================================================= */
@media (min-width: 768px) and (max-width: 1023px) {
  .main {
    min-width: 0;
    padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
    padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
  }

  /* Rejilla fluida; no forzar 2 columnas fijas (evita tarjetas aplastadas) */
  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
  }

  .player-detail-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }

  .player-modal-dialog {
    max-height: min(86dvh, 86vh);
  }

  .footer-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
  }
}

/* Desktop: pie alineado si hace falta */
@media (min-width: 1024px) {
  .footer-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .nav-toggle-bar {
    transition-duration: 0.01ms !important;
  }
}
