/* ════════════════════════════════════════════════════════════
   PINNACLE FABWORKS — Product Card v3.0
   Premium Atelier-Grade Design System
   Engineered for all devices: 4K → Mobile
   ════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root {
  /* Shape */
  --pfwcard-radius: 16px;
  --pfwcard-border: 1px solid rgba(139, 26, 74, 0.06);
  --pfwcard-shadow-rest:
    0 1px 3px rgba(0, 0, 0, 0.02), 0 4px 12px rgba(139, 26, 74, 0.03);
  --pfwcard-shadow-hover:
    0 8px 30px rgba(139, 26, 74, 0.1), 0 2px 8px rgba(0, 0, 0, 0.04);
  --pfwcard-img-height: 280px;
  --pfwcard-img-bg: #ffffff;

  /* Brand Palette */
  --pfwcard-brand: #8b1a4a;
  --pfwcard-brand-light: #fbf5f8;
  --pfwcard-brand-hover: #a8215a;
  --pfwcard-brand-glow: rgba(139, 26, 74, 0.12);

  /* Text */
  --pfwcard-text: #1a1720;
  --pfwcard-text-secondary: #4a4550;
  --pfwcard-muted: #918d90;

  /* Typography */
  --pfwcard-font-serif:
    "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --pfwcard-font-sans: "DM Sans", "Inter", -apple-system, sans-serif;

  /* Spacing scale */
  --pfwcard-space-xs: 4px;
  --pfwcard-space-sm: 8px;
  --pfwcard-space-md: 16px;
  --pfwcard-space-lg: 24px;
  --pfwcard-space-xl: 32px;

  /* Animation */
  --pfwcard-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --pfwcard-ease-out: cubic-bezier(0.33, 1, 0.68, 1);
}

