/* responsive-fixes.css - Soluciones para problemas de visualización en móvil y tablet */

/* ================= CORRECCIONES GENERALES ================= */

/* Asegurar que el footer se muestre correctamente en todas las resoluciones */
.footer-wrapper {
    width: 100% !important;
    background-color: #f2f2f2;
    overflow: hidden; /* Prevenir desbordamiento horizontal */
  }
  
  /* Estilos base del footer */
  .footer {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
  }
  
  /* Línea para pantallas normales (escritorio) - CORREGIDA PARA CENTRADO */
  .desktop-line {
    background-color: #2a2929;
    height: 1px;
    width: 90%;
    margin-left: auto !important; /* Centrado horizontal */
    margin-right: auto !important; /* Centrado horizontal */
    display: block;
  }
  
  /* Línea para dispositivos móviles - CORREGIDA PARA CENTRADO */
  .mobile-line {
    background-color: #2a2929;
    height: 2px;
    width: 95%;
    margin-left: auto !important; /* Centrado horizontal */
    margin-right: auto !important; /* Centrado horizontal */
    display: none;
  }
  
  /* Contenedor de la galería */
  .gallery-container {
    width: 100%;
    overflow: hidden; /* Prevenir desbordamiento horizontal */
  }
  
  /* Grid de galería más robusto */
  .gallery-grid {
    display: grid;
    gap: 20px;
    width: 100%;
  }
  
  /* ================= Subrayado curvo sobre Beyond 35 ================= */
  #galeria .gallery-caption .badge.border.border-dark.text-dark {
    position: relative !important;
    display: inline-block !important;
    z-index: 1 !important;
  }


  
  /* ================= CORRECCIONES PARA TABLET ================= */
  
  @media (min-width: 768px) and (max-width: 1024px) {
    /* Ajustes para el contenedor de la galería */
    #galeria {
      padding-left: 1.5rem !important;
      padding-right: 1.5rem !important;
    }
    
    /* Asegurar que las imágenes mantengan su proporción */
    .gallery-img {
      width: 100%;
      height: auto;
      aspect-ratio: 4/3;
      object-fit: cover;
    }
    
    /* Ajustes para el footer */
    .footer .container {
      padding-left: 15px;
      padding-right: 15px;
    }

    /* Ajustes para el subrayado curvo en tablet */
    #galeria .gallery-caption .badge.border.border-dark.text-dark::before {
      width: 140% !important;
      left: -20px !important;
    }
  }
  
  /* ================= CORRECCIONES PARA MÓVIL ================= */
  
  @media (max-width: 767px) {
    /* Ajustes al contenedor principal */
    .main-content {
      margin-left: 0 !important;
      width: 100% !important;
      padding: 15px;
    }
    
    /* Ajustes para el icono de hamburguesa */
    .hamburger-btn {
      display: flex !important;
      z-index: 2100;
    }
    
    /* Ajustes para el sidebar/menú */
    .sidebar-modern {
      display: none;
      width: 100% !important;
      height: 100vh;
      z-index: 1100;
    }
    
    /* Cuando el menú está abierto */
    .sidebar-modern.show {
      display: flex;
      opacity: 1;
    }
    
    /* Ajustes para el footer en móvil */
    .desktop-line {
      display: none !important;
    }
    
    .mobile-line {
      display: block !important;
    }
    
    /* Footer apilado verticalmente en móvil */
    .footer .container {
      flex-direction: column;
      align-items: center;
      text-align: center;
      padding: 15px;
    }
    
    .footer-title {
      margin-bottom: 10px;
      font-size: 1rem;
    }
    
    .footer-credits {
      font-size: 0.85rem;
      text-align: center;
      width: 100%;
    }
    
    /* Ajustes para la galería en móvil */
    #galeria {
      padding-left: 1rem !important;
      padding-right: 1rem !important;
    }
    
    .gallery-grid {
      grid-template-columns: 1fr !important;
      gap: 15px;
    }

    /* Ajustes para el subrayado curvo en móvil */
    #galeria .gallery-caption .badge.border.border-dark.text-dark::before {
      width: 120% !important;
      left: -10px !important;
      top: -10px !important;
      height: 40px !important;
    }
  }
  
  /* ================= CORRECCIONES PARA IPAD PRO ================= */
  
  @media only screen and (min-width: 1024px) and (max-width: 1366px) {
    #galeria {
      padding-left: 1.5rem !important;
      padding-right: 1.5rem !important;
    }
    
    .footer-wrapper {
      width: 100% !important;
    }
    
    /* Corregir visualización del footer */
    .desktop-line {
      margin-left: auto !important;
      margin-right: auto !important;
    }
  }
  
  /* ================= CORRECCIONES PARA TELÉFONOS PEQUEÑOS ================= */
  
  @media only screen and (max-width: 375px) {
    .footer .container {
      padding: 10px 5px;
    }
    
    .footer-title {
      font-size: 0.9rem;
    }
    
    .footer-credits {
      font-size: 0.75rem;
    }

    /* Ajustes para el subrayado curvo en teléfonos pequeños */
    #galeria .gallery-caption .badge.border.border-dark.text-dark::before {
      width: 110% !important;
      left: -5px !important;
      top: -8px !important;
      height: 35px !important;
    }
  }

  /* Corrección para la alineación del footer */

