/* === AW PDP ULTIMATE REDESIGN === */
/* Scope: .single-product body class + .woocommerce-* standard classes        */
/* Target: atlasworks.nl — royal-elementor-kit-atlas child theme               */
/* Author: Atlas Jarvis build 2026-06-03                                       */
/* Load after: atlas-brand-stack CSS, front-page-atlasworks CSS                */
/* Load before: </body>                                                         */

/* ── Design tokens ─────────────────────────────────────────────────────────── */
.single-product {
  --pdp-navy:       #0E2A47;
  --pdp-blue:       #3B82F6;
  --pdp-blue-dark:  #1D4ED8;
  --pdp-blue-mist:  #EFF6FF;
  --pdp-green:      #1F8A52;
  --pdp-green-bg:   #F0FDF4;
  --pdp-orange:     #F59E0B;
  --pdp-red:        #EF4444;
  --pdp-white:      #FFFFFF;
  --pdp-ink:        #0B1730;
  --pdp-ink-soft:   #42526F;
  --pdp-ink-muted:  #6B7280;
  --pdp-surface:    #F8FAFC;
  --pdp-line:       #E2E8F0;
  --pdp-line-dark:  #CBD5E1;
  --pdp-radius:     12px;
  --pdp-radius-lg:  18px;
  --pdp-shadow:     0 4px 24px rgba(14, 42, 71, 0.10);
  --pdp-shadow-lg:  0 8px 40px rgba(14, 42, 71, 0.14);
  --pdp-font-head:  "Space Grotesk", Inter, -apple-system, sans-serif;
  --pdp-font-body:  Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --pdp-max-w:      1280px;
  --pdp-thumb-w:    72px;
  --pdp-thumb-h:    68px;
  --pdp-img-max:    540px;
}

/* ── Base page reset inside single-product ──────────────────────────────────── */
.single-product *,
.single-product *::before,
.single-product *::after {
  box-sizing: border-box;
}

.single-product body,
body.single-product {
  background: var(--pdp-surface);
  color: var(--pdp-ink);
  font-family: var(--pdp-font-body);
}

/* ── Container ──────────────────────────────────────────────────────────────── */
.single-product .aw-container,
.single-product .woocommerce-pdp-container {
  width: min(var(--pdp-max-w), calc(100% - 48px));
  margin: 0 auto;
}

/* ═══════════════════════════════════════════════════════════════════════════
   1. GALLERY FIXES — ROOT CAUSE: flexslider inline width override
   ═══════════════════════════════════════════════════════════════════════════ */

/* 1a. Outer gallery wrapper — NEVER let flexslider inline style cap us */
.single-product .woocommerce-product-gallery,
.single-product .aw-pdp__gallery {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  flex: 1 1 0 !important;
  position: relative;
}

/* 1b. The grid that controls left-thumbstrip + right main image */
.single-product .aw-pdp__gallery__inner,
.single-product .woocommerce-product-gallery__wrapper-outer {
  display: grid !important;
  grid-template-columns: var(--pdp-thumb-w) 1fr !important;
  grid-template-rows: auto;
  gap: 12px !important;
  align-items: start;
}

/* 1c. Thumbnail strip — vertical column on the LEFT */
.single-product .flex-control-nav.flex-control-thumbs,
.single-product .aw-pdp__thumbstrip {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  max-height: var(--pdp-img-max) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: thin !important;
  scrollbar-color: var(--pdp-line-dark) transparent !important;
  width: var(--pdp-thumb-w) !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  order: -1;
}

.single-product .flex-control-nav.flex-control-thumbs::-webkit-scrollbar {
  width: 4px;
}
.single-product .flex-control-nav.flex-control-thumbs::-webkit-scrollbar-thumb {
  background: var(--pdp-line-dark);
  border-radius: 4px;
}

/* 1d. Individual thumbnails */
.single-product .flex-control-thumbs li,
.single-product .aw-pdp__thumb {
  width: var(--pdp-thumb-w) !important;
  height: var(--pdp-thumb-h) !important;
  min-height: var(--pdp-thumb-h) !important;
  flex-shrink: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  border-radius: 8px;
  overflow: hidden;
  border: 2px solid var(--pdp-line);
  cursor: pointer;
  transition: border-color 0.18s ease, opacity 0.18s ease;
  opacity: 0.65;
  background: var(--pdp-white);
}

.single-product .flex-control-thumbs li img,
.single-product .aw-pdp__thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  display: block;
}

