/* Mobile fixes to eliminate right-side blank space and constrain wide elements (only for small screens) */
@media (max-width: 900px) {
  html, body {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  /* Ensure main containers don't add extra horizontal space */
  .container,
  .nav-container,
  .hero-inner,
  .hero-index .hero-inner {
    box-sizing: border-box !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 100% !important;
  }

  /* Prevent media (video/img) from exceeding viewport */
  img, video, iframe, .hero-video-banner, .hero-image img, .hero-image video {
    max-width: 90vw !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Prevent logo from scaling with generic img rule */
  .logo-img {
    max-width: 56px !important;
    width: 56px !important;
    height: auto !important;
    display: block !important;
  }

  /* Center hero content and avoid side offsets */
  .hero-index .hero-inner,
  .hero-inner {
    justify-content: center !important;
    align-items: center !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* Limit any absolutely positioned decorative elements that could push layout */
  .hero-index::after,
  .hero-index::before,
  .hero-productos::after,
  .hero-productos::before {
    display: none !important;
  }

  /* Ensure header does not cause horizontal overflow */
  .header, .nav-container {
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
  }

  /* Reduce overly large fixed widths used for videos/cards */
  .hero-video-banner, .hero-image-card, .hero-image video {
    max-width: 92vw !important;
  }
}

/* Mobile video placement and reduced vertical spacing */
.hero-video-mobile {
  display: none;
}

@media (max-width: 900px) {
  /* Hide original hero video on mobile (we added a mobile-only section) */
  .hero-index .hero-image {
    display: none !important;
  }

  /* Show mobile-only video section */
  .hero-video-mobile {
    display: block !important;
    padding: 6px 0 !important;
    margin: 0 auto !important;
  }
  .hero-video-banner-mobile {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    border-radius: 12px !important;
    box-shadow: 0 12px 28px rgba(0,0,0,0.16) !important;
    display: block !important;
  }

  /* Reduce vertical spacing globally between sections on mobile */
  section {
    padding-top: 18px !important;
    padding-bottom: 18px !important;
  }
  /* Specific overrides for common large-padding sections */
  .hero-index {
    padding-top: 24px !important;
    padding-bottom: 8px !important;
    min-height: auto !important;
  }
  .products-section,
  .services-slider,
  .about,
  .benefits,
  .importance,
  .testimonials {
    padding-top: 18px !important;
    padding-bottom: 18px !important;
  }
  .section-header {
    margin-bottom: 14px !important;
  }
  .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* Fixes específicos para la sección "Tratamientos Especializados" en móviles */
@media (max-width: 900px) {
  /* Apilar y/o estrechar columnas para evitar desbordes */
  #especiales .about-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
  }

  /* Texto e imagen ocupan 100% y eliminan paddings grandes */
  #especiales .about-text,
  #especiales .about-image,
  #especiales .about-features {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* Imagen: contenedor responsivo y sin overflow */
  .about-image-card {
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: none !important;
  }

  /* Contenedor de imágenes rotativas: mostrar solo la imagen activa para evitar altura inesperada */
  .rotating-image-container {
    display: block !important;
    position: relative !important;
    height: auto !important;
    overflow: hidden !important;
  }
  .rotating-image {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-height: 360px !important;
    object-fit: cover !important;
    border-radius: 12px !important;
  }
  /* Mostrar todas las imágenes en móvil (no ocultar por clase .active) */

  /* Ajustes de texto para mejor legibilidad en pantalla pequeña */
  #especiales .about-panel {
    padding: 8px 6px !important;
  }
  #especiales .about-intro {
    font-size: 0.95rem !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
  }

  /* Espaciado reducido entre título y contenido */
  #especiales .section-label,
  #especiales .about-panel h2 {
    margin-bottom: 6px !important;
  }

  /* Evitar márgenes laterales excesivos */
  #especiales .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* Mobile fixes for promo.html - sección "¿POR QUÉ ELEGIRNOS?" */
@media (max-width: 900px) {
  /* Stack text and image vertically and center content */
  #elegirnos .about-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    width: 100% !important;
    overflow: visible !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* Make text block centered and constrain its width for readability */
  #elegirnos .about-text {
    width: 100% !important;
    max-width: 640px !important;
    padding: 0 !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
    text-align: center !important;
    transform: none !important;
    left: auto !important;
    right: auto !important;
  }

  /* Center image/map card and constrain width */
  #elegirnos .about-image,
  #elegirnos .about-image-card {
    width: 100% !important;
    max-width: 640px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    position: static !important;
    float: none !important;
  }

  /* Prevent elements from causing horizontal scroll */
  #elegirnos, 
  #elegirnos .container,
  #elegirnos .about-content,
  #elegirnos .about-image,
  #elegirnos .about-text {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  /* Center the feature list and limit its width so items wrap nicely */
  .promo-list-v2 {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 auto 12px auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    align-items: center !important;
    max-width: 640px !important;
  }
  .promo-list-v2 li {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    font-size: 0.97rem !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    justify-content: flex-start !important;
    width: 100% !important;
  }
  .promo-list-v2 li i {
    min-width: 28px !important;
    color: var(--verde-claro) !important;
    font-size: 1.1rem !important;
    flex-shrink: 0 !important;
    margin-top: 0 !important;
    margin-right: 8px !important;
  }

  /* Reduce nosotras image size and center it */
  .nosotras-img {
    display: block !important;
    width: 120px !important;
    max-width: 30% !important;
    height: auto !important;
    margin: 12px auto 0 auto !important;
    border-radius: 8px !important;
  }

  /* Ensure promo contact card and map fit the viewport and are centered */
  .about-image-card img,
  .contact-promo-card img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    border-radius: 12px !important;
    display: block !important;
    margin: 0 auto !important;
  }

  .contact-promo-card {
    padding: 12px !important;
    margin: 12px auto 0 auto !important;
    box-sizing: border-box !important;
    max-width: 640px !important;
  }
  .contact-promo-map iframe {
    width: 100% !important;
    height: 220px !important;
    border-radius: 12px !important;
    display: block !important;
    margin: 8px auto 0 auto !important;
  }

  /* Force images and iframe to not exceed viewport */
  #elegirnos img,
  #elegirnos iframe,
  #elegirnos video {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
  }

  /* Remove any absolute positioning that could push elements right */
  #elegirnos .about-image,
  #elegirnos .about-image-card,
  #elegirnos .about-text {
    position: static !important;
    float: none !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
  }

  /* Reduce vertical spacing for this section */
  #elegirnos {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    overflow-x: hidden !important;
    text-align: center !important;
  }

  /* Extra centering & layout fixes for #elegirnos on small screens */
  /* Keeps text, image and map centered and prevents right offset */
  #elegirnos .about-content {
    align-items: center !important;
    justify-content: center !important;
  }
  #elegirnos .about-text {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  /* Center the list container but keep list items left-aligned for readability */
  #elegirnos .promo-list-v2 {
    max-width: 680px !important;
    margin: 0 auto 12px auto !important;
    align-items: flex-start !important;
    padding-left: 0 !important;
  }
  #elegirnos .promo-list-v2 li {
    justify-content: flex-start !important;
    text-align: left !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  /* Center and constrain image/map card */
  #elegirnos .about-image-card,
  #elegirnos .contact-promo-card {
    margin: 0 auto !important;
    max-width: 680px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  #elegirnos .about-image-card img {
    display: block !important;
    margin: 0 auto !important;
    max-width: 100% !important;
    height: auto !important;
  }
  #elegirnos .contact-promo-map iframe {
    display: block !important;
    margin: 0 auto !important;
    max-width: 100% !important;
  }
}

