/* Fix huecos entre tarjetas - usar flexbox en lugar de float */
#ribalta-catalog-content .ribalta-cat-section .row {
  display: flex !important;
  flex-wrap: wrap !important;
}

/* Hacer que cada columna use flexbox para igualar alturas */
#ribalta-catalog-content .ribalta-cat-section .col-sm-6.col-md-4 {
  float: none !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Hacer que el div interno (tarjeta) ocupe toda la altura disponible */
#ribalta-catalog-content .ribalta-cat-section .col-sm-6.col-md-4 > div {
  flex: 1 !important;
  height: 100% !important;
}

/* Hacer que el bloque de info crezca para llenar el espacio */
#ribalta-catalog-content .ribalta-cat-section .col-sm-6.col-md-4 > div > div:last-child {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

/* Aside sticky */
.aside-left {
  position: sticky !important;
  top: 10px !important;
  align-self: flex-start !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
}

/* Ocultar referencia en tarjetas del catalogo */
#ribalta-catalog-content .thumbnail .ref,
#ribalta-catalog-content .thumbnail [class*=ref],
#ribalta-catalog-content .thumbnail p strong:first-child {
  display: none !important;
}

/* Igualar altura de todas las tarjetas */
#ribalta-catalog-content .ribalta-cat-section .row {
  align-items: stretch !important;
}

#ribalta-catalog-content .thumbnail {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  min-height: 420px !important;
}

#ribalta-catalog-content .thumbnail .caption {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

#ribalta-catalog-content .thumbnail img {
  width: 100% !important;
  height: 220px !important;
  object-fit: cover !important;
}