/* 1e. Thumbnail active + hover state */
.single-product .flex-control-thumbs li.flex-active,
.single-product .flex-control-thumbs li:hover,
.single-product .aw-pdp__thumb.active,
.single-product .aw-pdp__thumb:hover {
  border-color: var(--pdp-blue) !important;
  opacity: 1 !important;
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.20);
}

/* 1f. Main viewport — RIGHT column */
.single-product .flex-viewport,
.single-product .woocommerce-product-gallery__wrapper,
.single-product .aw-pdp__main-img-wrap {
  width: 100% !important;
  max-width: 100% !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  border-radius: var(--pdp-radius-lg);
  overflow: hidden;
  background: var(--pdp-white);
  border: 1px solid var(--pdp-line);
  aspect-ratio: 1 / 1 !important;
  max-height: var(--pdp-img-max);
  display: flex !important;
  align-items: center;
  justify-content: center;
}

/* 1g. Flexslider list reset */
.single-product .woocommerce-product-gallery .slides,
.single-product .woocommerce-product-gallery ul.slides {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  list-style: none !important;
}

.single-product .woocommerce-product-gallery .slides li,
.single-product .woocommerce-product-gallery ul.slides li {
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 1h. Main product image */
.single-product .woocommerce-product-gallery__image,
.single-product .wp-post-image,
.single-product .woocommerce-product-gallery .flex-viewport img,
.single-product .aw-pdp__main-img {
  width: 100% !important;
  height: 100% !important;
  max-height: var(--pdp-img-max) !important;
  object-fit: contain !important;
  display: block !important;
  background: var(--pdp-white);
  cursor: zoom-in;
  transition: transform 0.28s ease;
}

/* 1i. Hover zoom on main image */
.single-product .woocommerce-product-gallery:hover .woocommerce-product-gallery__image img,
.single-product .woocommerce-product-gallery:hover .wp-post-image,
.single-product .aw-pdp__gallery:hover .aw-pdp__main-img {
  transform: scale(1.03);
}

/* 1j. Lightbox-ready class — JS adds this */
.single-product .aw-pdp__main-img-wrap.lightbox-active {
  cursor: zoom-in;
}
.single-product .aw-pdp__main-img-wrap.lightbox-active::after {
  content: "⤢";
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(14, 42, 71, 0.72);
  color: #fff;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  pointer-events: none;
}

/* 1k. Badge / label chips overlaid on main image */
.single-product .aw-pdp__badge-wrap {
  position: absolute;
  top: 14px;
  left: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 4;
  pointer-events: none;
}

.single-product .aw-pdp__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1;
}

.single-product .aw-pdp__badge--new     { background: var(--pdp-navy);  color: #fff; }
.single-product .aw-pdp__badge--sale    { background: var(--pdp-red);   color: #fff; }
.single-product .aw-pdp__badge--best    { background: var(--pdp-orange); color: #fff; }
.single-product .aw-pdp__badge--refurb  { background: var(--pdp-green); color: #fff; }

/* 1l. Gallery nav arrows */
.single-product .flex-direction-nav .flex-prev,
.single-product .flex-direction-nav .flex-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--pdp-line);
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(14, 42, 71, 0.12);
  z-index: 5;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.2s ease;
  text-indent: -9999px;
}

.single-product .flex-direction-nav .flex-prev { left: 8px; }
.single-product .flex-direction-nav .flex-next { right: 8px; }

.single-product .woocommerce-product-gallery:hover .flex-direction-nav .flex-prev,
.single-product .woocommerce-product-gallery:hover .flex-direction-nav .flex-next {
  opacity: 1;
}

.single-product .flex-direction-nav .flex-prev::after,
.single-product .flex-direction-nav .flex-next::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--pdp-ink);
  border-bottom: 2px solid var(--pdp-ink);
  text-indent: 0;
}
.single-product .flex-direction-nav .flex-prev::after { transform: rotate(135deg) translate(-1px, 1px); }
.single-product .flex-direction-nav .flex-next::after { transform: rotate(-45deg) translate(1px, 1px); }

/* 1m. Image count indicator */
.single-product .aw-pdp__img-count {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(14, 42, 71, 0.68);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  pointer-events: none;
  white-space: nowrap;
  z-index: 4;
}