/* ── BASE CARD ── */
li.pfwcard {
  position: relative;
  border-radius: var(--pfwcard-radius);
  border: var(--pfwcard-border);
  overflow: hidden;
  background: #ffffff;
  box-shadow: var(--pfwcard-shadow-rest);
  transition:
    transform 0.45s var(--pfwcard-ease),
    box-shadow 0.45s var(--pfwcard-ease),
    border-color 0.3s ease;
  list-style: none;
  padding: 0 !important;
  margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  height: 100%;
  will-change: transform;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

li.pfwcard:hover {
  box-shadow: var(--pfwcard-shadow-hover);
  border-color: rgba(139, 26, 74, 0.1);
}

/* ── ULTIMATE HOVER RESET ── */
/* This kills vertical movement for the card itself and any children (except the image zoom) */
li.pfwcard, 
li.pfwcard:hover,
li.pfwcard:hover .pfwcard__info,
/*li.pfwcard:hover .pfwcard__actions,*/
li.pfwcard:hover .pfwcard__price,
li.pfwcard:hover .pfwcard__name,
li.pfwcard:hover .pfwcard__category,
li.pfwcard:hover .pfwcard__atc-btn,
li.pfwcard:hover .button {
  transform: translateY(0) !important;
  margin-top: 0 !important;
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Re-allow the image to zoom (since that's a good feature) */
li.pfwcard:hover .pfwcard__img {
  transform: scale(1.04) !important;
}

/* ── DIVI GRID EQUAL HEIGHT FIX ── */
.woocommerce ul.products,
.woocommerce-page ul.products,
.et_pb_shop ul.products,
.et_pb_module ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  padding: 0 !important;
  list-style: none !important;
  width: 100% !important;
  max-width: 100% !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.et_pb_shop ul.products::before,
.et_pb_shop ul.products::after {
  display: none !important;
  content: none !important;
}
.woocommerce ul.products li.pfwcard,
.woocommerce ul.products li.product,
.et_pb_shop ul.products li.product {
  float: none !important;
  height: auto !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  clear: none !important;
}

/* ── DIVI COLUMN-CLASS OVERRIDE (kills width:48% from Divi core) ── */
.et_pb_shop ul.products.columns-2 li.product,
.et_pb_shop ul.products.columns-3 li.product,
.et_pb_shop ul.products.columns-4 li.product,
.et_pb_shop ul.products.columns-5 li.product,
.et_pb_shop ul.products.columns-6 li.product,
.woocommerce ul.products.columns-2 li.product,
.woocommerce ul.products.columns-3 li.product,
.woocommerce ul.products.columns-4 li.product,
.woocommerce ul.products.columns-5 li.product,
.woocommerce ul.products.columns-6 li.product {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  clear: none !important;
}

/* ── IMAGE WRAPPER ── */
.pfwcard__image-wrap {
  position: relative;
  overflow: hidden;
  background: #ffffff;
  display: block;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0;
  font-size: 0;
}

.pfwcard__image-wrap a {
  display: block;
  line-height: 0;
  font-size: 0;
  margin: 0 !important;
  padding: 0 !important;
}

.pfwcard__img {
  display: block;
  width: 100%;
  height: var(--pfwcard-img-height);
  object-fit: cover;
  object-position: center;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  transition:
    transform 0.7s var(--pfwcard-ease),
    filter 0.5s ease;
  backface-visibility: hidden;
}

li.pfwcard:hover .pfwcard__img {
  transform: scale(1.04);
}

/* ── SALE BADGE ── */
.pfwcard__sale-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--pfwcard-brand);
  color: #ffffff;
  font-family: var(--pfwcard-font-sans);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 20px;
  line-height: 1;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(139, 26, 74, 0.25);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* ══════════════════════════════════════════════════════════
   WISHLIST BUTTON — YITH WooCommerce Wishlist v3+
   Targets actual YITH v3 class names from add-to-wishlist.scss
   ══════════════════════════════════════════════════════════ */

/* ── Override YITH's default SVG size globally on our cards ── */
li.pfwcard svg.yith-wcwl-icon-svg,
li.pfwcard .yith-wcwl-icon,
li.pfwcard img.yith-wcwl-custom-icon {
  width: 16px !important;
  height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
}

/* ── Outer wrapper block — position absolute over image ── */
li.pfwcard .yith-add-to-wishlist-button-block,
.pfwcard__image-wrap .yith-add-to-wishlist-button-block,
.woocommerce li.pfwcard .yith-add-to-wishlist-button-block,
.et_pb_shop li.product .yith-add-to-wishlist-button-block {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 10 !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

/* Also handle older YITH wrapper (.yith-wcwl-add-to-wishlist) */
li.pfwcard .yith-wcwl-add-to-wishlist,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist,
.woocommerce li.pfwcard .yith-wcwl-add-to-wishlist,
.et_pb_shop li.product .yith-wcwl-add-to-wishlist {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 10 !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

/* ── The actual button/anchor — frosted glass circle ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button,
li.pfwcard button.yith-wcwl-add-to-wishlist-button,
li.pfwcard a.yith-wcwl-add-to-wishlist-button,
li.pfwcard a.yith-wcwl-add-to-wishlist-button-anchor-wrapper,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist-button,
.woocommerce li.pfwcard .yith-wcwl-add-to-wishlist-button,
.et_pb_shop li.product .yith-wcwl-add-to-wishlist-button,
/* Older YITH selectors */
li.pfwcard .yith-wcwl-add-to-wishlist a,
li.pfwcard .yith-wcwl-add-to-wishlist button,
li.pfwcard .yith-wcwl-add-to-wishlist a.add_to_wishlist,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist a,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  max-width: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
  flex-direction: row !important;
  transition:
    background 0.3s ease,
    border-color 0.3s ease,
    transform 0.3s ease,
    box-shadow 0.3s ease !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
  text-decoration: none !important;
  overflow: hidden !important;
  cursor: pointer !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

/* ── Anchor wrapper YITH adds around button ── */
li.pfwcard a.yith-wcwl-add-to-wishlist-button__wrapper,
.pfwcard__image-wrap a.yith-wcwl-add-to-wishlist-button__wrapper {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  width: 36px !important;
  height: 36px !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ── HIDE text label — "Add to wishlist" etc. ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button__label,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button
  .yith-wcwl-add-to-wishlist-button__label,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist-button__label,
li.pfwcard .yith-wcwl-add-to-wishlist__feedback,
li.pfwcard .yith-wcwl-add-to-wishlist-tooltip,
li.pfwcard .yith-wcwl-add-to-wishlist .feedback,
li.pfwcard .yith-wcwl-add-to-wishlist__counter,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button
  .yith-wcwl-add-to-wishlist__counter {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  position: absolute !important;
  clip: rect(0, 0, 0, 0) !important;
  visibility: hidden !important;
}

/* ── SHOW the icon wrapper span ── */
li.pfwcard .yith-wcwl-icon-svg__wrapper,
li.pfwcard .yith-wcwl-add-to-wishlist-button .yith-wcwl-icon-svg__wrapper,
li.pfwcard .yith-wcwl-add-to-wishlist-button__icon,
li.pfwcard .yith-wcwl-add-to-wishlist .yith-wcwl-add-to-wishlist-button__icon,
.pfwcard__image-wrap .yith-wcwl-icon-svg__wrapper,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist-button__icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 16px !important;
  height: 16px !important;
  position: static !important;
  clip: auto !important;
  visibility: visible !important;
  overflow: visible !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── SVG heart icon — default (outline) state ── */
li.pfwcard svg.yith-wcwl-icon-svg,
li.pfwcard .yith-wcwl-add-to-wishlist-button svg.yith-wcwl-icon-svg,
li.pfwcard .yith-wcwl-add-to-wishlist-button svg,
li.pfwcard .yith-wcwl-add-to-wishlist svg,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button
  svg.yith-wcwl-add-to-wishlist-button-icon,
li.pfwcard .yith-wcwl-add-to-wishlist-button img.yith-wcwl-custom-icon,
.pfwcard__image-wrap svg.yith-wcwl-icon-svg,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist svg {
  width: 16px !important;
  height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  color: var(--pfwcard-brand) !important;
  fill: none !important;
  stroke: var(--pfwcard-brand) !important;
  stroke-width: 1.5px !important;
  transition:
    fill 0.3s ease,
    stroke 0.3s ease !important;
  display: inline-block !important;
  visibility: visible !important;
}

/* Also handle <i> font icons (older YITH / FA) */
li.pfwcard .yith-wcwl-add-to-wishlist i,
li.pfwcard .yith-wcwl-add-to-wishlist-button i,
.pfwcard__image-wrap .yith-wcwl-add-to-wishlist i {
  font-size: 14px !important;
  width: 14px !important;
  height: 14px !important;
  color: var(--pfwcard-brand) !important;
  display: inline-block !important;
  visibility: visible !important;
  line-height: 1 !important;
}

/* ── Hover state ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button:hover,
li.pfwcard .yith-wcwl-add-to-wishlist a:hover,
li.pfwcard .yith-wcwl-add-to-wishlist button:hover {
  background: #ffffff !important;
  border-color: var(--pfwcard-brand) !important;
  transform: scale(1.1) !important;
  box-shadow: 0 4px 16px var(--pfwcard-brand-glow) !important;
}
li.pfwcard .yith-wcwl-add-to-wishlist-button:hover svg,
li.pfwcard .yith-wcwl-add-to-wishlist a:hover svg,
li.pfwcard .yith-wcwl-add-to-wishlist button:hover svg {
  fill: var(--pfwcard-brand) !important;
  stroke: var(--pfwcard-brand) !important;
}
li.pfwcard .yith-wcwl-add-to-wishlist-button:hover i,
li.pfwcard .yith-wcwl-add-to-wishlist a:hover i,
li.pfwcard .yith-wcwl-add-to-wishlist button:hover i {
  color: var(--pfwcard-brand) !important;
}

/* ── Added / exists in wishlist state — filled heart + brand border ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button--added,
li.pfwcard button.yith-wcwl-add-to-wishlist-button--added,
li.pfwcard a.yith-wcwl-add-to-wishlist-button--added,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button.yith-wcwl-add-to-wishlist-button--added {
  border-color: rgba(139, 26, 74, 0.2) !important;
  background: rgba(255, 255, 255, 0.95) !important;
}
li.pfwcard .yith-wcwl-add-to-wishlist-button--added svg,
li.pfwcard .yith-wcwl-add-to-wishlist-button--added svg.yith-wcwl-icon-svg,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button--added
  svg.yith-wcwl-add-to-wishlist-button-icon {
  fill: var(--pfwcard-brand) !important;
  stroke: var(--pfwcard-brand) !important;
  color: var(--pfwcard-brand) !important;
}
li.pfwcard .yith-wcwl-add-to-wishlist-button--added i {
  color: var(--pfwcard-brand) !important;
}
/* Older YITH added/exists wrappers */
li.pfwcard .yith-wcwl-wishlistaddedbrowse a,
li.pfwcard .yith-wcwl-wishlistaddedbrowse button,
li.pfwcard .yith-wcwl-wishlistexistsbrowse a,
li.pfwcard .yith-wcwl-wishlistexistsbrowse button {
  border-color: rgba(139, 26, 74, 0.2) !important;
  background: rgba(255, 255, 255, 0.95) !important;
}
li.pfwcard .yith-wcwl-wishlistaddedbrowse svg,
li.pfwcard .yith-wcwl-wishlistexistsbrowse svg {
  fill: var(--pfwcard-brand) !important;
  stroke: var(--pfwcard-brand) !important;
  color: var(--pfwcard-brand) !important;
}

/* ── Override YITH CSS custom properties on our cards ── */
li.pfwcard,
li.pfwcard .yith-add-to-wishlist-button-block,
li.pfwcard .yith-wcwl-add-to-wishlist {
  --add-to-wishlist-icon-color: var(--pfwcard-brand) !important;
  --added-to-wishlist-icon-color: var(--pfwcard-brand) !important;
  --color-add-to-wishlist-background: rgba(255, 255, 255, 0.92) !important;
  --color-add-to-wishlist-text: transparent !important;
  --color-add-to-wishlist-border: rgba(255, 255, 255, 0.5) !important;
  --color-add-to-wishlist-background-hover: #ffffff !important;
  --color-add-to-wishlist-text-hover: transparent !important;
  --color-add-to-wishlist-border-hover: var(--pfwcard-brand) !important;
  --rounded-corners-radius: 50% !important;
}

/* ── Loading state ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button--loading,
li.pfwcard .yith-wcwl-add-to-wishlist .ajax-loading,
li.pfwcard .yith-wcwl-add-to-wishlist .yith-wcwl-icon-spinner {
  cursor: progress !important;
}

/* ── Feedback popup — hide on card (it shows globally) ── */
li.pfwcard .yith-wcwl-add-to-wishlist__feedback,
li.pfwcard
  .yith-wcwl-add-to-wishlist__feedback.yith-wcwl-add-to-wishlist__feedback-on-product-image {
  display: none !important;
}

/* ── Over-image style from YITH — force our styling ── */
li.pfwcard .yith-wcwl-add-to-wishlist-button-over-image,
li.pfwcard
  .yith-wcwl-add-to-wishlist-button.yith-wcwl-add-to-wishlist-button-over-image {
  position: static !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  max-width: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
  padding: 0 !important;
  gap: 0 !important;
  overflow: hidden !important;
  font-size: 0 !important;
  color: transparent !important;
}

/* ── INFO AREA ── */
.pfwcard__info {
  padding: 10px 14px 14px;
  background: #ffffff;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  margin-top: 0 !important;
  border-top: none !important;
}

/* ── CATEGORY LABEL ── */
.pfwcard__category,
li.pfwcard .pfwcard__info .pfwcard__category,
.woocommerce li.pfwcard .pfwcard__category {
  display: block;
  font-family: var(--pfwcard-font-sans) !important;
  font-size: 9px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pfwcard-muted) !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3 !important;
}

/* ── PRODUCT NAME ── */
.pfwcard__name-link {
  text-decoration: none;
}

.pfwcard__name,
li.pfwcard .pfwcard__info h2.pfwcard__name,
.woocommerce li.pfwcard h2.pfwcard__name,
.et_pb_shop li.product h2.pfwcard__name,
.woocommerce ul.products li.product .pfwcard__name {
  font-family: 'DM Sans',sans-serif !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: #1A1A1A !important;
  line-height: 1.3 !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  transition: color 0.25s ease;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
  hyphens: auto;
  text-transform: none !important;
  letter-spacing: 0 !important;
  text-align: left;
}
.single-product.woocommerce div.product div.dfw-1-woo-image .flex-active {
	box-shadow: 0 0 0 2px #A8215A !important;
	border-radius: 6px;
}
.single-product.woocommerce div.product_meta a {
	color: #A8215A !important;
}
.single-product.woocommerce ul.products li.product a img, .single-product.woocommerce-page ul.products li.product a img {
	border-radius: 0 !important;
}

.pfwcard__name-link:hover .pfwcard__name {
  color: var(--pfwcard-brand);
}
.woocommerce div.product .dfw-1-add-to-cart form.cart .variations tr td {
	width: 100% !important;
	padding: 0 0 10px 0 !important;
}
.single-product h2 {
	font-family: 'Cormorant Garamond',serif !important;
}
/* ── PRICE ── */
.pfwcard__price {
  margin-bottom: 10px;
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px;
}

.pfwcard__price .price,
li.pfwcard .pfwcard__price .price,
.woocommerce li.pfwcard .pfwcard__price .price,
.woocommerce ul.products li.product .pfwcard__price .price,
.et_pb_shop li.product .pfwcard__price .price {
  font-family: var(--pfwcard-font-sans) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--pfwcard-text) !important;
  display: inline !important;
  line-height: 1.4 !important;
  white-space: nowrap;
  margin: 0 !important;
  padding: 0 !important;
}

.pfwcard__price .price del,
li.pfwcard .pfwcard__price .price del {
  color: var(--pfwcard-muted) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  text-decoration: line-through;
  opacity: 0.6;
  display: inline !important;
  margin-right: 4px;
}

.pfwcard__price .price ins,
li.pfwcard .pfwcard__price .price ins {
  text-decoration: none !important;
  font-weight: 700 !important;
  display: inline !important;
  color: var(--pfwcard-brand) !important;
  background: none !important;
}

/* Price range separator — keep inline */
.pfwcard__price .price > span,
.pfwcard__price .price .woocommerce-Price-amount {
  display: inline !important;
  white-space: nowrap;
}

/* ── ADD TO CART BUTTON ── */
.pfwcard__actions {
  margin-top: auto;
  width: 100%;
}

.pfwcard__actions .pfwcard__atc-btn, .pfwcard__actions .button, .pfwcard__actions a.button, .pfwcard__actions a.add_to_cart_button, .pfwcard__actions a.product_type_variable {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 90%;
	padding: 0.3em 2em 0.3em 1em;
	border-radius: 3px;
	background: var(--pfwcard-brand-light) !important;
	color: var(--pfwcard-brand) !important;
	font-family: var(--pfwcard-font-sans);
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none !important;
	text-align: center;
	border: 1px solid #F3C4D4;
	cursor: pointer;
	transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
	line-height: 1.7em;
	margin: 0 auto;
}

.pfwcard__actions .pfwcard__atc-btn:hover,
.pfwcard__actions .button:hover,
.pfwcard__actions a.button:hover,
.pfwcard__actions a.add_to_cart_button:hover,
.pfwcard__actions a.product_type_variable:hover {
  background: var(--pfwcard-brand) !important;
  color: #ffffff !important;
  border-color: var(--pfwcard-brand);
  box-shadow: 0 4px 14px var(--pfwcard-brand-glow);
  transform: none !important; /* Forces the button to stay still */
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS — ALL DEVICES
   4K → Desktop → Laptop → iPad Pro → iPad → Phablet → Mobile
   ════════════════════════════════════════════════════════════ */

/* ── 4K / Ultra-wide (2560px+) ── */
@media (min-width: 2560px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 32px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 360px;
    --pfwcard-radius: 18px;
  }
  .pfwcard__info {
    padding: 16px 20px 20px;
  }
  .pfwcard__category {
    font-size: 10px;
    margin-bottom: 8px;
  }
  .pfwcard__name {
    font-size: 19px;
    margin-bottom: 8px;
  }
  .pfwcard__price .price {
    font-size: 17px;
  }
  .pfwcard__price {
    margin-bottom: 14px;
  }
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  .pfwcard__actions a.button {
    padding: 12px 8px;
    font-size: 11px;
    border-radius: 10px;
  }
}

/* ── Large Desktop (1440px – 2559px) ── */
@media (min-width: 1440px) and (max-width: 2559px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 24px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 280px;
  }
  .pfwcard__info {
    padding: 14px 16px 16px;
  }
  .pfwcard__name {
    font-size: 16px;
  }
  .pfwcard__price .price {
    font-size: 14px;
  }
}

/* ── Standard Desktop (1024px – 1439px) ── */
@media (min-width: 1024px) and (max-width: 1439px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 18px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 230px;
  }
  .pfwcard__info {
    padding: 12px 14px 14px;
  }
  .pfwcard__name {
    font-size: 15px;
  }
  .pfwcard__price .price {
    font-size: 13px;
  }
}

/* ── iPad Landscape / Small Laptop (768px – 1023px) ── */
@media (min-width: 768px) and (max-width: 1023px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 210px;
    --pfwcard-radius: 12px;
  }
  .pfwcard__info,
  li.pfwcard .pfwcard__info {
    padding: 10px 12px 12px !important;
  }
  .pfwcard__category,
  li.pfwcard .pfwcard__info .pfwcard__category {
    font-size: 8px !important;
    margin: 0 0 4px 0 !important;
  }
  .pfwcard__name,
  li.pfwcard .pfwcard__info h2.pfwcard__name,
  .woocommerce li.pfwcard h2.pfwcard__name {
    font-size: 14px !important;
    margin: 0 0 5px 0 !important;
  }
  .pfwcard__price .price,
  li.pfwcard .pfwcard__price .price {
    font-size: 13px !important;
  }
  .pfwcard__price,
  li.pfwcard .pfwcard__price {
    margin-bottom: 8px !important;
  }
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  .pfwcard__actions a.button {
    padding: 9px 6px !important;
    font-size: 9px !important;
    border-radius: 7px !important;
  }
}

