/* === Фикс «Показать всё»: сетка товаров на flex === */
.product-grid,
.products-grid,
#content .row.products,
#content .product-list.grid,
.category .product-grid { 
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

/* Карточка товара: 4 в ряд на десктопе */
.product-grid .product-layout,
.products-grid .product-layout,
#content .row.products .product-layout,
#content .product-list.grid .product-layout,
.category .product-grid .product-layout {
  box-sizing: border-box;
  padding: 10px;
  width: 25%;
}

/* Адаптивные ряды */
@media (max-width: 1199.98px) {
  .product-grid .product-layout,
  .products-grid .product-layout,
  #content .row.products .product-layout,
  #content .product-list.grid .product-layout,
  .category .product-grid .product-layout { width: 33.333%; }
}
@media (max-width: 991.98px) {
  .product-grid .product-layout,
  .products-grid .product-layout,
  #content .row.products .product-layout,
  #content .product-list.grid .product-layout,
  .category .product-grid .product-layout { width: 50%; }
}
@media (max-width: 575.98px) {
  .product-grid .product-layout,
  .products-grid .product-layout,
  #content .row.products .product-layout,
  #content .product-list.grid .product-layout,
  .category .product-grid .product-layout { width: 100%; }
}

/* Равная высота карточек, чтобы ряды не «ломало» при длинных названиях/ценах */
.product-thumb, .product-layout .product-thumb {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Картинки не растягиваются и не сдвигают ряды при lazyload */
.product-thumb .image img { 
  width: 100%;
  height: auto;
  display: block;
}

/* На случай, если тема где-то оставила float — уберём влияние */
.product-layout { float: none !important; }