/* ═══════════════════════════════════════════════════════════════════════════
   2. GALLERY OUTER LAYOUT — two-column PDP wrapper
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .product,
.single-product .aw-pdp__wrapper {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 48px !important;
  align-items: start;
  padding: 32px 0 64px;
}

.single-product .woocommerce-product-gallery,
.single-product .aw-pdp__gallery {
  position: sticky;
  top: 88px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   3. PRICE BLOCK
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .pdp-price-card,
.single-product .aw-pdp-price-card {
  background: var(--pdp-white);
  border: 1px solid var(--pdp-line);
  border-radius: var(--pdp-radius-lg);
  padding: 24px;
  box-shadow: var(--pdp-shadow);
}

/* 3a. Price row */
.single-product .pdp-price-card .price,
.single-product .aw-pdp-price,
.single-product .woocommerce-Price-amount {
  font-family: var(--pdp-font-head);
  font-size: 40px !important;
  font-weight: 800 !important;
  color: var(--pdp-navy) !important;
  line-height: 1.0 !important;
  letter-spacing: -0.02em;
  display: block;
}

/* 3b. Original / strikethrough price */
.single-product del .woocommerce-Price-amount,
.single-product .pdp-price-card del,
.single-product .aw-pdp-price-original {
  font-size: 20px !important;
  font-weight: 500 !important;
  color: var(--pdp-ink-muted) !important;
  text-decoration: line-through !important;
  opacity: 0.8;
}

/* 3c. Savings badge */
.single-product .aw-pdp-savings,
.single-product .pdp-savings-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: #FEF3C7;
  color: #92400E;
  border: 1px solid #FDE68A;
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 13px;
  font-weight: 700;
  margin-left: 10px;
  vertical-align: middle;
}

/* 3d. VAT line */
.single-product .aw-pdp-vat,
.single-product .pdp-vat-note {
  font-size: 13px;
  color: var(--pdp-ink-muted);
  margin-top: 4px;
  display: block;
}

/* 3e. Monthly installment line */
.single-product .aw-pdp-installment {
  font-size: 13px;
  color: var(--pdp-ink-soft);
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.single-product .aw-pdp-installment::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2342526F'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M3 10h18M7 15h1m4 0h1m-7 4h12a3 3 0 003-3V8a3 3 0 00-3-3H6a3 3 0 00-3 3v8a3 3 0 003 3z'/%3E%3C/svg%3E") center/contain no-repeat;
  flex-shrink: 0;
}

/* 3f. in3 / SEPA trust chip */
.single-product .aw-pdp-sepa-chip,
.single-product .pdp-in3-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--pdp-blue-mist);
  border: 1px solid rgba(59, 130, 246, 0.25);
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--pdp-blue-dark);
  margin-top: 10px;
  width: 100%;
  justify-content: center;
}

/* 3g. Urgency / scarcity indicator */
.single-product .aw-pdp-stock-low {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #FFF7ED;
  border: 1px solid #FED7AA;
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  color: #9A3412;
  margin-top: 10px;
}

@keyframes pdp-pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.8); }
}

.single-product .aw-pdp-stock-low::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--pdp-red);
  flex-shrink: 0;
  animation: pdp-pulse-dot 1.4s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════════════════════════════════
   4. ADD-TO-CART BUTTON
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .single_add_to_cart_button,
.single-product form.cart .button,
.single-product .aw-pdp-atc-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  min-height: 54px !important;
  padding: 0 28px !important;
  background: var(--pdp-blue) !important;
  color: var(--pdp-white) !important;
  border: none !important;
  border-radius: var(--pdp-radius) !important;
  font-family: var(--pdp-font-head) !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  cursor: pointer !important;
  transition: background 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease !important;
  box-shadow: 0 4px 16px rgba(59, 130, 246, 0.38) !important;
  position: relative;
  overflow: hidden;
  margin-top: 16px !important;
}

.single-product .single_add_to_cart_button:hover,
.single-product form.cart .button:hover,
.single-product .aw-pdp-atc-btn:hover {
  background: var(--pdp-blue-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 22px rgba(59, 130, 246, 0.46) !important;
}

.single-product .single_add_to_cart_button:active,
.single-product form.cart .button:active {
  transform: translateY(0) !important;
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.30) !important;
}

/* ATC directional arrow */
.single-product .single_add_to_cart_button::after,
.single-product form.cart .button::after {
  content: "→";
  font-size: 18px;
  margin-left: 4px;
  transition: transform 0.18s ease;
}

.single-product .single_add_to_cart_button:hover::after,
.single-product form.cart .button:hover::after {
  transform: translateX(3px);
}

/* Loading state */
.single-product .single_add_to_cart_button.loading,
.single-product form.cart .button.loading {
  pointer-events: none;
  opacity: 0.75;
}

.single-product .single_add_to_cart_button.loading::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: pdp-spin 0.7s linear infinite;
  margin-right: 4px;
}

@keyframes pdp-spin {
  to { transform: rotate(360deg); }
}