/* ── iPad Portrait / Tablet (600px – 767px) ── */
@media (min-width: 600px) and (max-width: 767px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 200px;
    --pfwcard-radius: 12px;
  }
  .pfwcard__info,
  li.pfwcard .pfwcard__info {
    padding: 10px 12px 12px !important;
  }
  .pfwcard__category,
  li.pfwcard .pfwcard__info .pfwcard__category {
    font-size: 8px !important;
    margin: 0 0 4px 0 !important;
  }
  .pfwcard__name,
  li.pfwcard .pfwcard__info h2.pfwcard__name,
  .woocommerce li.pfwcard h2.pfwcard__name {
    font-size: 14px !important;
    margin: 0 0 5px 0 !important;
  }
  .pfwcard__price .price,
  li.pfwcard .pfwcard__price .price {
    font-size: 13px !important;
  }
  .pfwcard__price,
  li.pfwcard .pfwcard__price {
    margin-bottom: 8px !important;
  }
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  .pfwcard__actions a.button {
    padding: 9px 6px !important;
    font-size: 9px !important;
    border-radius: 7px !important;
  }
}

/* ── Mobile — FORCE 2 COLUMNS (max 599px) ── */
@media (max-width: 599px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .et_pb_shop ul.products,
  .et_pb_module ul.products,
  .et_pb_wc_related_products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    padding: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .woocommerce ul.products li.product,
  .woocommerce ul.products li.pfwcard,
  .et_pb_shop ul.products li.product {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    float: none !important;
    box-sizing: border-box !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 180px;
    --pfwcard-radius: 10px;
    margin-bottom: 0 !important;
  }
  .pfwcard__info,
  li.pfwcard .pfwcard__info {
    padding: 8px 10px 10px !important;
  }
  .pfwcard__category,
  li.pfwcard .pfwcard__info .pfwcard__category,
  .woocommerce li.pfwcard .pfwcard__category {
    font-size: 7px !important;
    letter-spacing: 0.08em !important;
    margin: 0 0 3px 0 !important;
  }
  .pfwcard__name,
  li.pfwcard .pfwcard__info h2.pfwcard__name,
  .woocommerce li.pfwcard h2.pfwcard__name,
  .woocommerce ul.products li.product .pfwcard__name {
    font-size: 12px !important;
    margin: 0 0 4px 0 !important;
    line-height: 1.25 !important;
  }
  .pfwcard__price .price,
  li.pfwcard .pfwcard__price .price,
  .woocommerce li.pfwcard .pfwcard__price .price {
    font-size: 12px !important;
  }
  .pfwcard__price .price del,
  li.pfwcard .pfwcard__price .price del {
    font-size: 10px !important;
  }
  .pfwcard__price,
  li.pfwcard .pfwcard__price {
    margin-bottom: 8px !important;
    gap: 3px;
  }
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  .pfwcard__actions a.button,
  .pfwcard__actions a.add_to_cart_button,
  .pfwcard__actions a.product_type_variable {
    padding: 8px 4px !important;
    font-size: 8px !important;
    letter-spacing: 0.05em !important;
    border-radius: 6px !important;
  }
  .pfwcard__sale-badge {
    font-size: 7px !important;
    padding: 3px 8px;
    top: 8px;
    left: 8px;
    border-radius: 14px;
  }
  li.pfwcard .yith-wcwl-add-to-wishlist,
  li.pfwcard .yith-add-to-wishlist-button-block {
    top: 8px !important;
    right: 8px !important;
    width: 28px !important;
    height: 28px !important;
  }
  li.pfwcard .yith-wcwl-add-to-wishlist-button,
  li.pfwcard .yith-wcwl-add-to-wishlist a,
  li.pfwcard .yith-wcwl-add-to-wishlist button {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
  }
  li.pfwcard .yith-wcwl-add-to-wishlist svg.yith-wcwl-icon-svg,
  li.pfwcard .yith-wcwl-add-to-wishlist-button svg.yith-wcwl-icon-svg,
  li.pfwcard .yith-wcwl-add-to-wishlist svg,
  li.pfwcard .yith-wcwl-add-to-wishlist i,
  li.pfwcard .yith-wcwl-add-to-wishlist-button svg,
  li.pfwcard .yith-wcwl-add-to-wishlist-button i {
    width: 12px !important;
    height: 12px !important;
    font-size: 12px !important;
  }
}

