/* SAT Product Layout Premium v1.0.5 */

.sat-plp-hidden-cart{ display:none !important; }

.sat-plp-wrap{
  display:grid;
  grid-template-columns: 90px 1.4fr 1fr;
  gap:18px;
  align-items:start;
  margin: 18px 0 10px 0;
}
@media (max-width: 900px){
  .sat-plp-wrap{
    grid-template-columns: 74px 1fr;
    grid-template-areas:
      "thumb main"
      "right right";
  }
  .sat-plp-left{ grid-area: thumb; }
  .sat-plp-center{ grid-area: main; }
  .sat-plp-right{ grid-area: right; }
}

.sat-plp-left{ display:flex; flex-direction:column; gap:10px; }
.sat-plp-thumb{
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  overflow:hidden;
  background:#fff;
  padding:0;
  cursor:pointer;
}
.sat-plp-thumb img{ display:block; width:100%; height:auto; }
.sat-plp-thumb.is-active{ outline: 2px solid rgba(0,0,0,.35); outline-offset: 2px; }

.sat-plp-main{
  background:#fff;
  border-radius:20px;
  padding:14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.10);
  border:1px solid rgba(0,0,0,.08);
}
.sat-plp-main img{ width:100%; height:auto; display:block; border-radius:16px; }

.sat-plp-right{
  background:#fff;
  border-radius:20px;
  padding:18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.10);
  border:1px solid rgba(0,0,0,.08);
}

.sat-plp-title{ font-size:28px; font-weight:900; margin: 0 0 10px; line-height:1.1; }
@media (max-width:480px){ .sat-plp-title{ font-size:22px; } }
.sat-plp-price{ font-size:26px; font-weight:900; margin-bottom: 12px; }

.sat-plp-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.sat-plp-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:12px 14px;
  font-weight:900;
  text-decoration:none !important;
  color:#fff !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
  border:1px solid rgba(0,0,0,.08);
  flex: 1 1 calc(50% - 10px);
  min-width: 160px;
}
@media (max-width: 420px){
  .sat-plp-btn{ flex: 1 1 100%; min-width: 100%; }
}