/* Direct afrekenen secondary CTA */
.single-product .aw-pdp-atc-secondary,
.single-product .aw-pdp-direct-checkout {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  width: 100% !important;
  min-height: 46px !important;
  padding: 0 24px !important;
  background: var(--pdp-white) !important;
  color: var(--pdp-navy) !important;
  border: 2px solid var(--pdp-navy) !important;
  border-radius: var(--pdp-radius) !important;
  font-family: var(--pdp-font-head) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background 0.18s ease, color 0.18s ease !important;
  margin-top: 10px !important;
}

.single-product .aw-pdp-atc-secondary:hover,
.single-product .aw-pdp-direct-checkout:hover {
  background: var(--pdp-navy) !important;
  color: var(--pdp-white) !important;
}

/* Payment methods icon strip below ATC */
.single-product .aw-pdp-payment-icons {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.single-product .aw-pdp-payment-icons img,
.single-product .aw-pdp-payment-icon {
  height: 22px;
  width: auto;
  object-fit: contain;
  opacity: 0.75;
  filter: grayscale(0.2);
}

/* ═══════════════════════════════════════════════════════════════════════════
   5. TRUST PILLS
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .aw-pdp-trust-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.single-product .aw-pdp-trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  background: var(--pdp-green-bg);
  border: 1px solid rgba(31, 138, 82, 0.22);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--pdp-green);
  flex: 1 1 auto;
  justify-content: center;
  white-space: nowrap;
}

.single-product .aw-pdp-trust-pill svg,
.single-product .aw-pdp-trust-pill .icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   6. DELIVERY BLOCK
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .aw-pdp-delivery,
.single-product .pdp-delivery-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--pdp-green-bg);
  border: 1px solid rgba(31, 138, 82, 0.22);
  border-radius: var(--pdp-radius);
  margin-top: 14px;
}

.single-product .aw-pdp-delivery__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--pdp-green);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(31, 138, 82, 0.18);
}

.single-product .aw-pdp-delivery__text {
  font-size: 14px;
  font-weight: 700;
  color: var(--pdp-green);
}

.single-product .aw-pdp-delivery__date {
  font-size: 12px;
  color: var(--pdp-ink-soft);
  margin-left: auto;
}

/* ═══════════════════════════════════════════════════════════════════════════
   7. BREADCRUMB
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .pdp-crumb,
.single-product .woocommerce-breadcrumb,
.single-product .aw-pdp-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 16px 0 12px;
  font-size: 13px;
  color: var(--pdp-ink-soft);
  list-style: none;
  margin: 0;
}

.single-product .pdp-crumb a,
.single-product .woocommerce-breadcrumb a,
.single-product .aw-pdp-breadcrumb a {
  color: var(--pdp-ink-soft);
  text-decoration: none;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  padding: 0 2px;
}

.single-product .pdp-crumb a:hover,
.single-product .woocommerce-breadcrumb a:hover,
.single-product .aw-pdp-breadcrumb a:hover {
  color: var(--pdp-blue);
  text-decoration: underline;
}

.single-product .woocommerce-breadcrumb .breadcrumb-sep,
.single-product .pdp-crumb .sep {
  color: var(--pdp-line-dark);
  font-size: 11px;
  margin: 0 2px;
}

/* Active (current page) crumb */
.single-product .woocommerce-breadcrumb > span:last-child,
.single-product .aw-pdp-breadcrumb > li:last-child,
.single-product .pdp-crumb .current {
  font-weight: 700;
  color: var(--pdp-navy);
}

/* ═══════════════════════════════════════════════════════════════════════════
   8. PRODUCT TITLE + BRAND ROW
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .pdp-brand,
.single-product .aw-pdp-brand-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.single-product .pdp-brand a,
.single-product .aw-pdp-brand-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--pdp-blue) !important;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.single-product .aw-pdp-sku {
  font-size: 12px;
  color: var(--pdp-ink-muted);
  font-weight: 500;
  font-family: "JetBrains Mono", "Courier New", monospace;
}

.single-product .pdp-title,
.single-product .product_title,
.single-product .aw-pdp-title {
  font-family: var(--pdp-font-head) !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: var(--pdp-navy) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 6px !important;
}

/* USP tagline sub-headline */
.single-product .aw-pdp-tagline {
  font-size: 15px;
  color: var(--pdp-ink-soft);
  font-weight: 500;
  line-height: 1.4;
  margin: 0 0 12px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   9. RATINGS ROW
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .pdp-rating,
.single-product .aw-pdp-rating-row,
.single-product .woocommerce-product-rating {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 0 14px !important;
  flex-wrap: wrap;
}

.single-product .star-rating,
.single-product .aw-pdp-stars {
  color: var(--pdp-orange) !important;
  font-size: 15px !important;
  letter-spacing: 1px;
}

.single-product .aw-pdp-rating-score {
  font-size: 15px;
  font-weight: 700;
  color: var(--pdp-navy);
}

.single-product .aw-pdp-rating-count,
.single-product .woocommerce-review-link {
  font-size: 13px;
  color: var(--pdp-blue) !important;
  text-decoration: none !important;
  font-weight: 600;
  cursor: pointer;
}

.single-product .aw-pdp-rating-count:hover,
.single-product .woocommerce-review-link:hover {
  text-decoration: underline !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   10. SPECS TABLE
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .aw-pdp-specs-table,
.single-product .woocommerce-product-attributes {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-top: 8px;
}

.single-product .aw-pdp-specs-table tr:nth-child(even),
.single-product .woocommerce-product-attributes tr:nth-child(even) {
  background: var(--pdp-surface);
}

.single-product .aw-pdp-specs-table tr:nth-child(odd),
.single-product .woocommerce-product-attributes tr:nth-child(odd) {
  background: var(--pdp-white);
}

.single-product .aw-pdp-specs-table th,
.single-product .woocommerce-product-attributes th {
  width: 35%;
  text-align: left;
  color: var(--pdp-ink-soft);
  font-weight: 500;
  padding: 9px 12px;
  vertical-align: top;
  border-bottom: 1px solid var(--pdp-line);
}

.single-product .aw-pdp-specs-table td,
.single-product .woocommerce-product-attributes td {
  font-weight: 600;
  color: var(--pdp-ink);
  padding: 9px 12px;
  border-bottom: 1px solid var(--pdp-line);
}

/* Spec chips */
.single-product .aw-pdp-spec-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--pdp-blue-mist);
  color: var(--pdp-navy);
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 6px;
  padding: 3px 9px;
  font-size: 12px;
  font-weight: 700;
  margin: 2px;
}

/* Alle specificaties expand row */
.single-product .aw-pdp-specs-expand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-size: 13px;
  font-weight: 700;
  color: var(--pdp-blue);
  cursor: pointer;
  border: none;
  background: none;
  width: 100%;
  transition: color 0.18s;
  border-top: 1px solid var(--pdp-line);
  margin-top: 4px;
}