/* ── Small Mobile (max 374px — iPhone SE) ── */
@media (max-width: 374px) {
  .woocommerce ul.products,
  .et_pb_shop ul.products {
    gap: 8px !important;
  }
  li.pfwcard {
    --pfwcard-img-height: 150px;
    --pfwcard-radius: 8px;
  }
  .pfwcard__info,
  li.pfwcard .pfwcard__info {
    padding: 6px 8px 8px !important;
  }
  .pfwcard__category,
  li.pfwcard .pfwcard__info .pfwcard__category {
    font-size: 6px !important;
    margin: 0 0 2px 0 !important;
  }
  .pfwcard__name,
  li.pfwcard .pfwcard__info h2.pfwcard__name,
  .woocommerce li.pfwcard h2.pfwcard__name {
    font-size: 11px !important;
    margin: 0 0 3px 0 !important;
  }
  .pfwcard__price .price,
  li.pfwcard .pfwcard__price .price {
    font-size: 11px !important;
  }
  .pfwcard__price,
  li.pfwcard .pfwcard__price {
    margin-bottom: 6px !important;
  }
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  .pfwcard__actions a.button {
    padding: 7px 4px !important;
    font-size: 7px !important;
    border-radius: 5px !important;
  }
}

/* ── Touch Device: Remove hover lift on touch ── */
@media (hover: none) and (pointer: coarse) {
  li.pfwcard:hover {
    transform: none;
    box-shadow: var(--pfwcard-shadow-rest);
  }
  li.pfwcard:active {
    transform: scale(0.98);
    transition-duration: 0.12s;
  }
  li.pfwcard:hover .pfwcard__img {
    transform: none;
  }
}

