/* =========================================================================
   LARES — Responsive (mobile / tablet)
   Overrides con !important porque el layout base usa estilos inline (1440px).
   ========================================================================= */

/* ---------- Tablet ---------- */
@media (max-width: 1024px) {
  .g-col5 { grid-template-columns: repeat(3, 1fr) !important; }
  .g-col4 { grid-template-columns: repeat(2, 1fr) !important; }
  .g-col3 { grid-template-columns: repeat(2, 1fr) !important; }
  .s-body { grid-template-columns: 1fr 380px !important; }
}

/* ---------- Phone ---------- */
@media (max-width: 720px) {

  /* Evitar scroll horizontal de página (el scroll vive solo en .s-filters) */
  html, body { overflow-x: hidden !important; max-width: 100% !important; }

  /* Padding lateral de página */
  .sec { padding-left: 20px !important; padding-right: 20px !important; }

  /* ----- Navbar ----- */
  .nav { padding: 14px 20px !important; }
  .nav-links { display: none !important; }
  .nav-right .nav-link { display: none !important; }
  .nav-right { gap: 12px !important; }

  /* ----- Landing: hero ----- */
  .l-hero { grid-template-columns: 1fr !important; min-height: 0 !important; }
  .l-hero-text { padding: 16px 20px 4px !important; }
  .l-hero-text h1 { font-size: 42px !important; }
  .l-hero-text p { font-size: 16px !important; }
  .l-hero-media { display: none !important; }
  .l-hero-cta { flex-wrap: wrap !important; }
  .l-hero-cta .btn { flex: 1 1 150px !important; justify-content: center !important; }
  .l-hero-stats { gap: 26px !important; margin-top: 30px !important; flex-wrap: wrap !important; }
  /* Popovers a ancho de pantalla */
  .searchbar .lares-pop { left: 10px !important; right: 10px !important; width: auto !important; max-width: calc(100vw - 20px) !important; }

  /* ----- SearchBar: apilar vertical ----- */
  .searchbar { flex-direction: column !important; align-items: stretch !important; border-radius: 18px !important; }
  .search-field { border-radius: 0 !important; padding: 13px 18px !important; }
  .search-field + .search-field::before {
    left: 18px !important; right: 18px !important; top: 0 !important; bottom: auto !important;
    width: auto !important; height: 1px !important; opacity: 1 !important;
  }
  .search-go { margin: 10px 14px 14px !important; padding: 14px !important; justify-content: center !important; width: auto !important; }

  /* ----- Grillas a 1–2 columnas ----- */
  .g-col5 { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; }
  .g-col4 { grid-template-columns: 1fr 1fr !important; gap: 16px !important; }
  .g-col3 { grid-template-columns: 1fr !important; }
  .g-2 { grid-template-columns: 1fr !important; }
  .l-promesa { padding: 0 !important; }
  .l-promesa-text { padding: 44px 20px !important; }
  .l-promesa-media { display: none !important; }
  .g-foot { grid-template-columns: 1fr 1fr !important; gap: 28px !important; }
  .foot-bottom { flex-direction: column !important; gap: 16px !important; align-items: flex-start !important; text-align: left !important; }
  .l-cta-box { padding: 44px 26px !important; }

  /* Reducir paddings verticales grandes de secciones */
  .sec-tight { padding-top: 48px !important; }

  /* ----- App de búsqueda ----- */
  .s-head {
    grid-template-columns: 1fr auto !important;
    grid-template-areas: 'logo acct' 'pill pill' !important;
    row-gap: 12px !important; column-gap: 12px !important; padding: 12px 16px !important;
  }
  .s-head > a { grid-area: logo; align-self: center; }
  .s-head > .nav-right { grid-area: acct; }
  .s-head > .s-pill { grid-area: pill; width: 100% !important; justify-content: space-between !important; }
  .s-pill { padding: 6px 6px 6px 8px !important; min-width: 0 !important; }
  .s-pill .s-pill-text { font-size: 12.5px !important; flex: 1; min-width: 0; overflow: hidden; white-space: nowrap; }
  .s-pill .s-pill-seg { padding: 0 9px !important; }
  .s-pill .s-pill-go { width: 32px !important; height: 32px !important; }
  .s-filters { padding: 0 16px 14px !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
  .s-body { grid-template-columns: 1fr !important; }
  .s-list { padding: 18px 20px 50px !important; }
  .s-map { display: none !important; }
  .res-row { grid-template-columns: 1fr !important; gap: 14px !important; }
  .res-media { aspect-ratio: 16 / 10 !important; }

  /* Dropdowns de filtros como bottom-sheet (no se salen de pantalla) */
  .pop-filter {
    position: fixed !important; left: 12px !important; right: 12px !important;
    bottom: 14px !important; top: auto !important; width: auto !important; max-width: none !important;
    max-height: 72vh; overflow: auto; border-radius: 18px !important; padding: 20px !important;
  }

  /* ----- Ficha de hotel ----- */
  .d-head { flex-direction: column !important; align-items: flex-start !important; gap: 16px !important; }
  .d-gallery { grid-template-columns: 1fr 1fr !important; grid-template-rows: auto !important; height: auto !important; }
  .d-gallery > .d-gallery-main { grid-row: auto !important; grid-column: 1 / -1 !important; aspect-ratio: 16 / 11 !important; }
  .d-gallery > .d-gallery-cell { aspect-ratio: 1 / 1 !important; }
  .d-body { grid-template-columns: 1fr !important; gap: 0 !important; }
  .d-widget { position: static !important; top: auto !important; margin-top: 8px !important; }
  .d-room { grid-template-columns: 84px 1fr !important; }
  .d-room .d-room-cta { grid-column: 1 / -1 !important; text-align: left !important; display: flex !important; align-items: center !important; justify-content: space-between !important; }
  .d-reviews { grid-template-columns: 1fr !important; gap: 22px !important; }

  /* ----- Checkout ----- */
  .co-grid { grid-template-columns: 1fr !important; }
  .co-confirm { flex-direction: column !important; }
  .co-confirm > div { border-right: none !important; border-bottom: 1px solid var(--line) !important; }
  .co-confirm > div:last-child { border-bottom: none !important; }
}

/* Móviles muy chicos */
@media (max-width: 420px) {
  .g-col5 { grid-template-columns: 1fr 1fr !important; }
  .g-col4 { grid-template-columns: 1fr !important; }
  .d-gallery { grid-template-columns: 1fr !important; }
  .l-hero-text h1 { font-size: 38px !important; }
}