.single-product .aw-pdp-specs-expand:hover {
  color: var(--pdp-blue-dark);
}

.single-product .aw-pdp-specs-expand::after {
  content: "▾";
  font-size: 16px;
  transition: transform 0.2s;
}

.single-product .aw-pdp-specs-expand.expanded::after {
  transform: rotate(180deg);
}

/* ═══════════════════════════════════════════════════════════════════════════
   11. TRUST STRIP (below price card)
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .aw-pdp-trust-strip,
.single-product .pdp-trust-strip {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 16px;
  background: var(--pdp-white);
  border: 1px solid var(--pdp-line);
  border-radius: var(--pdp-radius);
  margin-top: 16px;
}

.single-product .aw-pdp-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 120px;
  font-size: 13px;
  font-weight: 600;
  color: var(--pdp-ink);
}

.single-product .aw-pdp-trust-item svg,
.single-product .aw-pdp-trust-item .trust-icon {
  width: 20px;
  height: 20px;
  color: var(--pdp-green);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   12. TABS SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .woocommerce-tabs,
.single-product .aw-pdp-tabs {
  margin-top: 48px;
  border-top: 1px solid var(--pdp-line);
  padding-top: 0;
}

.single-product .woocommerce-tabs ul.tabs,
.single-product .aw-pdp-tabs__nav {
  display: flex !important;
  gap: 0 !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: 2px solid var(--pdp-line);
  background: none !important;
  overflow-x: auto;
  scrollbar-width: none;
}

.single-product .woocommerce-tabs ul.tabs::-webkit-scrollbar,
.single-product .aw-pdp-tabs__nav::-webkit-scrollbar {
  display: none;
}

.single-product .woocommerce-tabs ul.tabs li,
.single-product .aw-pdp-tabs__tab {
  list-style: none !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  white-space: nowrap;
}

.single-product .woocommerce-tabs ul.tabs li a,
.single-product .aw-pdp-tabs__tab a {
  display: block;
  padding: 14px 22px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--pdp-ink-soft) !important;
  text-decoration: none !important;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: color 0.18s ease, border-color 0.18s ease;
  background: none !important;
  border-radius: 0 !important;
}

.single-product .woocommerce-tabs ul.tabs li.active a,
.single-product .woocommerce-tabs ul.tabs li a:hover,
.single-product .aw-pdp-tabs__tab.active a,
.single-product .aw-pdp-tabs__tab a:hover {
  color: var(--pdp-navy) !important;
  border-bottom-color: var(--pdp-navy) !important;
}

.single-product .woocommerce-tabs .panel,
.single-product .aw-pdp-tabs__panel {
  padding: 28px 0 !important;
  background: none !important;
  border: none !important;
  font-size: 15px;
  line-height: 1.65;
  color: var(--pdp-ink);
}

/* Spec table in tab — prevent overflow on mobile */
.single-product .woocommerce-tabs .panel table,
.single-product .shop_attributes {
  max-width: 100%;
  overflow-x: auto;
  display: block;
}