/* ── Landscape orientation for phones ── */
@media (max-width: 896px) and (orientation: landscape) {
  li.pfwcard {
    --pfwcard-img-height: 180px;
  }
}

/* ── High-DPI / Retina fine tuning ── */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  li.pfwcard {
    border-width: 0.5px;
  }
}

/* ── Reduced Motion Preference ── */
@media (prefers-reduced-motion: reduce) {
  li.pfwcard,
  .pfwcard__img,
  .pfwcard__actions .pfwcard__atc-btn,
  .pfwcard__actions .button,
  li.pfwcard .yith-wcwl-add-to-wishlist a {
    transition: none !important;
  }
  li.pfwcard:hover .pfwcard__img {
    transform: none;
  }
}

/* ════════════════════════════════════════════════════════════
   QUICK VIEW MODAL (YITH WCQV) & VARIATIONS
   Premium Atelier Look & Feel inside the Modal
   ════════════════════════════════════════════════════════════ */
#yith-quick-view-modal .yith-wcqv-main {
  border-radius: var(--pfwcard-radius) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important;
  overflow: hidden !important;
  background: #ffffff !important;
}

#yith-quick-view-close {
  color: var(--pfwcard-text) !important;
  border: 1px solid rgba(139, 26, 74, 0.08) !important;
  background: rgba(255,255,255,0.9) !important;
  backdrop-filter: blur(8px) !important;
  border-radius: 50% !important;
  top: 15px !important;
  right: 15px !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
  z-index: 99 !important;
}

