/* ==========================================================================
   xSmart — Product Cards (SINGLE SOURCE OF TRUTH)
   Used on: homepage, category, search, related products
   ========================================================================== */

/* --- Base card --- */
.product-miniature,
article.product-miniature,
.xs-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 14px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
}
.product-miniature:hover,
.xs-card:hover {
  border-color: #3662A1;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}

/* --- Badges --- */
.product-miniature .product-flags,
.xs-card__badges {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  display: flex;
  gap: 4px;
}
.product-flag {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: #3662A1;
  color: #fff;
}
.product-flag.on-sale,
.product-flag.discount {
  background: #dc2626;
}
/* Hide "new" flag */
.product-flag:not(.on-sale):not(.discount) {
  display: none;
}

/* --- Image --- */
.product-miniature .thumbnail-container,
.xs-card__img {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 160px;
  margin-bottom: 10px;
  padding: 8px;
}
.product-miniature .thumbnail-container img,
.product-miniature .thumbnail-container .product-thumbnail,
.xs-card__img img {
  max-height: 140px;
  max-width: 100%;
  width: auto;
  object-fit: contain;
  margin: 0 auto;
}

/* --- Card body --- */
.xs-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* --- Title --- */
.product-miniature .product-title,
.product-miniature h3,
.xs-card__title {
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
  min-height: 35px;
}
.product-miniature .product-title a,
.xs-card__title a {
  color: #111827;
  text-decoration: none !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.product-miniature .product-title a:hover,
.xs-card__title a:hover {
  color: #3662A1;
}

/* --- Description (short, shown on category pages) --- */
.product-miniature .product-description-short {
  font-size: 11px;
  color: #6b7280;
  line-height: 1.4;
  margin: 0 0 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* Hide description on homepage horizontal scroll */
.xhome-section .product-miniature .product-description-short {
  display: none;
}

/* --- Price --- */
.product-miniature .product-price-and-shipping,
.xs-card__price-row {
  margin: 4px 0 10px;
}
.product-miniature .price,
.xs-card__price {
  font-size: 15px;
  font-weight: 700;
  color: #111827;
}
.product-miniature .regular-price,
.xs-card__price-old {
  font-size: 12px;
  color: #999;
  text-decoration: line-through;
  margin-right: 4px;
}
.product-miniature .discount-percentage,
.product-miniature .discount-amount {
  font-size: 11px;
  font-weight: 600;
  color: #dc2626;
}

/* --- "Koupit" button --- */
.product-miniature .add-to-cart-btn,
.product-miniature [data-button-action="add-to-cart"],
.xs-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 7px 18px;
  background: #3662A1;
  color: #fff !important;
  border: none;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none !important;
  transition: background 0.15s;
  cursor: pointer;
  margin-top: auto;
}
.product-miniature .add-to-cart-btn:hover,
.product-miniature [data-button-action="add-to-cart"]:hover,
.xs-card__btn:hover {
  background: #2d5289;
}
.xs-card__btn svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
}

/* --- CTA row --- */
.xs-card__cta {
  margin-top: auto;
  padding-top: 4px;
}

/* --- Hide unwanted elements --- */
.product-miniature .highlighted-informations,
.product-miniature .variant-links,
.product-miniature .product-availability,
.product-miniature .product-list-reviews {
  display: none !important;
}

/* --- Grids --- */

/* Homepage: horizontal scroll */
.xhome-section .products,
.xhome-section .xs-products-module__list {
  display: flex !important;
  overflow-x: auto !important;
  flex-wrap: nowrap !important;
  gap: 12px !important;
  padding-bottom: 6px;
}
.xhome-section .product-miniature,
.xhome-section .xs-card,
.xhome-section .product {
  min-width: 180px !important;
  max-width: 200px !important;
  flex-shrink: 0 !important;
  width: auto !important;
}

/* Category/Search: grid */
#js-product-list .products,
body.page-category .products,
body.page-search .products,
body.page-best-sales .products,
body.page-new-products .products,
body.page-prices-drop .products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
  gap: 14px !important;
  overflow-x: visible !important;
}
#js-product-list .product-miniature,
body.page-category .product-miniature {
  min-width: unset !important;
  max-width: unset !important;
  width: auto !important;
}

/* Responsive */
@media (max-width: 767px) {
  .xhome-section .product-miniature,
  .xhome-section .xs-card {
    min-width: 150px !important;
    max-width: 170px !important;
  }
  #js-product-list .products,
  body.page-category .products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 479px) {
  #js-product-list .products,
  body.page-category .products {
    grid-template-columns: 1fr !important;
  }
}