/* ═══════════════════════════════════════════════════════════════════════════
   13. RELATED PRODUCTS GRID
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .related.products,
.single-product .upsells.products,
.single-product .aw-pdp-related {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid var(--pdp-line);
}

.single-product .related.products > h2,
.single-product .upsells.products > h2,
.single-product .aw-pdp-related h2 {
  font-family: var(--pdp-font-head) !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--pdp-navy) !important;
  letter-spacing: -0.015em !important;
  margin: 0 0 24px !important;
}

.single-product .related.products ul.products,
.single-product .upsells.products ul.products,
.single-product .aw-pdp-related .products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.single-product .related.products ul.products li.product,
.single-product .upsells.products ul.products li.product {
  background: var(--pdp-white);
  border: 1px solid var(--pdp-line);
  border-radius: var(--pdp-radius);
  padding: 16px;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.single-product .related.products ul.products li.product:hover,
.single-product .upsells.products ul.products li.product:hover {
  box-shadow: var(--pdp-shadow);
  transform: translateY(-2px);
}

/* ═══════════════════════════════════════════════════════════════════════════
   14. STICKY ATC BAR
   ═══════════════════════════════════════════════════════════════════════════ */

#aw-sticky-atc {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 64px;
  background: var(--pdp-white);
  border-top: 1px solid var(--pdp-line);
  box-shadow: 0 -4px 20px rgba(14, 42, 71, 0.12);
  z-index: 999;
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  transform: translateY(100%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

#aw-sticky-atc.aw-sticky-atc--visible {
  transform: translateY(0);
}

#aw-sticky-atc .aw-sticky-atc__thumb {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  object-fit: contain;
  border: 1px solid var(--pdp-line);
  background: var(--pdp-white);
  flex-shrink: 0;
}

#aw-sticky-atc .aw-sticky-atc__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--pdp-navy);
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

#aw-sticky-atc .aw-sticky-atc__price {
  font-family: var(--pdp-font-head);
  font-size: 20px;
  font-weight: 800;
  color: var(--pdp-navy);
  flex-shrink: 0;
}

#aw-sticky-atc .aw-sticky-atc__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 44px;
  padding: 0 22px;
  background: var(--pdp-blue);
  color: var(--pdp-white);
  border: none;
  border-radius: var(--pdp-radius);
  font-family: var(--pdp-font-head);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  flex-shrink: 0;
  white-space: nowrap;
  transition: background 0.18s ease;
}

#aw-sticky-atc .aw-sticky-atc__btn:hover {
  background: var(--pdp-blue-dark);
}

/* ═══════════════════════════════════════════════════════════════════════════
   15. WISHLIST BUTTON
   ═══════════════════════════════════════════════════════════════════════════ */

.single-product .aw-pdp-wishlist,
.single-product .pdp-save-later {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  min-height: 42px;
  padding: 0 20px;
  background: transparent;
  color: var(--pdp-ink-soft);
  border: 1px solid var(--pdp-line);
  border-radius: var(--pdp-radius);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.18s, color 0.18s, background 0.18s;
  margin-top: 8px;
}

.single-product .aw-pdp-wishlist:hover,
.single-product .pdp-save-later:hover {
  border-color: var(--pdp-blue);
  color: var(--pdp-blue);
  background: var(--pdp-blue-mist);
}

.single-product .aw-pdp-wishlist.active {
  border-color: var(--pdp-red);
  color: var(--pdp-red);
}