#yith-quick-view-close:hover {
  background: var(--pfwcard-brand) !important;
  color: #fff !important;
  transform: rotate(90deg);
}

#yith-quick-view-modal .product .summary {
  padding: 40px !important;
}

#yith-quick-view-modal .product h1.product_title {
  font-family: var(--pfwcard-font-serif) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--pfwcard-text) !important;
  margin-bottom: 12px !important;
  line-height: 1.2 !important;
}

#yith-quick-view-modal .product .price {
  font-family: var(--pfwcard-font-sans) !important;
  color: var(--pfwcard-brand) !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  border-bottom: 1px solid rgba(139, 26, 74, 0.06) !important;
  padding-bottom: 20px !important;
  margin-bottom: 20px !important;
}

#yith-quick-view-modal .woocommerce-variation-add-to-cart {
  padding-top: 20px !important;
  margin-top: 20px !important;
  border-top: 1px solid rgba(139, 26, 74, 0.06) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
}

#yith-quick-view-modal form.cart .button {
  background: var(--pfwcard-brand) !important;
  color: #fff !important;
  border-radius: 8px !important;
  font-family: var(--pfwcard-font-sans) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  padding: 16px 24px !important;
  width: 100% !important; /* Full width button inside modal */
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: none !important;
}

#yith-quick-view-modal form.cart .button:hover {
  background: var(--pfwcard-brand-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(139, 26, 74, 0.2) !important;
}

/* Basic Swatch styling overrides inside modal (will work with most swatch plugins) */
.woo-variation-swatches .variable-items-wrapper .variable-item {
  border-radius: 50px !important; /* Default to pill */
  transition: all 0.3s var(--pfwcard-ease) !important;
  margin-right: 8px !important;
  margin-bottom: 8px !important;
  border: 1px solid rgba(139, 26, 74, 0.08) !important;
  background: var(--pfwcard-brand-light) !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item:hover,
.woo-variation-swatches .variable-items-wrapper .variable-item.selected {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--pfwcard-brand) !important;
  border-color: var(--pfwcard-brand) !important;
}

/* Specific: Color Swatches -> Perfect Circles */
.woo-variation-swatches .variable-items-wrapper .variable-item.color-variable-item {
  border-radius: 50% !important;
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  background-image: none !important; /* Remove any text backgrounds */
  background-color: var(--pfwcard-brand-light); /* Fallback */
  overflow: hidden !important;
  position: relative !important;
}

/* Hide text label inside color circles */
.woo-variation-swatches .variable-items-wrapper .variable-item.color-variable-item .variable-item-contents {
  display: none !important;
}

/* ════════════════════════════════════════════════════════════
   WPC SMART QUICK VIEW EXTENSION — ATELIER REFINE
   ════════════════════════════════════════════════════════════ */
   
   #woosq-popup .pdp-static-info {
	display: none;
}
   
#woosq-popup,
.woosq-popup {
  z-index: 9999999 !important; /* Above any sticky header */
  border-radius: 12px;
}
#woosq-popup form.cart .button:hover::after {
	content: none;
}

#woosq-popup .woosq-inner {
  border-radius: 20px !important;
  box-shadow: 0 30px 90px rgba(139, 26, 74, 0.18) !important;
  background: #ffffff !important;
  overflow: hidden !important;
  border: 1px solid rgba(139, 26, 74, 0.05) !important;
}

/* Close Button — Glassmorphic Accent */
#woosq-popup .woosq-close {
  color: var(--pfwcard-text) !important;
  background: rgba(255,255,255,0.95) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-radius: 50% !important;
  top: 15px !important;
  right: 15px !important;
  width: 36px !important;
  height: 36px !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important;
  z-index: 999999 !important; /* Force high z-index */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

#woosq-popup .woosq-close:hover {
  background: var(--pfwcard-brand) !important;
  color: #fff !important;
  transform: rotate(90deg) scale(1.1) !important;
}

#woosq-popup .product .summary {
  /*padding: 40px 48px !important;*/
  display: flex !important;
  flex-direction: column !important;
}
#woosq-popup .woocommerce div.product form.cart .variations td:last-child {
	padding-bottom: 0 !important;
}
/* Title — High-end Serif */
#woosq-popup .product h1.product_title {
  font-family: var(--pfwcard-font-serif) !important;
  font-size: 26px !important;
  font-weight: 600 !important;
  color: var(--pfwcard-text) !important;
  margin-bottom: 0 !important;
  line-height: 1.2 !important;
  letter-spacing: -0.02em !important;
  padding-bottom: 0 !important;
}
#woosq-popup .thumbnails {
	padding: 25px;
	background: transparent;
}
/* Price — Clean & Bold */
#woosq-popup .product .price {
  font-family: var(--pfwcard-font-sans) !important;
  color: var(--pfwcard-brand) !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  border: none !important;
  margin-bottom: 16px !important;
}

/* Description — Elegant & Readable */
#woosq-popup .product .woocommerce-product-details__short-description {
  font-family: var(--pfwcard-font-sans) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: var(--pfwcard-text-secondary) !important;
  margin-bottom: 24px !important;
  opacity: 0.85;
}

/* Swatches — Premium Pill Design */
#woosq-popup table.variations {
  border: none !important;
  margin-bottom: 0 !important;
}

#woosq-popup table.variations td.label,
#woosq-popup table.variations th {
  padding: 0 !important;
  font-family: var(--pfwcard-font-sans) !important;
  font-weight: 800 !important;
  color: var(--pfwcard-text) !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  display: block;
}
#woosq-popup .woosq-product > .product .summary .summary-content {
	padding: 23px 40px 8px 0;
}

#woosq-popup .woocommerce-review-link {
	color: #C9A96E;
}
#woosq-popup .woocommerce .star-rating span::before, #woosq-popup .woocommerce-page .star-rating span::before {
	color: #C9A96E;
}

