.woocommerce ul.products li.product.tss-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 14px;
  overflow: hidden;
  padding: 0;
  margin: 0 0 20px;
}

.woocommerce ul.products li.product.tss-card:hover {
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.tss-card__image {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
}

.tss-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.tss-card__body {
  padding: 14px 14px 16px;
}

.tss-card__title {
  font-size: 15px;
  line-height: 1.25;
  margin: 0 0 8px;
}

.tss-card__title a {
  text-decoration: none;
}

.tss-card__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.tss-card__price {
  font-weight: 700;
}

.tss-card__stock {
  font-size: 12px;
  opacity: 0.85;
  white-space: nowrap;
}

.tss-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Qty */
.tss-qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(0,0,0,0.14);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.tss-qty__btn {
  width: 42px;
  height: 42px;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.tss-qty__input {
  width: 54px;
  height: 42px;
  border: 0;
  border-left: 1px solid rgba(0,0,0,0.12);
  border-right: 1px solid rgba(0,0,0,0.12);
  text-align: center;
  outline: none;
}

.tss-qty__input::-webkit-outer-spin-button,
.tss-qty__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Add to cart */
.tss-atc {
  height: 42px;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 14px !important;
  border-radius: 12px !important;
  border: 1px solid #7f174a !important;
  background: #7f174a !important;
  color: #fff !important;
  text-decoration: none !important;
}

.tss-atc:hover,
.tss-atc:focus {
  opacity: 0.92;
}

.tss-atc--disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

/* Wishlist icon */
.tss-icon-btn {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid #7f174a;
  background: #fff;
  text-decoration: none;
}

.tss-icon-btn i {
  font-size: 18px;
  line-height: 1;
  color: #7f174a;
}

.tss-icon-btn,
.tss-icon-btn:hover,
.tss-icon-btn:focus,
.tss-atc,
.tss-atc:hover,
.tss-atc:focus {
  box-shadow: none !important;
  outline: none !important;
}

/* =========================================================
   TSS GRID POLISH (alignment + equal heights + stop wrapping)
   ========================================================= */

/* Make each card a proper column so actions can sit at the bottom */
.woocommerce ul.products li.product.tss-card{
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

.woocommerce ul.products li.product.tss-card .tss-card__body{
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
}

/* Clamp title so one long title doesn't make the card taller */
.woocommerce ul.products li.product.tss-card .tss-card__title{
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  min-height: calc(2 * 1.25em) !important; /* keeps card heights consistent */
}

/* Keep actions on ONE line on desktop */
.woocommerce ul.products li.product.tss-card .tss-card__actions{
  margin-top: auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
}

/* Allow the middle button to shrink without forcing wrap */
.woocommerce ul.products li.product.tss-card .tss-card__actions > *{
  min-width: 0 !important;
}

/* Make everything the same height */
.woocommerce ul.products li.product.tss-card .tss-qty,
.woocommerce ul.products li.product.tss-card .tss-atc,
.woocommerce ul.products li.product.tss-card .tss-icon-btn{
  height: 46px !important;
}

/* Qty control: compact + aligned */
.woocommerce ul.products li.product.tss-card .tss-qty{
  flex: 0 0 auto !important;
  border-radius: 12px !important;
}

.woocommerce ul.products li.product.tss-card .tss-qty__btn{
  width: 40px !important;
  height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.woocommerce ul.products li.product.tss-card .tss-qty__input{
  width: 52px !important;
  height: 46px !important;
  line-height: 46px !important;
  padding: 0 !important;
}

/* Add to basket: fill available space, don't wrap text */
.woocommerce ul.products li.product.tss-card .tss-atc{
  flex: 1 1 auto !important;
  width: auto !important;
  white-space: nowrap !important;
}

/* Wishlist: never wrap to next line */
.woocommerce ul.products li.product.tss-card .tss-icon-btn{
  flex: 0 0 auto !important;
}

/* On small screens allow wrap, but keep it tidy */
@media (max-width: 520px){
  .woocommerce ul.products li.product.tss-card .tss-card__actions{
    flex-wrap: wrap !important;
  }
  .woocommerce ul.products li.product.tss-card .tss-atc{
    flex: 1 0 100% !important;
    width: 100% !important;
  }
}


/* =========================================================
   TSS GRID POLISH v2
   - add real spacing between cards (grid gap)
   - fix qty alignment + show +/- clearly
   - remove native number spinners (up/down arrows)
   ========================================================= */

/* 1) Give the product list a proper gap (works regardless of theme floats) */
body.post-type-archive-product .woocommerce ul.products,
body.tax-product_cat .woocommerce ul.products,
body.search.search-results.post-type-archive-product .woocommerce ul.products{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
  gap: 22px !important;
}

/* kill float/width packing from the theme */
body.post-type-archive-product .woocommerce ul.products li.product,
body.tax-product_cat .woocommerce ul.products li.product,
body.search.search-results.post-type-archive-product .woocommerce ul.products li.product{
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}

/* 2) Qty control: center everything + make +/- visible */
.woocommerce ul.products li.product.tss-card .tss-qty{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 8px !important;
  overflow: hidden !important;
}

/* Ensure buttons are visible and not clipped */
.woocommerce ul.products li.product.tss-card .tss-qty__btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 46px !important;
  width: 42px !important;

  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;

  color: #7f174a !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  padding: 0 !important;
}

/* Input: vertically centered, no extra padding pushing it "up" */
.woocommerce ul.products li.product.tss-card .tss-qty__input{
  height: 46px !important;
  width: 54px !important;
  padding: 0 !important;
  margin: 0 !important;
  text-align: center !important;
  line-height: 46px !important;
}

/* 3) Remove native number spinners (up/down arrows) */
.woocommerce ul.products li.product.tss-card .tss-qty__input::-webkit-outer-spin-button,
.woocommerce ul.products li.product.tss-card .tss-qty__input::-webkit-inner-spin-button{
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.woocommerce ul.products li.product.tss-card .tss-qty__input[type="number"]{
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}


/* =========================================================
   TSS GRID POLISH v3 - FIX "BUNCHING"
   - force the products UL to stretch full width
   - ensure cards stretch and columns distribute evenly
   ========================================================= */

body.post-type-archive-product .woocommerce ul.products,
body.tax-product_cat .woocommerce ul.products,
body.search.search-results.post-type-archive-product .woocommerce ul.products{
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;

  /* sometimes themes set these and it causes bunching */
  justify-content: stretch !important;
  justify-items: stretch !important;
  align-items: stretch !important;

  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Make sure the grid can actually fill the row */
body.post-type-archive-product .woocommerce ul.products,
body.tax-product_cat .woocommerce ul.products,
body.search.search-results.post-type-archive-product .woocommerce ul.products{
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
}

/* Ensure each product/card can stretch inside the grid cell */
body.post-type-archive-product .woocommerce ul.products li.product,
body.tax-product_cat .woocommerce ul.products li.product,
body.search.search-results.post-type-archive-product .woocommerce ul.products li.product{
  width: 100% !important;
  max-width: none !important;
}

.woocommerce ul.products li.product.tss-card{
  height: 100% !important;
}