/* ═══════════════════════════════════════════════════════════════════════════
   16. MOBILE — max-width: 768px
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* Single column layout */
  .single-product .product,
  .single-product .aw-pdp__wrapper {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    padding: 16px 0 80px !important;
  }

  /* Gallery: single column, thumbs move to bottom as horizontal strip */
  .single-product .aw-pdp__gallery__inner,
  .single-product .woocommerce-product-gallery__wrapper-outer {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 10px !important;
  }

  /* Main image on top (row 1) */
  .single-product .flex-viewport,
  .single-product .woocommerce-product-gallery__wrapper,
  .single-product .aw-pdp__main-img-wrap {
    grid-column: 1 !important;
    grid-row: 1 !important;
    max-height: 320px !important;
  }

  /* Thumbnail strip below as horizontal scroll (row 2) */
  .single-product .flex-control-nav.flex-control-thumbs,
  .single-product .aw-pdp__thumbstrip {
    flex-direction: row !important;
    gap: 8px !important;
    max-height: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    width: 100% !important;
    grid-column: 1 !important;
    grid-row: 2 !important;
    padding: 4px 0 8px !important;
    scrollbar-width: thin;
  }

  .single-product .flex-control-thumbs li,
  .single-product .aw-pdp__thumb {
    flex-shrink: 0 !important;
    width: 64px !important;
    height: 64px !important;
    min-height: 64px !important;
  }

  /* Gallery not sticky on mobile */
  .single-product .woocommerce-product-gallery,
  .single-product .aw-pdp__gallery {
    position: static !important;
  }

  /* Price card full width, no top border-radius rounding on bottom */
  .single-product .pdp-price-card,
  .single-product .aw-pdp-price-card {
    border-radius: var(--pdp-radius);
    margin-top: 16px;
  }

  /* Main price larger on mobile too */
  .single-product .pdp-price-card .price,
  .single-product .aw-pdp-price,
  .single-product .woocommerce-Price-amount {
    font-size: 36px !important;
  }

  /* ATC button full width with larger tap area */
  .single-product .single_add_to_cart_button,
  .single-product form.cart .button,
  .single-product .aw-pdp-atc-btn {
    min-height: 56px !important;
    font-size: 18px !important;
  }

  /* Trust pills stacked 2-across */
  .single-product .aw-pdp-trust-pills {
    gap: 6px;
  }

  .single-product .aw-pdp-trust-pill {
    flex: 1 1 40%;
    font-size: 11px;
  }

  /* Title smaller on mobile */
  .single-product .pdp-title,
  .single-product .product_title,
  .single-product .aw-pdp-title {
    font-size: 22px !important;
  }

  /* Tabs scroll horizontal */
  .single-product .woocommerce-tabs ul.tabs,
  .single-product .aw-pdp-tabs__nav {
    white-space: nowrap;
  }

  .single-product .woocommerce-tabs ul.tabs li a,
  .single-product .aw-pdp-tabs__tab a {
    padding: 12px 16px !important;
    font-size: 14px !important;
  }

  /* Specs table horizontal scroll */
  .single-product .aw-pdp-specs-table,
  .single-product .woocommerce-product-attributes {
    display: block;
    overflow-x: auto;
  }

  /* Sticky ATC bar smaller on mobile */
  #aw-sticky-atc {
    height: 56px;
    padding: 0 16px;
    gap: 10px;
  }

  #aw-sticky-atc .aw-sticky-atc__thumb {
    width: 36px;
    height: 36px;
  }

  #aw-sticky-atc .aw-sticky-atc__title {
    font-size: 13px;
  }

  #aw-sticky-atc .aw-sticky-atc__price {
    font-size: 17px;
  }

  #aw-sticky-atc .aw-sticky-atc__btn {
    height: 38px;
    padding: 0 16px;
    font-size: 14px;
  }

  /* Related products 2-col on mobile */
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  /* Trust strip single column */
  .single-product .aw-pdp-trust-strip {
    flex-direction: column;
    gap: 8px;
  }

  .single-product .aw-pdp-trust-item {
    flex: none;
  }

  /* Breadcrumb font size */
  .single-product .pdp-crumb,
  .single-product .woocommerce-breadcrumb {
    font-size: 12px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   17. TABLET — 769px to 1024px
   ═══════════════════════════════════════════════════════════════════════════ */

@media (min-width: 769px) and (max-width: 1024px) {

  .single-product .product,
  .single-product .aw-pdp__wrapper {
    gap: 28px !important;
  }

  .single-product .pdp-title,
  .single-product .product_title {
    font-size: 24px !important;
  }

  .single-product .pdp-price-card .price,
  .single-product .woocommerce-Price-amount {
    font-size: 34px !important;
  }

  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   18. FLEXSLIDER inline-style override (nuclear — runs AFTER flexslider fires)
   ═══════════════════════════════════════════════════════════════════════════ */

/* These exist purely to override flexslider JS injected inline width/height */
.single-product .woocommerce-product-gallery .flexslider {
  width: 100% !important;
  max-width: 100% !important;
}

.single-product .woocommerce-product-gallery .flex-viewport {
  width: 100% !important;
  max-width: 100% !important;
}

.single-product .woocommerce-product-gallery .flexslider .slides > li {
  width: 100% !important;
}

/* ── END OF AW PDP ULTIMATE REDESIGN ──────────────────────────────────────── */

/* ── GALLERY SIZING FIX 2026-06-03 ─────────────────────────────── */
.aw-pdp {
  display: grid !important;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr) !important;
  gap: 48px !important;
  align-items: start !important;
  width: 100%;
}

.aw-pdp__gallery {
  width: 100% !important;
  min-width: 0 !important;
  position: sticky;
  top: 88px;
}

.aw-pdp__gallery__inner {
  display: grid !important;
  grid-template-columns: 72px 1fr !important;
  gap: 12px !important;
  align-items: start !important;
  width: 100% !important;
}

.aw-pdp__thumbstrip {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  width: 72px !important;
}

.aw-pdp__thumb {
  width: 68px !important;
  height: 68px !important;
  border: 2px solid #E2E8F0 !important;
  border-radius: 8px !important;
  overflow: hidden;
  cursor: pointer;
  background: #fff;
  opacity: 0.7;
  transition: border-color .18s, opacity .18s;
  padding: 0;
  display: block;
}

.aw-pdp__thumb.is-active,
.aw-pdp__thumb:hover {
  border-color: #3B82F6 !important;
  opacity: 1 !important;
}

.aw-pdp__thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.aw-pdp__main-img-wrap {
  position: relative;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  min-height: 420px !important;
  background: #fff;
  border-radius: 12px;
  border: 1px solid #E2E8F0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.aw-pdp__main-img__el {
  width: 100% !important;
  height: 100% !important;
  max-height: 540px !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  cursor: zoom-in;
}

.aw-pdp__counter {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(14,42,71,.72);
  color: #fff;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 20px;
}

.aw-pdp__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,.92);
  border: 1px solid #E2E8F0;
  border-radius: 50%;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 4;
  line-height: 1;
}