/* Make swatch pills feel expensive (for size/text/button swatches) */
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item {
	border-radius: 50px !important;
	padding: 4px 10px !important;
	background: var(--pfwcard-brand-light) !important;
	border: 1px solid rgba(139, 26, 74, 0.08) !important;
	font-size: 10px !important;
	font-weight: 700 !important;
	color: var(--pfwcard-brand) !important;
	box-shadow: none !important;
	min-width: 48px !important;
	height: auto !important;
	text-align: center !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
}
#woosq-popup .woocommerce div.product form.cart {
	margin-bottom: 10px;
	margin-top: 0;
}
#woosq-popup .woocommerce-variation-price {
	margin-top: 10px;
	margin-bottom: 15px;
}

/*.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item:hover {
  background: var(--pfwcard-brand) !important;
  color: #fff !important;
  border-color: var(--pfwcard-brand) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px var(--pfwcard-brand-glow) !important;
}*/

.product .variations_form .variations .variable-items-wrapper .variable-item.selected {
	border: 1px solid #A8215A !important;
	background: #FDF4F8 !important;
}
.product .variations_form .variations .variable-items-wrapper .variable-item.selected .variable-item-span {
	color: #8B1A4A !important;
}
body.single-product #page-container .et_pb_section .et_pb_wc_add_to_cart_0_tb_body .button {
	color: #fff !important;
	font-size: 13.5px;
	font-family: 'DM Sans',sans-serif !important;
	text-transform: capitalize;
    border-color: #fff !important;
}
.product .variations_form .variations .variable-items-wrapper .variable-item .variable-item-span {
	color: #5C5C5C !important;
}
.single-product.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item {
	border-radius: 12px !important;
	border: 1px solid #EADDE5 !important;
}
.woocommerce div.product form.cart div.quantity .qty.text {
	border-color: #8B1A4A !important;
}
.single-product #main-content .woocommerce-breadcrumb a {
	color: #A8215A !important;
}

/* Ensure the color value from the attribute (if any) shows through */
.woo-variation-swatches .variable-items-wrapper .variable-item.color-variable-item {
  background: transparent !important; /* Clear the brand-light override */
  border: 1px solid rgba(0,0,0,0.1) !important;
}

/* ── GLOBAL RUNTIME COLOR DICTIONARY (MYNTRA-STYLE) ── */
/* This automatically transforms any common color name into a visual circle at runtime. */

/* Catch-all selector for items that match common color names */
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="blue"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="grey"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="gray"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="purple"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="pink"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="peachy-pink"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="black"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="white"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="red"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="green"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="yellow"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="orange"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="brown"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="teal"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="navy"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="maroon"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="charcoal"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="lavender"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="cream"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="beige"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="olive"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="gold"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="silver"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="forest-green"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="sky-blue"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="hot-pink"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="dark-pink"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="dusty-purple"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="monochrome-elegance"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="pink-cosmic-swirl"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="sapphire-prism"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="blush-pink"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ash"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="dusky"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ocean"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="plum"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="rose"],
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="bold-geometrics"],
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="coral-rush"],
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="rainbow-burst"],
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="mint"] {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  font-size: 0 !important; /* Hide text */
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.1) !important;
}

/* Dictionary: Actual Hex Codes */
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="black"], .woof_container input[data-slug="black"] { background-color: #000000 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="white"], .woof_container input[data-slug="white"] { background-color: #ffffff !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="red"], .woof_container input[data-slug="red"] { background-color: #e63946 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="blue"], .woof_container input[data-slug="blue"] { background-color: #2b58a1 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="sky-blue"], .woof_container input[data-slug="sky-blue"] { background-color: #87ceeb !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="green"], .woof_container input[data-slug="green"] { background-color: #2a9d8f !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="forest-green"], .woof_container input[data-slug="forest-green"] { background-color: #2d6a4f !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="yellow"], .woof_container input[data-slug="yellow"] { background-color: #e9c46a !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="orange"], .woof_container input[data-slug="orange"] { background-color: #f4a261 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="purple"], .woof_container input[data-slug="purple"] { background-color: #c4b7d7 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="lavender"], .woof_container input[data-slug="lavender"] { background-color: #e6e6fa !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="pink"], .woof_container input[data-slug="pink"] { background-color: #ffb7c5 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="peachy-pink"], .woof_container input[data-slug="peachy-pink"] { background-color: #f49ca8 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="grey"], .woof_container input[data-slug="grey"],
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="gray"], .woof_container input[data-slug="gray"] { background-color: #a0a0a0 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="charcoal"], .woof_container input[data-slug="charcoal"] { background-color: #36454f !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="navy"], .woof_container input[data-slug="navy"] { background-color: #000080 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="teal"], .woof_container input[data-slug="teal"] { background-color: #008080 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="maroon"], .woof_container input[data-slug="maroon"] { background-color: #800000 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="cream"], .woof_container input[data-slug="cream"] { background-color: #fffdd0 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="beige"], .woof_container input[data-slug="beige"] { background-color: #f5f5dc !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="olive"], .woof_container input[data-slug="olive"] { background-color: #808000 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="gold"], .woof_container input[data-slug="gold"] { background-color: #ffd700 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="silver"], .woof_container input[data-slug="silver"] { background-color: #c0c0c0 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="hot-pink"], .woof_container input[data-slug="hot-pink"] { background-color: #FF69B4 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="dark-pink"], .woof_container input[data-slug="dark-pink"] { background-color: #AA336A !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="dusty-purple"], .woof_container input[data-slug="dusty-purple"] { background-color: #825F87 !important; }
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="monochrome-elegance"],.woof_container input[data-slug="monochrome-elegance"] {
  background-color: #747577 !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="pink-cosmic-swirl"], .woof_container input[data-slug="pink-cosmic-swirl"] {
background-color: #F783D6 !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="sapphire-prism"], .woof_container input[data-slug="sapphire-prism"] {
background-color: #0F52BA !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="blush-pink"],.woof_container input[data-slug="blush-pink"] {
background-color: #FF7782 !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ash"],.woof_container input[data-slug="ash"] {
background-color: #B2BEB5 !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="dusky"],.woof_container input[data-slug="dusky"] {
background-color: #664455 !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ocean"],.woof_container input[data-slug="ocean"] {
background-color: #017B92 !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="plum"],.woof_container input[data-slug="plum"]  {
background-color: #8E4585 !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="rose"],.woof_container input[data-slug="rose"], .woof_container input[data-slug="rosy"]  {
background-color: #FF007F !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="bold-geometrics"],.woof_container input[data-slug="bold-geometrics"] {
background-color: #0B0000 !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="coral-rush"],.woof_container input[data-slug="coral-rush"] {
background-color: #FF7F50 !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="rainbow-burst"],.woof_container input[data-slug="rainbow-burst"] {
background-color: #F28DBC !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="mint"],.woof_container input[data-slug="mint"] {
background-color: #3EB489 !important;
}