/* Extra forced small-screen overrides for #elegirnos */
@media (max-width: 480px) {
  #elegirnos .about-content,
  #elegirnos .about-text,
  #elegirnos .about-image,
  #elegirnos .about-image-card,
  #elegirnos .contact-promo-card {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    box-sizing: border-box !important;
    transform: none !important;
    left: auto !important;
    right: auto !important;
    position: static !important;
  }

  /* Ensure the list is centered but items left-aligned for readability */
  #elegirnos .promo-list-v2 {
    max-width: 100% !important;
    margin: 0 auto 12px auto !important;
    padding-left: 0 !important;
    align-items: flex-start !important;
  }
  #elegirnos .promo-list-v2 li {
    width: 100% !important;
    padding-left: 0 !important;
    text-align: left !important;
    box-sizing: border-box !important;
  }

  /* Headings centered for visual balance */
  #elegirnos .about-text .section-label,
  #elegirnos .about-text h2 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Force images and iframe to occupy full width and be centered */
  #elegirnos img,
  #elegirnos iframe,
  #elegirnos video {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Remove any unexpected transforms/margins from nested elements */
  #elegirnos * {
    transform: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* Force mobile layout for cursos sections that were overflowing */
@media (max-width: 900px) {
  /* Stack and center content */
  #spa-training .about-content,
  #ferias-salud .about-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    overflow: visible !important;
  }

  /* Ensure text block is centered and readable */
  #spa-training .about-text,
  #ferias-salud .about-text {
    width: 100% !important;
    max-width: 720px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
    box-sizing: border-box !important;
    order: 1 !important;
  }

  /* Place image below text on mobile and center it */
  #spa-training .about-image,
  #ferias-salud .about-image {
    width: 100% !important;
    max-width: 720px !important;
    margin: 0 auto !important;
    order: 2 !important;
    padding: 0 !important;
  }

  /* Image sizing */
  #spa-training .about-image-card img,
  #ferias-salud .about-image-card img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    border-radius: 12px !important;
    margin: 0 auto !important;
  }

  /* Remove any inline order or floats causing horizontal shift */
  #spa-training .about-image,
  #spa-training .about-text,
  #ferias-salud .about-image,
  #ferias-salud .about-text {
    position: static !important;
    float: none !important;
    transform: none !important;
    left: auto !important;
    right: auto !important;
  }

  /* Prevent horizontal overflow from nested elements */
  #spa-training, #ferias-salud,
  #spa-training .container, #ferias-salud .container {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
}