.aw-pdp__nav--prev { left: 8px; }
.aw-pdp__nav--next { right: 8px; }

/* Mobile stacking */
@media (max-width: 900px) {
  .aw-pdp {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .aw-pdp__gallery {
    position: static !important;
    width: 100% !important;
  }
  .aw-pdp__main-img-wrap {
    min-height: 300px !important;
  }
}

@media (max-width: 600px) {
  .aw-pdp__gallery__inner {
    grid-template-columns: 1fr !important;
  }
  .aw-pdp__thumbstrip {
    flex-direction: row !important;
    width: 100% !important;
    overflow-x: auto !important;
    gap: 6px !important;
  }
  .aw-pdp__thumb {
    flex-shrink: 0 !important;
    width: 56px !important;
    height: 56px !important;
  }
  .aw-pdp__main-img-wrap {
    min-height: 260px !important;
  }
}
/* ── END GALLERY SIZING FIX ─────────────────────────────────────── */

/* ── GAP FIX 2026-06-03 ─────────────────────────────────────────── */
/* Remove extra white space between hero and tabs sections */
.aw-pdp-hero { padding-bottom: 0 !important; }
.aw-pdp { padding-bottom: 0; }
.aw-pdp__info-inner {
  position: sticky !important;
  top: 88px !important;
  max-height: calc(100vh - 100px) !important;
  overflow-y: auto !important;
}
/* Ensure the tabs section sits right below the hero */
.aw-pdp-tabs-section, 
.single-product .aw-pdp-tabs,
.single-product .woocommerce-tabs {
  margin-top: 0 !important;
}
/* ── END GAP FIX ─────────────────────────────────────────────────── */

/* ── INFO SCROLL + GAP DEFINITIVE FIX 2026-06-03 ───────────────── */
/* Remove inner overflow scroll - ATC button was getting cut off     */
.aw-pdp__info-inner {
  position: static !important;
  max-height: none !important;
  overflow: visible !important;
  overflow-y: visible !important;
  padding-right: 0 !important;
}

/* Sticky at section level instead */
.aw-pdp__info {
  position: sticky !important;
  top: 88px !important;
  align-self: start !important;
}

/* Remove bottom gap from hero section */
.aw-pdp-hero {
  padding-bottom: 8px !important;
}

.aw-pdp {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* Ensure the section below (tabs) is tight */
.aw-pdp-hero + * {
  margin-top: 0 !important;
}
/* ── END DEFINITIVE FIX ─────────────────────────────────────────── */