.woof_container input.woof_radio_term {
	opacity: 1 !important;
	height: 15px;
	width: 15px;
	-webkit-appearance: none;
    -moz-appearance: none;
	margin-top: 2px;
	border-radius: 10px;
    visibility: visible !important;
}
.woof_container .iradio_flat-purple {
	background: transparent;
}
/* Hide contents for all mapped colors to ensure absolute visual circles */
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="blue"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="grey"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="gray"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="purple"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="pink"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="peachy-pink"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="black"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="white"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="red"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="green"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="hot-pink"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="yellow"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="orange"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="dusty-purple"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="pink-cosmic-swirl"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="sapphire-prism"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="blush-pink"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ash"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="dusky"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="ocean"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="plum"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="rose"] .variable-item-contents,
.woo-variation-swatches .variable-items-wrapper .variable-item.button-variable-item[data-value="bold-geometrics"] .variable-item-contents{
  display: none !important;
},
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="dark-pink"] .variable-item-contents {
  display: none !important;
},
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="monochrome-elegance"] .variable-item-contents {
  display: none !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="coral-rush"] .variable-item-contents {
  display: none !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="mint"] .variable-item-contents {
  display: none !important;
}

.woo-variation-swatches .variable-items-wrapper .variable-item[data-value="rainbow-burst"] .variable-item-contents {
  display: none !important;
}

/* ATC Button & Quantity Area 
#woosq-popup .woocommerce-variation-add-to-cart {
  padding-top: 24px !important;
  margin-top: 10px !important;
  border-top: 1px solid rgba(139, 26, 74, 0.08) !important;
  display: flex !important;
  gap: 12px !important;
}*/

#woosq-popup .woocommerce-variation-add-to-cart .quantity {
	display: inline-block;
	float: none;
}

#woosq-popup form.cart .quantity input.qty {
  height: 48px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  background: #fbfbfb !important;
  width: 60px !important;
  font-weight: 700 !important;
}

#woosq-popup form.cart .button {
  float: none;
  display: inline-block;
  width: 100%;
  background: #8B1A4A;
  border: 0;
  color: #fff;
  letter-spacing: .04em;
  text-transform: capitalize;
  padding: 8px 0;
  border-radius: 6px;
  font-size: 14px;
  margin-top: 10px;
}

#woosq-popup form.cart .button:hover {
  background: var(--pfwcard-brand-hover) !important;
  box-shadow: 0 6px 20px var(--pfwcard-brand-glow) !important;
}

/* Fix WPC Product Image Sizing */
#woosq-popup .product .images {
  padding: 0 !important;
  margin: 0 !important;
}

/* Responsive Mobile Fixes */
@media (max-width: 767px) {
  #woosq-popup .woosq-inner {
    border-radius: 12px !important;
    max-height: 85vh !important;
  }
  #woosq-popup .product .summary {
    padding: 24px !important;
  }
  #woosq-popup .product h1.product_title {
    font-size: 22px !important;
  }
  #woosq-popup .woocommerce-variation-add-to-cart {
    flex-direction: column !important;
  }
  #woosq-popup form.cart .quantity {
    width: 100% !important;
  }
  #woosq-popup form.cart .quantity input.qty {
    width: 100% !important;
  }
  
  /* Mobile Close Button Alignment */
  #woosq-popup .woosq-close {
    top: 10px !important;
    right: 10px !important;
    width: 40px !important; /* Larger touch target for mobile */
    height: 40px !important;
    background: #ffffff !important; /* More opaque background for mobile visibility */
    box-shadow: 0 4px 20px rgba(0,0,0,0.15) !important;
  }
}

/* ── HIDE AUTO-INJECTED PLUGIN BUTTONS ── */
/* Some plugins inject buttons using hooks. We ONLY want ours inside .pfwcard__actions */
.pfwcard .woosq-btn, 
.pfwcard .woosq-link,
.pfwcard .wooview-btn {
  display: none !important;
}

/* Re-show ONLY the one we manually placed in the actions area */
.pfwcard .pfwcard__actions .woosq-btn,
.pfwcard .pfwcard__actions .woosq-link,
.pfwcard .pfwcard__actions .button.pfwcard__atc-btn {
  display: flex !important;
  position: static !important; 
  transform: none !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.woocommerce.woocommerce-shop ul.products li.product a img, .woocommerce-shop .woocommerce-page ul.products li.product a img {
	border-radius: 0 !important;
}
@media (min-width: 1024px) and (max-width: 1439px) {
  .woocommerce.woocommerce-shop ul.products, .woocommerce-shop .et_pb_shop ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 18px !important;
  }
}

.woof_container_inner .irs--flat .irs-bar {
	background: #8B1A4A;
}
.woof_container_inner .irs--flat .irs-handle > i:first-child {
	background-color: #8B1A4A;
}
@media (max-width: 1024px) {
#woosq-popup .woosq-product > .product .summary .summary-content {
	padding: 18px 0 8px 0;
}
}