.sat-plp-btn.primary{ background:#b70f1a; }
.sat-plp-btn.dark{ background:#111; }
.sat-plp-btn.wa{ background:#1f8f4a; }
.sat-plp-btn.call{ background:#0d3a77; }

.sat-plp-storecard{
  margin-top: 14px;
  display:flex;
  gap:14px;
  align-items:center;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.10);
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
  text-decoration:none !important;
  color:inherit !important;
}
.sat-plp-storelogo{
  width:64px;
  height:64px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  object-fit:cover;
  flex: 0 0 auto;
}
.sat-plp-storelabel{
  font-size:12px;
  font-weight:900;
  opacity:.65;
  margin-bottom:3px;
  letter-spacing:.2px;
}
.sat-plp-storename{
  font-size:20px;
  font-weight:1000;
  line-height:1.1;
}


.sat-plp-related{ margin-top:30px; padding-top:8px; }
.sat-plp-related-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:8px 0 16px;
}
.sat-plp-related-title{ font-size:28px; font-weight:900; margin:0; }
.sat-plp-related-nav{ display:flex; gap:10px; }
.sat-related-arrow{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  border-radius:999px;
  background:#fff;
  color:#222;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.sat-related-arrow:hover{ transform:translateY(-1px); }
.sat-plp-related-track{ overflow:hidden; width:100%; }
.sat-plp-like-slot{ margin-top:14px; }
.sat-plp-like-slot .sat-like-wrap{ margin-top:0; }

.sat-plp-related ul.products{
  display:grid !important;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - 72px) / 5);
  gap:18px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-behavior:smooth;
  padding:4px 2px 14px !important;
  margin:0 !important;
  list-style:none;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  align-items:stretch;
}
.sat-plp-related ul.products::-webkit-scrollbar{ display:none; }
.sat-plp-related ul.products::before,
.sat-plp-related ul.products::after{ display:none !important; }

.sat-plp-related ul.products li.product{
  width:auto !important;
  min-width:0 !important;
  max-width:none !important;
  margin:0 !important;
  float:none !important;
  list-style:none;
  background:#fff;
  border:1px solid #e8e8e8;
  border-radius:18px;
  padding:12px;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:100%;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.sat-plp-related ul.products li.product:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 24px rgba(0,0,0,.10);
  border-color:#d9d9d9;
}
.sat-plp-related ul.products li.product > a:first-of-type{
  text-decoration:none;
  color:inherit;
}
.sat-plp-related ul.products li.product img.wp-post-image,
.sat-plp-related ul.products li.product img.attachment-woocommerce_thumbnail,
.sat-plp-related ul.products li.product img.size-woocommerce_thumbnail{
  width:100% !important;
  height:190px !important;
  object-fit:contain;
  object-position:center;
  display:block;
  margin:0 0 10px !important;
  border-radius:12px;
  background:#fff;
}
.sat-plp-related ul.products li.product img:not(.wp-post-image):not(.attachment-woocommerce_thumbnail):not(.size-woocommerce_thumbnail){
  width:auto !important;
  height:auto !important;
  max-width:42px;
  max-height:42px;
  object-fit:contain;
}
.sat-plp-related ul.products li.product .woocommerce-loop-product__title{
  font-size:18px !important;
  line-height:1.28 !important;
  font-weight:600;
  color:#222;
  margin:0 0 8px !important;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:46px;
}
.sat-plp-related ul.products li.product .price{
  color:#111 !important;
  font-size:17px;
  font-weight:700;
  margin:0 0 8px !important;
}
.sat-plp-related ul.products li.product .price del{
  opacity:.55;
  font-size:.88em;
  margin-right:6px;
}
.sat-plp-related ul.products li.product .price ins{ text-decoration:none; }
.sat-plp-related ul.products li.product .button,
.sat-plp-related ul.products li.product .add_to_cart_button,
.sat-plp-related ul.products li.product .product_type_simple{
  margin-top:auto !important;
  width:100%;
  border-radius:999px !important;
  padding:11px 14px !important;
  text-align:center;
  font-weight:700;
  background:#111 !important;
  color:#fff !important;
  border:none !important;
  box-shadow:none !important;
}
.sat-plp-related ul.products li.product .star-rating{ display:none !important; }
.sat-plp-related ul.products li.product .onsale{
  top:10px !important;
  left:10px !important;
  right:auto !important;
  min-height:auto !important;
  min-width:auto !important;
  line-height:1.1 !important;
  border-radius:999px !important;
  padding:6px 10px !important;
  font-size:12px !important;
  font-weight:800 !important;
}
@media (max-width: 1100px){
  .sat-plp-related ul.products li.product{
    flex:0 0 calc(33.333% - 12px);
    width:calc(33.333% - 12px) !important;
    min-width:calc(33.333% - 12px);
    max-width:calc(33.333% - 12px);
  }
  .sat-plp-related-title{ font-size:24px; }
}

@media (max-width: 767px){
  .sat-plp-related{ margin-top:24px; }
  .sat-plp-related-head{ margin-bottom:14px; }
  .sat-plp-related-title{ font-size:22px; }
  .sat-plp-related-nav{ display:none; }
  .sat-plp-related-track{ overflow:visible; }
  .sat-plp-related ul.products{
    display:grid !important;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-auto-flow:row !important;
    grid-auto-columns:auto !important;
    gap:12px;
    overflow:visible;
    padding:0 !important;
  }
  .sat-plp-related ul.products li.product{
    flex:none;
    width:auto !important;
    min-width:0 !important;
    max-width:none !important;
    border-radius:14px;
    padding:10px;
    box-shadow:none;
  }
  .sat-plp-related ul.products li.product a img{
    height:145px !important;
    margin-bottom:8px !important;
    border-radius:10px;
  }
  .sat-plp-related ul.products li.product .woocommerce-loop-product__title{
    font-size:15px !important;
    line-height:1.25 !important;
    min-height:38px;
    margin-bottom:6px !important;
  }
  .sat-plp-related ul.products li.product .price{
    font-size:16px;
    margin-bottom:6px !important;
  }
  .sat-plp-related ul.products li.product .button,
  .sat-plp-related ul.products li.product .add_to_cart_button,
  .sat-plp-related ul.products li.product .product_type_simple{
    padding:10px 12px !important;
    font-size:14px !important;
  }
}