/* Asegurar que el contenedor del footer mantenga el flex row en todas las resoluciones excepto móvil */
.footer .container {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-direction: row !important;
    width: 100% !important;
  }
  
  /* Asegurar que el título se alinee a la izquierda */
  .footer-title {
    text-align: left !important;
    margin-bottom: 0 !important;
  }
  
  /* Asegurar que los créditos se alineen a la derecha */
  .footer-credits {
    text-align: right !important;
  }
  
  /* Solo en dispositivos móviles cambiamos a columna */
  @media (max-width: 767px) {
    .footer .container {
      flex-direction: column !important;
      text-align: center !important;
    }
    
    .footer-title, .footer-credits {
      text-align: center !important;
      width: 100% !important;
    }
    
    .footer-title {
      margin-bottom: 10px !important;
    }
  }

  /* Ajuste para mover la línea del footer más a la derecha solo en escritorio */
@media (min-width: 768px) {
    .desktop-line {
      width: 90%;
      margin-left: 38px !important; /* Volvemos a aplicar el margen izquierdo original */
      margin-right: 0 !important; /* Quitamos el margen derecho automático */
    }
  }
  
  /* Mantener la línea centrada en tablets */
  @media (min-width: 768px) and (max-width: 1024px) {
    .desktop-line {
      width: 90%;
      margin-left: auto !important;
      margin-right: auto !important;
    }
  }

  /* Solución para mantener el footer al final de la pantalla al usar el buscador */
html, body {
  height: 100%;
  margin: 0;
}

body {
  display: flex;
  flex-direction: column;
}

.main-content {
  flex: 1 0 auto; /* Esto hace que el contenido principal ocupe todo el espacio disponible */
  min-height: 85vh; /* Altura mínima para asegurar que hay suficiente contenido */
}

.footer-wrapper {
  flex-shrink: 0; /* Evita que el footer se encoja */
  margin-top: auto; /* Empuja el footer al final cuando hay poco contenido */
  position: relative; /* Mantiene el footer en el flujo del documento */
  width: 100% !important;
  background-color: #f2f2f2;
  z-index: 10; /* Asegura que el footer esté por encima de otros elementos */
}

/* Ajuste para cuándo hay pocos resultados de búsqueda */
#galeria {
  min-height: 60vh; /* Asegura una altura mínima para la galería */
}

/* Mantener los márgenes adecuados en dispositivos móviles */
@media (max-width: 768px) {
  .main-content {
    min-height: 80vh;
  }
  
  #galeria {
    min-height: 50vh;
  }
}

/* Solución optimizada para mantener el footer en su lugar sin afectar el diseño original */
.footer-wrapper {
  width: 100% !important;
  background-color: #f2f2f2;
  position: relative;
  z-index: 10;
}

/* Estilo condicional que se aplica solo cuando hay pocos elementos en la galería */
@media screen and (min-height: 700px) {
  body.search-active .gallery-grid:only-child {
    min-height: calc(100vh - 300px); /* Altura ajustable según el tamaño del footer y header */
  }
}

/* Evitar alterar el layout en dispositivos móviles */
@media (max-width: 768px) {
  body.search-active .gallery-grid:only-child {
    min-height: auto; /* Usar altura automática en móviles */
  }
  
  /* Asegurar que no se cree scroll innecesario */
  html, body {
    overflow-x: hidden;
  }
}

/* Clase auxiliar - se añadirá vía JavaScript cuando se realice una búsqueda */
body.search-active .footer-wrapper {
  margin-top: auto;
}