/* SMB Carousel basic card styles, title clamp, and price emphasis. */
.smb-carousel { --smb-card-height: 340px; }
.smb-carousel .wd-carousel-item { height: var(--smb-card-height); }
.smb-carousel .smb-card { position: relative; background: #fff !important; border-radius: 12px; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,.06); padding: 10px; display: flex; flex-direction: column; gap: 8px; height: 100%; }
/* Gambar seragam: kotak rasio 1:1, gambar contain agar tinggi/lebar konsisten */
.smb-carousel .smb-image { display: block; position: relative; width: 100%; aspect-ratio: var(--smb-image-ratio, 1 / 1); background: #fff !important; border-radius: 6px; overflow: hidden; }
.smb-carousel .smb-thumb { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 1; background:#fff; }
/* Fallback ratio 1:1 untuk browser tanpa dukungan aspect-ratio */
@supports not (aspect-ratio: 1 / 1) {
  .smb-carousel .smb-image::before { content: ""; display: block; padding-top: 100%; }
}
/* Badge image overlay — positioned bottom-left like reference */
.smb-carousel .smb-badge { position: absolute; left: 8px; bottom: 8px; z-index: 2; display: inline-block; }
.smb-carousel .smb-badge-img { display: block; width: 64px; height: auto; border-radius: 4px; box-shadow: 0 1px 2px rgba(0,0,0,.15); }
.smb-carousel .smb-title {
  display: -webkit-box;
  -webkit-line-clamp: var(--smb-title-lines,2);
  -webkit-box-orient: vertical;
  line-clamp: var(--smb-title-lines,2);
  overflow: hidden;
  font-size: 13px;
  color: #111;
  margin: 0;
  line-height: 1.35;
  min-height: calc(1.35em * var(--smb-title-lines,2));
  height: calc(1.35em * var(--smb-title-lines,2));
}
.smb-carousel .smb-price { display: flex; align-items: center; gap: 8px; height: 30px; margin-top: auto; white-space: nowrap; }
.smb-carousel .smb-sale, .smb-carousel .smb-sale .amount, .smb-carousel .smb-sale .woocommerce-Price-amount, .smb-carousel .smb-sale bdi { color: #111 !important; font-weight: 700; }
.smb-carousel .smb-percent { color: #e53935; font-weight: 700; font-size: 12px; background: transparent; border-radius: 0; padding: 0; flex-shrink: 0; }
.smb-carousel .smb-regular { color: #777; }

/* Professional overlay navigation arrows */
.smb-carousel .wd-carousel-inner { position: relative; }
.smb-carousel .wd-carousel-wrap { display:flex; align-items: stretch; }
.smb-carousel .wd-carousel-item { display: flex; align-items: stretch; }

/* Apply responsive column widths using WoodMart variables */
.smb-carousel .wd-carousel-item {
  flex: 0 0 calc(100% / var(--wd-col-lg, 5)) !important;
  width: calc(100% / var(--wd-col-lg, 5)) !important;
  max-width: calc(100% / var(--wd-col-lg, 5)) !important;
}

@media (max-width: 1024px) {
  .smb-carousel .wd-carousel-item {
    flex: 0 0 calc(100% / var(--wd-col-md, var(--wd-col-lg, 4))) !important;
    width: calc(100% / var(--wd-col-md, var(--wd-col-lg, 4))) !important;
    max-width: calc(100% / var(--wd-col-md, var(--wd-col-lg, 4))) !important;
  }
}

@media (max-width: 767px) {
  .smb-carousel .wd-carousel-item {
    flex: 0 0 calc(100% / var(--wd-col-sm, 2)) !important;
    width: calc(100% / var(--wd-col-sm, 2)) !important;
    max-width: calc(100% / var(--wd-col-sm, 2)) !important;
  }
}

.smb-carousel .wd-carousel-item > .smb-card { flex: 1 1 auto; }
.smb-carousel .wd-carousel { scroll-behavior: smooth; }
.smb-carousel .wd-carousel .wd-carousel-wrap { will-change: transform; }
.smb-carousel .smb-arrow { outline: none; }
.smb-carousel .wd-carousel-container { --smb-card-height: 320px; }
.smb-carousel .wd-carousel-inner, .smb-carousel .wd-carousel-wrap { background: transparent !important; }
.smb-carousel .wd-carousel-item { background: transparent !important; border-radius: 0; padding: 8px; height: var(--smb-card-height); box-shadow: none; }
.smb-carousel .wd-nav-arrows { position: absolute; left: 0; right: 0; top: 50%; transform: translateY(-50%); z-index: 260; pointer-events: none; }
.smb-carousel .wd-btn-arrow { position: absolute; top: 0; pointer-events: auto; opacity: 1; visibility: visible; width: var(--smb-arrow-hit, 44px); height: var(--smb-arrow-hit, 44px); display: flex; align-items: center; justify-content: center; }
.smb-carousel .wd-btn-arrow.wd-prev { display: none; }
.smb-carousel .wd-btn-arrow.wd-next .wd-arrow-inner { background: var(--smb-arrow-bg); color: var(--smb-arrow-color); }
.smb-carousel .wd-nav-arrows.wd-pos-sep { --wd-arrow-offset-h: -16px; --wd-arrow-offset-v: 0px; }
.smb-carousel .wd-btn-arrow.wd-disabled { opacity: .45; }
.smb-carousel .wd-arrow-inner:after { content: none !important; }
.smb-carousel .wd-nav-arrows.wd-pos-sep:after { content: none; }
.smb-carousel .wd-nav-arrows.wd-pos-sep .wd-next { left: auto !important; right: var(--smb-arrow-inset-right, 16px) !important; top: 50% !important; transform: translateY(-50%) !important; }
.smb-carousel .wd-nav-arrows.wd-hover-1 { pointer-events: auto; }
.smb-carousel .wd-nav-arrows.wd-hover-1 .wd-btn-arrow { pointer-events: auto; }
.smb-carousel .wd-arrow-inner { cursor: pointer; }
.smb-carousel .wd-arrow-inner { width: var(--smb-arrow-size, 32px); height: var(--smb-arrow-size, 32px); border-radius: 999px; background: var(--smb-arrow-bg, #fff); box-shadow: 0 6px 18px rgba(0,0,0,.12); color: var(--smb-arrow-color, #fff); display: inline-flex; align-items: center; justify-content: center; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; pointer-events: auto; border: none; }
.smb-carousel .wd-arrow-inner.smb-arrow::before { content:"\f113"; font-family:"woodmart-font"; font-size:14px; color:currentColor; }
.smb-carousel .wd-arrow-inner:hover, .smb-carousel .wd-arrow-inner:focus { transform: scale(1.06); box-shadow: 0 8px 22px rgba(0,0,0,.18); background: #fff; }

@media (max-width: 767px) {
  .smb-carousel .wd-arrow-inner { width: 34px; height: 34px; box-shadow: 0 4px 12px rgba(0,0,0,.12); }
  .smb-carousel .wd-nav-arrows { padding: 0 4px; }
}
@media (max-width: 1024px) { .smb-carousel { --smb-card-height: 320px; } }
@media (max-width: 767px) { .smb-carousel { --smb-card-height: 300px; } }
