/* ===== 33. WC: Catalogue Product (pdp-) ===== */
/* Exact styles from the Diabolo Dumbbells prototype                       */

/* Sticky Sub-Nav */
.pdp-subnav {
  position: sticky;
  top: 0;
  z-index: 90;
  background: var(--color-white);
  border-bottom: 1px solid var(--color-grey-300);
  transition: box-shadow var(--duration-base) var(--ease-out-quart);
}
.pdp-subnav.is-shadow { box-shadow: 0 2px 20px rgba(0,0,0,0.06); }
.pdp-subnav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}
.pdp-subnav__links {
  display: flex;
  gap: var(--space-8);
  list-style: none;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}
.pdp-subnav__link {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-grey-500);
  white-space: nowrap;
  padding: var(--space-2) 0;
  position: relative;
  transition: color var(--duration-fast) var(--ease-out-quart);
  text-decoration: none;
}
.pdp-subnav__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--color-bronze);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.pdp-subnav__link:hover,
.pdp-subnav__link.is-active { color: var(--color-charcoal); }
.pdp-subnav__link.is-active::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* Product Placeholder Images */
.product-placeholder {
  background: linear-gradient(135deg, var(--color-charcoal-dark) 0%, var(--color-charcoal) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--space-3);
  width: 100%;
  height: 100%;
}
.product-placeholder svg { width: 80px; height: 80px; opacity: 0.15; }
.product-placeholder--light {
  background: linear-gradient(135deg, var(--color-grey-100) 0%, var(--color-grey-200) 100%);
}
.product-placeholder--light svg { opacity: 0.08; }
.product-placeholder--angle2 { background: linear-gradient(225deg, var(--color-charcoal-dark) 0%, var(--color-charcoal) 100%); }
.product-placeholder--angle3 { background: linear-gradient(315deg, var(--color-charcoal-dark) 0%, var(--color-charcoal) 100%); }
.product-placeholder--angle4 { background: linear-gradient(45deg, var(--color-charcoal-dark) 0%, var(--color-charcoal-light) 100%); }
.product-placeholder--angle5 { background: linear-gradient(180deg, var(--color-charcoal) 0%, var(--color-charcoal-dark) 100%); }

/* Gallery */
.pdp-gallery {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: var(--space-4);
}
.pdp-gallery__featured {
  aspect-ratio: 4 / 3;
  cursor: zoom-in;
  overflow: hidden;
  position: relative;
  border-radius: var(--radius-sm);
}
.pdp-gallery__zoom-hint {
  position: absolute;
  bottom: var(--space-4);
  right: var(--space-4);
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26,26,26,0.6);
  color: var(--color-offwhite);
  border-radius: 50%;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease-out-quart);
  z-index: 1;
}
.pdp-gallery__featured:hover .pdp-gallery__zoom-hint { opacity: 1; }
.pdp-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.pdp-gallery__thumb {
  aspect-ratio: 1;
  border: 2px solid transparent;
  cursor: pointer;
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out-quart), opacity var(--duration-fast) var(--ease-out-quart);
  opacity: 0.5;
  background: none;
  padding: 0;
  border-radius: var(--radius-sm);
}
.pdp-gallery__thumb:hover { opacity: 0.8; }
.pdp-gallery__thumb.is-active { border-color: var(--color-bronze); opacity: 1; }

/* Variations / Configurator */
.pdp-variations__title {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-grey-600);
  margin-bottom: var(--space-6);
}
.pdp-variations__options {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.pdp-swatch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-out-quart);
  border-radius: var(--radius-sm);
  min-width: 120px;
}
.pdp-swatch:hover { border-color: var(--color-grey-300); }
.pdp-swatch.is-active { border-color: var(--color-bronze); }
.pdp-swatch__preview {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: 1px solid var(--color-grey-300);
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.pdp-swatch:hover .pdp-swatch__preview { transform: scale(1.08); }
.pdp-swatch__name {
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-charcoal);
}

.pdp-weight-options {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.pdp-weight {
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.05em;
  background: transparent;
  border: 1px solid var(--color-grey-300);
  color: var(--color-charcoal);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out-quart);
}
.pdp-weight:hover { border-color: var(--color-charcoal); }
.pdp-weight.is-active {
  background: var(--color-charcoal);
  color: var(--color-offwhite);
  border-color: var(--color-charcoal);
}

/* Catalogue product options — WC variation form with purchase elements hidden */
.pdp-options .variations_form {
  width: 100%;
}
.pdp-options .variations_form .variations {
  width: 100%;
  border: none;
  border-collapse: collapse;
}
.pdp-options .variations_form .variations td,
.pdp-options .variations_form .variations th {
  padding: var(--space-3) 0;
  border: none;
  border-bottom: 1px solid var(--color-grey-200);
  vertical-align: middle;
}
.pdp-options .variations_form .variations .label {
  width: 160px;
  padding-right: var(--space-4);
}
.pdp-options .variations_form .variations .label label {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-charcoal);
}
.pdp-options .variations_form .variations .value select {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-grey-300);
  border-radius: 0;
  background: var(--color-white);
  color: var(--color-charcoal);
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23333' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.pdp-options .variations_form .variations .value select:focus {
  border-color: var(--color-bronze);
  outline: none;
}
.pdp-options .variations_form .variations .reset_variations {
  font-family: var(--font-body-alt);
  font-size: var(--text-xs);
  color: var(--color-grey-600);
  text-decoration: underline;
}
/* ─── Zonkey Swatches — Theme Overrides ─── */
/* Override plugin's inline styles to match Paragon design language */

/* Color swatches — larger with label underneath */
.custom-swatches .color-swatch {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid var(--color-grey-300);
  transition: all var(--duration-fast) var(--ease-out-quart);
}
.custom-swatches .color-swatch:hover:not(.disabled) {
  transform: scale(1.1);
  border-color: var(--color-grey-400);
}
.custom-swatches .color-swatch.selected {
  border-color: var(--color-bronze);
  box-shadow: 0 0 0 2px var(--color-bronze);
}

/* Size / text swatches — match theme button style */
.custom-swatches .size-swatch {
  min-width: 50px;
  height: 44px;
  padding: 0 var(--space-5);
  border: 1px solid var(--color-grey-300);
  background: var(--color-white);
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--color-charcoal);
  transition: all var(--duration-fast) var(--ease-out-quart);
}
.custom-swatches .size-swatch:hover:not(.disabled) {
  border-color: var(--color-charcoal);
}
.custom-swatches .size-swatch.selected {
  background: var(--color-charcoal);
  color: var(--color-offwhite);
  border-color: var(--color-charcoal);
}

/* Disabled state */
.custom-swatches .swatch.disabled {
  opacity: 0.25;
  cursor: not-allowed;
}

/* Variation labels */
.variations .label label {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  margin-bottom: var(--space-3);
  display: block;
}
.variations .label label strong {
  color: var(--color-bronze);
  font-weight: 600;
}

/* Swatch container spacing */
.custom-swatches {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

/* Hide purchase elements on catalogue products */
.pdp-options .single_variation_wrap .woocommerce-variation-add-to-cart,
.pdp-options .single_variation_wrap .quantity,
.pdp-options .single_add_to_cart_button {
  display: none !important;
}
/* Still show variation description if present */
.pdp-options .woocommerce-variation-description {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  margin-top: var(--space-4);
}

.pdp-config-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-8);
  background: var(--color-offwhite);
  border: 1px solid var(--color-grey-300);
  gap: var(--space-8);
}
.pdp-config-summary__actions {
  display: flex;
  gap: var(--space-4);
  flex-shrink: 0;
}

/* Specifications */
.pdp-specs__group-title {
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: var(--space-4);
}

/* Enquiry Summary */
.pdp-enquiry-summary {
  padding: var(--space-6);
  background: var(--color-white);
  border: 1px solid var(--color-grey-300);
  border-left: 3px solid var(--color-bronze);
}


/* ===== 34. WC: Buy Online Product (bop-) ===== */
/* Exact styles from the Mocha Kettlebells prototype                       */

/* Breadcrumb bar above the product. main-content already has ~100px
   padding-top to clear the sticky header, so this only adds breathing room. */
.bop-breadcrumb {
  padding: 55px 0 var(--space-3);
  background: var(--color-offwhite);
  border-bottom: 1px solid rgba(175, 152, 123, 0.15);
}
@media (max-width: 768px) {
  .bop-breadcrumb {
    padding-top: 50px;
  }
}
.bop-breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-grey-600);
}
.bop-breadcrumb__list li {
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
}
.bop-breadcrumb__list a,
.bop-breadcrumb a {
  color: var(--color-grey-600);
  text-decoration: none;
  transition: color 200ms ease;
}
.bop-breadcrumb__list a:hover,
.bop-breadcrumb a:hover {
  color: var(--color-bronze-dark);
}
.bop-breadcrumb__list li span,
.bop-breadcrumb .breadcrumb-sep {
  color: var(--color-grey-400);
  margin: 0 var(--space-2);
}
/* Yoast breadcrumb output is wrapped in a single span — give it the same look */
.bop-breadcrumb > .container > span {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

/* Product Section (2-column) */
.bop-product {
  padding: var(--space-6) 0 var(--space-16);
}
.bop-product__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: start;
}

/* Gallery (left column, sticky) */
.bop-gallery {
  position: sticky;
  top: 100px;
}
.bop-gallery__main {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--color-grey-200);
  cursor: zoom-in;
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
}
.bop-gallery__main img {
  width: 100%;
  height: 100%;
  /* WC sizes are now 1:1 hard-cropped (see inc/woocommerce.php), so cover
     fills the square frame edge-to-edge with no distortion. */
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out-expo);
}
.bop-gallery__main:hover img { transform: scale(1.03); }
.bop-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}
.bop-gallery__thumb {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--color-grey-200);
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color var(--duration-fast);
}
.bop-gallery__thumb.is-active { border-color: var(--color-charcoal); }
.bop-gallery__thumb:hover { border-color: var(--color-grey-400); }
.bop-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Product Info (right column) */
.bop-info__category {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: var(--space-3);
}
.bop-info__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-3xl), 3vw, var(--text-4xl));
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.15;
  color: var(--color-charcoal);
  margin-bottom: var(--space-4);
}

/* Catalogue "From £X,XXX" price */
.bop-info__price-from {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin: 0 0 var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid rgba(175, 152, 123, 0.2);
}
.bop-info__price-from-label {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-bronze);
}
.bop-info__price-from-value {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-charcoal);
}
.bop-info__price-from-suffix,
.bop-info__price-from-unit {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--color-grey-600);
  letter-spacing: 0;
  margin-left: var(--space-1);
}
.bop-info__price-from-unit {
  /* Unit (e.g. "per SqM") sits closer to the price than the VAT suffix. */
  margin-left: 4px;
  color: var(--color-charcoal);
  font-weight: 500;
}
.bop-info__price-from .woocommerce-Price-amount {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}
.bop-info__price {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-charcoal);
  margin-bottom: var(--space-1);
}
.bop-info__vat {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-500);
  margin-bottom: var(--space-6);
}
.bop-info__desc {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-charcoal-light);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-8);
  border-bottom: var(--border-thin);
}

/* Colour Swatches */
.bop-swatches__label {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  margin-bottom: var(--space-4);
}
.bop-swatches__label span {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-grey-600);
  margin-left: var(--space-2);
}
.bop-swatches__row {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.bop-swatch {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  padding: 3px;
  transition: border-color var(--duration-fast);
  position: relative;
}
.bop-swatch.is-active { border-color: var(--color-charcoal); }
.bop-swatch:hover { border-color: var(--color-grey-400); }
.bop-swatch__fill {
  width: 100%;
  height: 100%;
  border-radius: 50%;
}
.bop-swatch__fill--mocha {
  background: linear-gradient(135deg, #8B7355 0%, #A0876D 50%, #6B5740 100%);
}
.bop-swatch__fill--slate {
  background: linear-gradient(135deg, #6B7B8D 0%, #8A9AA8 50%, #4A5968 100%);
}
.bop-swatch__fill--ivory {
  background: linear-gradient(135deg, #E8E0D4 0%, #F2ECE2 50%, #D4CBBD 100%);
}
.bop-swatch__tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-charcoal-dark);
  color: var(--color-offwhite);
  font-family: var(--font-body-alt);
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-fast), visibility 0s var(--duration-fast);
  pointer-events: none;
}
.bop-swatch__tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: var(--color-charcoal-dark);
}
.bop-swatch:hover .bop-swatch__tooltip {
  opacity: 1;
  visibility: visible;
  transition: opacity var(--duration-fast), visibility 0s 0s;
}

/* Stock */
.bop-stock {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-success);
  margin-bottom: var(--space-6);
}
.bop-stock__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-success);
}

/* Quantity + Add to Basket */
.bop-actions {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

/* Catalogue pdp-actions extends bop-actions for flexible CTA layout */
.pdp-actions {
  flex-direction: column;
  align-items: flex-start;
}
.pdp-actions .btn {
  width: 100%;
  text-align: center;
}
.pdp-actions__note {
  margin: 0;
  font-family: var(--font-body-alt, var(--font-body));
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  font-style: italic;
}
.pdp-actions__waitlist-remove {
  margin: var(--space-3) 0 0;
}
.pdp-actions__waitlist-remove a {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-grey-600);
  text-decoration: none;
  border-bottom: 1px solid var(--color-grey-400);
  padding-bottom: 2px;
  cursor: pointer;
  transition: color 200ms ease, border-color 200ms ease;
}
.pdp-actions__waitlist-remove a:hover {
  color: #a04040;
  border-bottom-color: #a04040;
}
.pdp-actions .pqb-waitlist-trigger {
  /* Ensures the waitlist button inherits our .btn styles when it's a <button> */
  display: inline-block;
  cursor: pointer;
}
.bop-qty {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-grey-300);
}
.bop-qty__btn {
  width: 44px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--text-xl);
  color: var(--color-charcoal);
  transition: background var(--duration-fast);
}
.bop-qty__btn:hover { background: var(--color-grey-200); }
.bop-qty__input {
  width: 52px;
  height: 52px;
  text-align: center;
  font-family: var(--font-body-alt);
  font-size: var(--text-base);
  border: none;
  border-left: 1px solid var(--color-grey-300);
  border-right: 1px solid var(--color-grey-300);
  outline: none;
  -moz-appearance: textfield;
}
.bop-qty__input::-webkit-outer-spin-button,
.bop-qty__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.bop-actions .btn { flex: 1; }

/* Stripe Payment Request / Express Checkout buttons (Apple/Google Pay) —
   pushed onto their own row below Add to Basket. The plugin injects them
   via woocommerce_after_add_to_cart_button which puts them inside the form,
   inheriting the .cart flex row. flex-basis: 100% claims the next line;
   order: 99 ensures they sit AFTER the qty+button regardless of injection
   position; broad selector list covers v6+, v7+, and the newer Express
   Checkout block. */
.bop-actions form.cart > .wc-stripe-payment-request-wrapper,
.bop-actions form.cart > .wc-stripe-product-checkout-container,
.bop-actions form.cart > .wc-stripe-clear,
.bop-actions form.cart > [id*="wc-stripe-payment-request"],
.bop-actions form.cart > [class*="wc-stripe-payment-request"],
.bop-actions form.cart > [class*="wc-stripe-express-checkout"],
.bop-actions form.cart > [id*="wc-stripe-express-checkout"],
.bop-actions form.cart > wc-order-attribution-inputs {
  flex-basis: 100%;
  width: 100%;
  order: 99;
}
/* No extra margin-top — form.cart's `gap` already spaces wrapped rows. */

/* Hide the "OR" separator the plugin sometimes adds — looks odd when the
   buttons are stacked rather than inline. */
.bop-actions #wc-stripe-payment-request-button-separator,
.bop-actions .wc-stripe-payment-request-button-separator {
  display: none !important;
}

/* WC add-to-cart form (output by woocommerce_template_single_add_to_cart) */
.bop-actions .cart {
  width: 100%;
}

/* Simple products: qty + button inline. flex-wrap allows late-injected
   payment-request buttons (Stripe Apple/Google Pay) to claim a new line
   below the Add to Basket — see Stripe rules below. */
.bop-actions form.cart:not(.variations_form) {
  display: flex;
  flex-wrap: wrap;
  /* row-gap (between wrapped Stripe row + cart row) tighter than column-gap
     (qty ↔ Add to Basket on the same row). */
  gap: var(--space-2) var(--space-4);
  align-items: stretch;
}

/* Variable products: stack variations table above the add-to-cart */
.bop-actions form.variations_form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.bop-actions form.variations_form .woocommerce-variation-add-to-cart {
  display: flex;
  gap: var(--space-4);
  align-items: stretch;
  flex-wrap: wrap;
}
.bop-actions .quantity {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-grey-300);
  flex-shrink: 0;
}
.bop-actions .quantity .qty {
  width: 60px;
  height: 52px;
  text-align: center;
  font-family: var(--font-body-alt);
  font-size: var(--text-base);
  border: none;
  outline: none;
  -moz-appearance: textfield;
  -webkit-appearance: none;
  background: transparent;
  color: var(--color-charcoal);
}
.bop-actions .quantity .qty::-webkit-outer-spin-button,
.bop-actions .quantity .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.bop-actions .single_add_to_cart_button {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 40px;
  font-family: var(--font-subheading);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  line-height: 1.4;
  border: 2px solid var(--color-charcoal);
  border-radius: var(--btn-radius);
  cursor: pointer;
  text-decoration: none;
  transition: all 300ms var(--ease-out-expo);
  background: var(--color-charcoal);
  color: var(--color-offwhite);
  white-space: nowrap;
}
.bop-actions .single_add_to_cart_button:hover {
  background: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

/* WC variation form within bop-actions */
.bop-actions .variations_form {
  width: 100%;
}
.bop-actions .variations_form .variations {
  width: 100%;
  border: none;
  border-collapse: collapse;
  margin-bottom: var(--space-6);
}
.bop-actions .variations_form .variations td,
.bop-actions .variations_form .variations th {
  padding: 0 0 var(--space-4);
  border: none;
  vertical-align: middle;
}
.bop-actions .variations_form .variations .label label {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-charcoal);
}
.bop-actions .variations_form .variations .value select {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-grey-300);
  border-radius: 0;
  background: var(--color-white);
  color: var(--color-charcoal);
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23333' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.bop-actions .variations_form .variations .value select:focus {
  border-color: var(--color-bronze);
  outline: none;
}
.bop-actions .variations_form .variations .reset_variations {
  font-family: var(--font-body-alt);
  font-size: var(--text-xs);
  color: var(--color-grey-600);
  text-decoration: underline;
  margin-left: var(--space-2);
}
.bop-actions .variations_form .single_variation_wrap {
  margin-top: var(--space-2);
}
.bop-actions .variations_form .woocommerce-variation-price {
  margin-bottom: var(--space-4);
}
/* Stock availability message — separate visually from the Add to Basket row */
.bop-actions .stock,
.bop-actions .woocommerce-variation-availability,
.bop-actions p.stock {
  margin: 0 0 var(--space-4);
}
.bop-actions .variations_form .woocommerce-variation-add-to-cart {
  display: flex;
  gap: var(--space-4);
  align-items: stretch;
}

/* Product Meta */
.bop-meta {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-500);
}
.bop-meta span { color: var(--color-charcoal); }
.bop-meta p { margin-bottom: var(--space-2); }

/* Tab: Description */
.bop-desc h3 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 500;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-6);
}
.bop-desc p {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--color-charcoal-light);
  margin-bottom: var(--space-3);
}
.bop-desc ul {
  list-style: none;
  margin-bottom: var(--space-3);
  padding-left: var(--space-4);
}
.bop-desc ul li {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--color-charcoal-light);
  padding-left: var(--space-6);
  position: relative;
  margin-bottom: var(--space-2);
}
.bop-desc ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 6px;
  background: var(--color-bronze);
  border-radius: 50%;
}

/* Tab: Specifications */
.bop-specs-table {
  width: 100%;
  border-collapse: collapse;
}
.bop-specs-table tr { border-bottom: 1px solid var(--color-grey-300); }
.bop-specs-table td {
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
}
.bop-specs-table td:first-child {
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-grey-600);
  width: 200px;
}

/* Tab: Reviews */
.bop-reviews__summary {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.bop-reviews__stars {
  display: flex;
  gap: 2px;
  color: var(--color-bronze);
}
.bop-reviews__stars svg { width: 18px; height: 18px; fill: currentColor; }
.bop-reviews__count {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
}
.bop-review {
  padding: var(--space-8) 0;
  border-bottom: 1px solid var(--color-grey-300);
}
.bop-review:first-child { border-top: 1px solid var(--color-grey-300); }
.bop-review__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.bop-review__author {
  font-family: var(--font-subheading);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-charcoal);
}
.bop-review__date {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-500);
}
.bop-review__stars {
  display: flex;
  gap: 2px;
  color: var(--color-bronze);
  margin-bottom: var(--space-3);
}
.bop-review__stars svg { width: 14px; height: 14px; fill: currentColor; }
.bop-review__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-charcoal-light);
}

/* Related Products */
.bop-related {
  padding: var(--space-16) 0 var(--space-20);
}
/* Compact BOP layout has no tabs section above, so the default top padding
   reads as a big empty band. Pull it in tighter when --compact is set. */
.bop-related--compact {
  padding-top: var(--space-8);
}
.bop-related__heading {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-3xl), 3vw, var(--text-4xl));
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: var(--space-12);
}
/* Responsive: 4/3-col grids of related products collapse to 2 cols on
   mobile/tablet so cards stay readable. Explicit 480px override prevents
   the global .grid-2/.grid-3 → 1fr in main.css from collapsing them too far. */
@media (max-width: 1024px) {
  .bop-related .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .bop-related .grid-2,
  .bop-related .grid-3,
  .bop-related .grid-4 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}
@media (max-width: 480px) {
  .bop-related .grid-2,
  .bop-related .grid-3,
  .bop-related .grid-4 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }
}


/* ===== 33b. WC: Archive / Product — Back to Range CTA ===== */
.archive-back-to-range,
.bop-back-to-range {
  padding: var(--space-6) 0 var(--space-12);
  text-align: center;
  border-top: 1px solid var(--color-grey-300);
  margin-top: var(--space-10);
}


/* ===== 34a. WC: BOP Compact Layout (accordions + payments + CTA) ===== */
/* Used when Site Settings → Theme Appearance → Buy Online Layout is set to a
   compact value. The same partial renders inline (inside .bop-info column)
   or full-width (own section below .bop-grid). */

.bop-compact {
  margin-top: var(--space-6);
  margin-bottom: var(--space-8);
}
.bop-compact--fullwidth {
  margin-top: 0;
  margin-bottom: 0;
  padding: var(--space-12) 0;
}

/* ── Accordion ────────────────────────────────────────────────────── */
.bop-accordion {
  border-top: 1px solid var(--color-grey-300);
  margin-bottom: var(--space-6);
}
.bop-accordion__item {
  border-bottom: 1px solid var(--color-grey-300);
}
.bop-accordion__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) 0;
  background: none;
  border: none;
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  cursor: pointer;
  text-align: left;
  transition: color var(--duration-fast) var(--ease-out-quart);
}
.bop-accordion__trigger:hover {
  color: var(--color-bronze);
}
.bop-accordion__icon {
  position: relative;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.bop-accordion__icon::before,
.bop-accordion__icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  transition: transform var(--duration-fast) var(--ease-out-quart);
}
.bop-accordion__icon::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  transform: translateY(-50%);
}
.bop-accordion__icon::after {
  top: 0;
  left: 50%;
  width: 1px;
  height: 100%;
  transform: translateX(-50%);
}
.bop-accordion__item.is-open .bop-accordion__icon::after {
  transform: translateX(-50%) scaleY(0);
}
.bop-accordion__panel {
  padding: 0 0 var(--space-5);
}
.bop-accordion__panel[hidden] {
  display: none;
}
.bop-compact--fullwidth .bop-accordion {
  max-width: var(--container-lg);
  margin: 0 auto;
}

/* ── Payment icons row ───────────────────────────────────────────── */
.bop-payments {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  /* Negative margin-top pulls the row up so the accordion's last bottom-border
     also serves as the payments' top border (no double line). The
     border-top below kicks in only when payments are NOT preceded by an
     accordion (standalone case). */
  margin: 0 0 var(--space-6);
  padding: var(--space-4) 0;
  list-style: none;
  border-top: 1px solid var(--color-grey-300);
  border-bottom: 1px solid var(--color-grey-300);
}
.bop-accordion + .bop-payments {
  border-top: 0;
  margin-top: calc(var(--space-6) * -1); /* counter accordion's margin-bottom */
  margin-bottom: var(--space-6);
}

/* Mobile: lock to a 3-column grid so the lone 4th icon doesn't drift left.
   Items 1–3 fill row 1; if there's exactly 4 items the 4th centres under item 2. */
@media (max-width: 600px) {
  .bop-payments {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-items: center;
    align-items: center;
    gap: var(--space-4);
  }
  .bop-payments__item {
    max-width: none;
  }
  .bop-payments__item:nth-child(4):last-child {
    grid-column: 2;
  }
}
/* Each item is a fixed-height box; flex stops it from being shrunk or
   wrapped onto its own row by oversized inline SVG dimensions. */
.bop-payments__item {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  max-width: 80px;
}
.bop-payments__svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  line-height: 0;
}
/* Force every icon (image OR pasted SVG, regardless of intrinsic
   width/height attributes in the source markup) to a uniform height
   with auto-scaling width. */
.bop-payments__item img,
.bop-payments__svg svg {
  display: block;
  height: 100%;
  width: auto;
  max-width: 100%;
  opacity: 0.65;
  transition: opacity var(--duration-fast) var(--ease-out-quart);
}
.bop-payments__item img:hover,
.bop-payments__svg:hover svg {
  opacity: 1;
}

/* ── "Any questions?" CTA ───────────────────────────────────────── */
.bop-cta-questions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-bronze-10);
  border: 1px solid var(--color-bronze-20);
  color: var(--color-charcoal);
  text-decoration: none;
  transition: background var(--duration-fast) var(--ease-out-quart),
              border-color var(--duration-fast) var(--ease-out-quart);
}
a.bop-cta-questions:hover {
  background: var(--color-bronze-20);
  border-color: var(--color-bronze);
}
.bop-cta-questions__icon {
  flex-shrink: 0;
  color: var(--color-bronze-dark);
}
.bop-cta-questions__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.bop-cta-questions__heading {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-charcoal);
}
.bop-cta-questions__body {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-bronze-dark);
}
.bop-compact--fullwidth .bop-cta-questions {
  max-width: var(--container-lg);
  margin: var(--space-8) auto 0;
}


/* ===== 34b. WC: Product Attributes Table (Additional Information tab) ===== */
.woocommerce-product-attributes {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
}
.woocommerce-product-attributes-item__label,
.woocommerce-product-attributes-item__value {
  padding: var(--space-4) var(--space-5);
  vertical-align: top;
  border-bottom: 1px solid var(--color-grey-300);
}
.woocommerce-product-attributes-item__label {
  width: 30%;
  text-align: left;
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-charcoal-dark);
}
.woocommerce-product-attributes-item__value p {
  margin: 0;
}
.woocommerce-product-attributes-item__value p + p {
  margin-top: var(--space-2);
}
.woocommerce-product-attributes-item:nth-child(odd) .woocommerce-product-attributes-item__label,
.woocommerce-product-attributes-item:nth-child(odd) .woocommerce-product-attributes-item__value {
  background: var(--color-bronze-10);
}
.woocommerce-product-attributes-item:last-child .woocommerce-product-attributes-item__label,
.woocommerce-product-attributes-item:last-child .woocommerce-product-attributes-item__value {
  border-bottom: none;
}

@media (max-width: 600px) {
  .woocommerce-product-attributes-item__label,
  .woocommerce-product-attributes-item__value {
    padding: var(--space-3) var(--space-4);
  }
  .woocommerce-product-attributes-item__label {
    width: 40%;
    font-size: var(--text-xs);
  }
}


/* ===== 35. WC: Shop Archive ===== */

.archive-banner {
  /* WC archives have #main-content padding-top: 0 (see main.css), so the dark banner
     extends to the top of the content area and must clear the sticky header itself.
     Matches the mobile rule pattern below. */
  padding: calc(var(--wp-bar-h, 0px) + 100px + var(--space-12)) 0 var(--space-10);
  background: var(--color-charcoal-dark);
  color: var(--color-offwhite);
}
.archive-banner__breadcrumb {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  color: var(--color-grey-400);
}
.archive-banner__breadcrumb a {
  color: var(--color-grey-400);
  text-decoration: none;
}
.archive-banner__breadcrumb a:hover {
  color: var(--color-bronze-light);
}
.archive-banner__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: var(--heading-transform, uppercase);
  margin-bottom: var(--space-4);
}
.archive-banner__description {
  max-width: 900px;
  color: var(--color-grey-400);
}
.archive-banner__description p {
  margin-bottom: var(--space-4);
}
.archive-banner__description p:last-child {
  margin-bottom: 0;
}

/* Category Cards (shop archive subcategory display) */
.card-category {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius-sm, 4px);
  list-style: none;
  aspect-ratio: 3 / 4;
  text-decoration: none;
  color: var(--color-offwhite);
}
.card-category__link {
  display: block;
  position: relative;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.card-category__image {
  position: absolute;
  inset: 0;
}
.card-category__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow, 0.6s) var(--ease-out-expo);
}
.card-category:hover .card-category__image img {
  transform: scale(1.05);
}
.card-category__placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-grey-200);
}
.card-category__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(30,30,30,0.7) 0%, rgba(30,30,30,0.1) 60%, transparent 100%);
  transition: opacity var(--duration-base) ease;
}
.card-category:hover .card-category__overlay {
  opacity: 0.9;
}
.card-category__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-6);
  z-index: 1;
}
.card-category__title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: var(--heading-transform, uppercase);
  margin: 0;
  color: #fff;
}
.card-category__count {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-bronze-light);
  margin: var(--space-1) 0 0;
}

/* Archive product grid — also style when showing categories */
ul.products .card-category {
  margin: 0;
  padding: 0;
}

/* Toolbar: result count + ordering */
.archive-toolbar {
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--color-grey-200);
}
.archive-toolbar__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
}
.archive-toolbar .woocommerce-result-count {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  margin: 0;
}
.archive-toolbar .woocommerce-ordering select {
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  letter-spacing: 0.05em;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-grey-300);
  background: var(--color-white);
  cursor: pointer;
}

/* Product grid */
.archive-products {
  padding: var(--space-12) 0 var(--space-16);
}
.archive-products ul.products {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
}
.archive-products ul.products li.product {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Pagination */
.archive-products__pagination {
  margin-top: var(--space-12);
  text-align: center;
}
.archive-products__pagination .woocommerce-pagination {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
}
.archive-products__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  letter-spacing: 0.05em;
  color: var(--color-charcoal);
  text-decoration: none;
  border: 1px solid var(--color-grey-300);
  transition: all var(--duration-fast) ease;
}
.archive-products__pagination .page-numbers:hover {
  border-color: var(--color-bronze);
  color: var(--color-bronze);
}
.archive-products__pagination .page-numbers.current {
  background: var(--color-charcoal-dark);
  color: var(--color-offwhite);
  border-color: var(--color-charcoal-dark);
}
.archive-products__pagination .page-numbers.prev,
.archive-products__pagination .page-numbers.next {
  width: auto;
  padding: 0 var(--space-4);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: var(--text-xs);
}



/* ===== 36. WC: My Account ===== */

/* Wrapper around the two-column layout WC outputs */
.woocommerce-account .woocommerce {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-12);
  align-items: start;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-8) var(--gutter) var(--space-16);
}

/* Sidebar navigation */
.woocommerce-MyAccount-navigation {
  border-right: 1px solid rgba(175, 152, 123, 0.15);
  padding-right: var(--space-4);
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.woocommerce-MyAccount-navigation li {
  margin: 0;
}
.woocommerce-MyAccount-navigation-link a {
  display: block;
  padding: var(--space-3) 0;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-grey-600);
  text-decoration: none;
  border-bottom: 1px solid rgba(175, 152, 123, 0.08);
  transition: color var(--duration-fast) ease, padding-left var(--duration-fast) ease;
}
.woocommerce-MyAccount-navigation-link a:hover {
  color: var(--color-bronze);
  padding-left: var(--space-2);
}
.woocommerce-MyAccount-navigation-link.is-active a,
.woocommerce-MyAccount-navigation-link--is-active a {
  color: var(--color-charcoal);
  font-weight: 600;
  border-left: 2px solid var(--color-bronze);
  padding-left: var(--space-3);
  margin-left: -2px;
}

/* Content area */
.woocommerce-MyAccount-content {
  min-width: 0;
}
.woocommerce-MyAccount-content > p:first-child {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
  margin-top: 0;
}
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
  font-family: var(--font-heading);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: var(--heading-transform, uppercase);
  color: var(--color-charcoal);
  margin-top: 0;
}
.woocommerce-MyAccount-content h2 {
  font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
  margin-bottom: var(--space-4);
}
.woocommerce-MyAccount-content h3 {
  font-size: var(--text-xl);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

/* Tables — Orders, Downloads etc. */
.woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-MyAccount-content .shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(175, 152, 123, 0.15);
  background: #fff;
  margin: var(--space-4) 0;
}
.woocommerce-MyAccount-content .shop_table th {
  background: var(--color-grey-100);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-grey-700);
  text-align: left;
  border-bottom: 1px solid rgba(175, 152, 123, 0.15);
}
.woocommerce-MyAccount-content .shop_table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-grey-100);
  font-size: var(--text-sm);
  color: var(--color-charcoal);
}
.woocommerce-MyAccount-content .shop_table tr:last-child td {
  border-bottom: 0;
}
.woocommerce-MyAccount-content .shop_table a {
  color: var(--color-bronze);
  text-decoration: none;
}
.woocommerce-MyAccount-content .shop_table a:hover {
  color: var(--color-bronze-dark);
}
.woocommerce-MyAccount-content .shop_table .button {
  font-size: var(--text-xs);
  padding: var(--space-2) var(--space-3);
}

/* Order statuses */
.woocommerce-orders-table__cell-order-status mark,
.order-status {
  background: var(--color-offwhite);
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 2px;
  color: var(--color-charcoal);
}

/* Forms — Addresses, edit account */
.woocommerce-MyAccount-content form.woocommerce-EditAccountForm,
.woocommerce-MyAccount-content form.woocommerce-address-fields {
  max-width: 640px;
}

/* Password change fieldset — remove default browser border */
.woocommerce-MyAccount-content fieldset {
  border: 0;
  padding: var(--space-6) 0 0;
  margin: var(--space-6) 0 0;
  border-top: 1px solid rgba(175, 152, 123, 0.15);
}
.woocommerce-MyAccount-content fieldset legend {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: var(--heading-transform, uppercase);
  color: var(--color-charcoal);
  padding: 0 0 var(--space-2);
  margin-bottom: var(--space-4);
  width: 100%;
}
.woocommerce-MyAccount-content .form-row {
  margin-bottom: var(--space-4);
}
.woocommerce-MyAccount-content .form-row label {
  display: block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  margin-bottom: var(--space-1);
}
.woocommerce-MyAccount-content .form-row input[type="text"],
.woocommerce-MyAccount-content .form-row input[type="email"],
.woocommerce-MyAccount-content .form-row input[type="password"],
.woocommerce-MyAccount-content .form-row input[type="tel"],
.woocommerce-MyAccount-content .form-row textarea,
.woocommerce-MyAccount-content .form-row select {
  width: 100%;
  padding: var(--space-3) var(--space-3);
  font-family: inherit;
  font-size: var(--text-base);
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 2px;
  color: var(--color-charcoal);
  transition: border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;
}
.woocommerce-MyAccount-content .form-row input:focus,
.woocommerce-MyAccount-content .form-row textarea:focus,
.woocommerce-MyAccount-content .form-row select:focus {
  outline: none;
  border-color: var(--color-bronze);
  box-shadow: 0 0 0 3px rgba(175, 152, 123, 0.15);
}

/* Login / register forms */
.woocommerce-account form.woocommerce-form-login,
.woocommerce-account form.woocommerce-form-register {
  max-width: 420px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-6);
  border: 1px solid rgba(175, 152, 123, 0.15);
  background: #fff;
}
.woocommerce-account .u-columns,
.woocommerce-account .col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  max-width: 1024px;
  margin: 0 auto;
  padding: var(--space-8) var(--gutter);
}
.woocommerce-account .u-column1,
.woocommerce-account .col-1 { padding: 0; }
.woocommerce-account .u-column2,
.woocommerce-account .col-2 { padding: 0; }

/* WC notices inside my-account */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error,
.woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-MyAccount-content .woocommerce-error {
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
  background: var(--color-grey-100);
  border-left: 3px solid var(--color-bronze);
  list-style: none;
  font-size: var(--text-sm);
}
.woocommerce-account .woocommerce-error,
.woocommerce-MyAccount-content .woocommerce-error {
  background: #fdf0f0;
  border-left-color: #c44;
  color: #8a3030;
}

/* Dashboard intro text */
.woocommerce-MyAccount-content .woocommerce-MyAccount-customer-links {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: var(--space-6) 0;
}
.woocommerce-MyAccount-content .woocommerce-MyAccount-customer-links li {
  margin: 0;
}
.woocommerce-MyAccount-content .woocommerce-MyAccount-customer-links a {
  display: block;
  padding: var(--space-4);
  background: var(--color-grey-100);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  text-decoration: none;
  text-align: center;
  transition: background var(--duration-fast) ease;
}
.woocommerce-MyAccount-content .woocommerce-MyAccount-customer-links a:hover {
  background: var(--color-offwhite);
  color: var(--color-bronze-dark);
}

/* Mobile: stack sidebar above content */
@media (max-width: 768px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .woocommerce-MyAccount-navigation {
    border-right: 0;
    padding-right: 0;
    border-bottom: 1px solid rgba(175, 152, 123, 0.15);
    padding-bottom: var(--space-2);
  }
  .woocommerce-MyAccount-navigation-link.is-active a,
  .woocommerce-MyAccount-navigation-link--is-active a {
    border-left: 0;
    margin-left: 0;
    padding-left: 0;
    border-bottom: 2px solid var(--color-bronze);
  }
  .woocommerce-account .u-columns,
  .woocommerce-account .col2-set {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}

/* ── Edit Account form: split Personal Details + Password cards ── */
.paragon-account-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  max-width: 720px;
}
.paragon-account-form .account-card {
  background: #fff;
  border: 1px solid var(--color-grey-300);
  padding: var(--space-6) var(--space-8);
}
.paragon-account-form .account-card__header {
  margin-bottom: var(--space-5);
}
.paragon-account-form .account-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  letter-spacing: 0.06em;
  text-transform: var(--heading-transform, uppercase);
  margin: 0 0 var(--space-2);
}
.paragon-account-form .account-card__hint {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  margin: 0;
}
.paragon-account-form .account-card__field-hint {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-grey-600);
}
.paragon-account-form .account-card__body .form-row {
  margin-bottom: var(--space-4);
}
.paragon-account-form .account-card__body .form-row-first,
.paragon-account-form .account-card__body .form-row-last {
  width: calc(50% - var(--space-2));
  display: inline-block;
}
.paragon-account-form .account-card__body .form-row-first { margin-right: var(--space-4); }
.paragon-account-form .account-card__footer {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-grey-300);
}
.paragon-account-form .account-card__submit[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

@media (max-width: 600px) {
  .paragon-account-form .account-card {
    padding: var(--space-5);
  }
  .paragon-account-form .account-card__body .form-row-first,
  .paragon-account-form .account-card__body .form-row-last {
    width: 100%;
    display: block;
    margin-right: 0;
  }
}


/* ===== 37. WC: Cart & Checkout ===== */

/* Container/padding for the cart & checkout pages */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-cart article,
.woocommerce-checkout article {
  max-width: var(--container-max, 1280px);
  margin: 0 auto;
  padding: var(--space-8) var(--gutter) var(--space-16);
}

.woocommerce-cart article,
.woocommerce-checkout article {
  background: transparent;
}

/* Cart table */
.woocommerce-cart table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(175, 152, 123, 0.15);
  background: #fff;
  margin: 0 0 var(--space-8);
}
.woocommerce-cart table.shop_table th,
.woocommerce-checkout table.shop_table th {
  padding: var(--space-3) var(--space-4);
  background: var(--color-grey-100);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-grey-700);
  text-align: left;
  border-bottom: 1px solid rgba(175, 152, 123, 0.15);
}
.woocommerce-cart table.shop_table td,
.woocommerce-checkout table.shop_table td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-grey-100);
  font-size: var(--text-sm);
  vertical-align: middle;
}
.woocommerce-cart table.shop_table tr:last-child td { border-bottom: 0; }
.woocommerce-cart table.shop_table img {
  width: 72px;
  height: auto;
  display: block;
}
.woocommerce-cart table.shop_table a.remove {
  color: var(--color-grey-500);
  font-size: 18px;
  text-decoration: none;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.woocommerce-cart table.shop_table a.remove:hover { color: #c44; }

/* Quantity controls — WC outputs qty input with +/- JS. Style uniformly. */
.woocommerce-cart .quantity,
.woocommerce-checkout .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--color-grey-300);
}
.woocommerce-cart .quantity input.qty,
.woocommerce-checkout .quantity input.qty {
  width: 50px;
  padding: var(--space-2);
  border: 0;
  text-align: center;
  font-family: inherit;
  font-size: var(--text-base);
  background: transparent;
}
.woocommerce-cart .quantity button,
.woocommerce-checkout .quantity button {
  padding: var(--space-2) var(--space-3);
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--color-charcoal);
}
.woocommerce-cart .quantity button:hover,
.woocommerce-checkout .quantity button:hover { color: var(--color-bronze); }

/* Update/Apply coupon buttons */
.woocommerce-cart .actions {
  padding: var(--space-4);
  background: #fff;
  border: 1px solid rgba(175, 152, 123, 0.15);
  margin-bottom: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  justify-content: space-between;
}
.woocommerce-cart .coupon {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}
.woocommerce-cart .coupon input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-grey-300);
  font-family: inherit;
  font-size: var(--text-sm);
  min-width: 160px;
}

/* Cart totals */
.cart_totals {
  max-width: 480px;
  margin-left: auto;
  background: #fff;
  border: 1px solid rgba(175, 152, 123, 0.15);
  padding: var(--space-6);
}
.cart_totals h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: var(--heading-transform, uppercase);
  margin: 0 0 var(--space-4);
  color: var(--color-charcoal);
}
.cart_totals table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-4);
}
.cart_totals th,
.cart_totals td {
  padding: var(--space-3) 0;
  border-bottom: 1px solid rgba(175, 152, 123, 0.15);
  vertical-align: top;
}
.cart_totals th {
  text-align: left;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-grey-700);
}
.cart_totals td { text-align: right; font-size: var(--text-base); }
.cart_totals tr.order-total th,
.cart_totals tr.order-total td {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--color-charcoal);
  border-bottom: 0;
  padding-top: var(--space-4);
}
.cart_totals .wc-proceed-to-checkout { margin-top: var(--space-4); }
.cart_totals .checkout-button {
  width: 100%;
  text-align: center;
  padding: var(--space-4);
  background: var(--color-charcoal-dark);
  color: #fff;
  text-decoration: none;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border: 0;
  cursor: pointer;
  transition: background var(--duration-fast) ease;
}
.cart_totals .checkout-button:hover { background: var(--color-bronze-dark); }

/* Empty cart message */
.cart-empty {
  text-align: center;
  padding: var(--space-16) var(--space-4);
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  color: var(--color-grey-600);
}
.return-to-shop { text-align: center; margin-top: var(--space-6); }

/* ── Checkout specific ── */
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: var(--space-8);
  align-items: start;
}
.woocommerce-checkout #customer_details { min-width: 0; }
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
  grid-column: 2;
}
.woocommerce-checkout h3 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: var(--heading-transform, uppercase);
  color: var(--color-charcoal);
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid rgba(175, 152, 123, 0.15);
}
.woocommerce-checkout .form-row {
  margin-bottom: var(--space-4);
}
.woocommerce-checkout .form-row label {
  display: block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  margin-bottom: var(--space-1);
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-selection {
  width: 100%;
  padding: var(--space-3);
  font-family: inherit;
  font-size: var(--text-base);
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 2px;
  color: var(--color-charcoal);
  box-sizing: border-box;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus {
  outline: none;
  border-color: var(--color-bronze);
  box-shadow: 0 0 0 3px rgba(175, 152, 123, 0.15);
}
.woocommerce-checkout .select2-selection--single {
  height: auto !important;
}

/* Checkout order review sidebar */
.woocommerce-checkout #order_review {
  background: #fff;
  border: 1px solid rgba(175, 152, 123, 0.15);
  padding: var(--space-6);
  position: sticky;
  top: calc(var(--wp-bar-h, 0px) + 120px);
}
.woocommerce-checkout #payment {
  background: transparent;
  border-top: 1px solid rgba(175, 152, 123, 0.15);
  padding-top: var(--space-4);
  margin-top: var(--space-4);
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4);
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: var(--space-2) 0;
  border-bottom: 1px solid rgba(175, 152, 123, 0.08);
}
.woocommerce-checkout #payment div.payment_box {
  margin-top: var(--space-2);
  padding: var(--space-3);
  background: var(--color-grey-100);
  font-size: var(--text-sm);
}
.woocommerce-checkout #place_order {
  width: 100%;
  padding: var(--space-4);
  margin-top: var(--space-4);
  background: var(--color-charcoal-dark);
  color: #fff;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border: 0;
  cursor: pointer;
  transition: background var(--duration-fast) ease;
}
.woocommerce-checkout #place_order:hover { background: var(--color-bronze-dark); }

/* Mobile stack for checkout */
@media (max-width: 900px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
  }
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review {
    grid-column: 1;
  }
  .woocommerce-checkout #order_review {
    position: static;
  }
}

/* Cart notices */
.woocommerce-cart .woocommerce-message,
.woocommerce-checkout .woocommerce-message,
.woocommerce-cart .woocommerce-info,
.woocommerce-checkout .woocommerce-info {
  padding: var(--space-3) var(--space-4);
  margin: 0 0 var(--space-4);
  background: var(--color-grey-100);
  border-left: 3px solid var(--color-bronze);
  list-style: none;
  font-size: var(--text-sm);
}
.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-error {
  background: #fdf0f0;
  border-left: 3px solid #c44;
  color: #8a3030;
  padding: var(--space-3) var(--space-4);
  margin: 0 0 var(--space-4);
  list-style: none;
}


/* ===================================================================
   RESPONSIVE: WooCommerce breakpoints
   =================================================================== */

@media (max-width: 1024px) {
  /* PDP Catalogue */
  .pdp-subnav__links { gap: var(--space-6); }
  .pdp-subnav .btn { display: none; }
  .pdp-intro { grid-template-columns: 1fr 1fr; gap: var(--space-10); }
  .pdp-gallery { grid-template-columns: 1fr 120px; }

  /* BOP */
  .bop-product__grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .bop-gallery { position: static; }

  /* Shop archive */
  .archive-products ul.products { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  /* PDP Catalogue */
  .pdp-hero { min-height: 90vh; }
  .pdp-hero__title { font-size: var(--text-5xl); }
  .pdp-hero__actions { flex-direction: column; align-items: flex-start; }
  .pdp-gallery { grid-template-columns: 1fr; }
  .pdp-gallery__thumbs { flex-direction: row; overflow-x: auto; gap: var(--space-2); }
  .pdp-gallery__thumb { aspect-ratio: 1; width: 80px; flex-shrink: 0; }
  .pdp-config-summary { flex-direction: column; text-align: center; }
  .pdp-config-summary__actions { flex-direction: column; width: 100%; }
  .pdp-config-summary__actions .btn { width: 100%; }
  .pdp-swatch { min-width: 100px; }
  .pdp-swatch__preview { width: 64px; height: 64px; }

  /* BOP */
  .bop-gallery__thumbs { grid-template-columns: repeat(4, 1fr); }
  .bop-specs-table td:first-child { width: 140px; }
  .bop-review__header { flex-direction: column; align-items: flex-start; gap: var(--space-1); }

  /* Shop archive */
  .archive-products ul.products { grid-template-columns: repeat(2, 1fr); }
  .archive-toolbar__inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  /* PDP Catalogue */
  .pdp-hero { min-height: 85vh; }
  .pdp-hero__title { font-size: var(--text-4xl); }
  .pdp-hero__tagline { font-size: var(--text-lg); }
  .pdp-hero__content { padding: var(--space-16) 1.25rem; }
  .pdp-section { padding: var(--space-16) 0; }
  .pdp-subnav__links { gap: var(--space-4); }
  .pdp-gallery__featured { aspect-ratio: 1; }
  .pdp-gallery__thumb { width: 64px; }
  .pdp-swatch { min-width: 80px; padding: var(--space-3); }
  .pdp-swatch__preview { width: 56px; height: 56px; }
  .pdp-swatch__name { font-size: var(--text-xs); }
  .pdp-weight { padding: var(--space-2) var(--space-4); font-size: var(--text-xs); }

  /* BOP */
  .bop-info__title { font-size: var(--text-2xl); }
  .bop-info__price { font-size: var(--text-2xl); }
  .bop-actions { flex-direction: column; }
  .bop-actions .btn { width: 100%; }

  /* Shop archive */
  .archive-products ul.products { grid-template-columns: 1fr; }
  .archive-banner { padding: calc(115px + var(--space-8)) 0 var(--space-8); }
  .archive-banner__title { font-size: var(--text-3xl); }
}


/* ===== Project sidebar: featured products ===== */
.proj-intro__products {
    margin-top: var(--space-8);
}
.proj-intro__products-title {
    font-family: var(--font-subheading);
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-bronze);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--color-grey-300);
}
.proj-product-card {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--color-grey-200);
    text-decoration: none;
    transition: background var(--duration-fast);
}
.proj-product-card:hover {
    background: var(--color-grey-100);
}
.proj-product-card__image {
    width: 60px;
    height: 60px;
    flex-shrink: 0;
    overflow: hidden;
    background: var(--color-grey-200);
}
.proj-product-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.proj-product-card__title {
    font-family: var(--font-subheading);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-charcoal);
}

/* ===== 38. WC: Quote Builder (pq-) ===== */
/* Theme override at woocommerce/quote-builder/quote-builder.php              */

.pq-builder {
    padding: var(--space-10) 0 var(--space-24);
}
.pq-builder__inner {
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-12);
}

/* ── Reference card (saved quote summary) ────────────────────────────────── */
.pq-reference {
    background: var(--color-cream, #f7f3ec);
    border-left: 3px solid var(--color-bronze);
    padding: var(--space-6) var(--space-8);
    border-radius: var(--radius-md);
}
.pq-reference__row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-6) var(--space-8);
    align-items: start;
}
.pq-reference__cell p {
    margin: 0;
}
.pq-reference__cell .type-overline {
    color: var(--color-bronze-dark);
    margin-bottom: 4px;
}
.pq-reference__code {
    font-family: var(--font-subheading);
    font-size: 1.125rem;
    letter-spacing: 0.15em;
    color: var(--color-charcoal-dark);
    font-weight: 600;
    text-transform: uppercase;
}
.pq-reference__value {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-charcoal);
}
.pq-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-subheading);
    font-size: 0.875rem;
    color: var(--color-charcoal);
}
.pq-status__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #2f8a4a;
    box-shadow: 0 0 0 4px rgba(47, 138, 74, 0.15);
}

/* ── Empty state ─────────────────────────────────────────────────────────── */
.pq-empty {
    background: var(--color-offwhite, #fafaf7);
    border: 1px solid var(--color-grey-200, #e5e5e5);
    border-radius: var(--radius-md);
    padding: var(--space-20) var(--space-8);
    text-align: center;
}
.pq-empty .type-overline {
    color: var(--color-bronze-dark);
    margin-bottom: var(--space-4);
}
.pq-empty__title {
    margin: 0 0 var(--space-4);
}
.pq-empty__text {
    max-width: 520px;
    margin: 0 auto var(--space-8);
    color: var(--color-charcoal-light);
}
.pq-empty__actions {
    display: flex;
    justify-content: center;
}

/* ── Items list ──────────────────────────────────────────────────────────── */
.pq-items {
    background: #fff;
    border: 1px solid var(--color-grey-200, #e5e5e5);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.pq-items__head {
    padding: var(--space-6) var(--space-8);
    border-bottom: 1px solid var(--color-grey-200, #e5e5e5);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.pq-items__head .type-overline {
    color: var(--color-bronze-dark);
    margin: 0 0 4px;
}
.pq-items__title {
    margin: 0;
}
.pq-items__count {
    margin: 0;
    font-family: var(--font-subheading);
    font-size: 0.875rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-charcoal-light);
}
.pq-items__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pq-line {
    display: grid;
    grid-template-columns: 110px 1fr auto auto;
    gap: var(--space-6);
    align-items: center;
    padding: var(--space-6) var(--space-8);
    border-bottom: 1px solid var(--color-grey-100, #f0f0f0);
}
.pq-line:last-child {
    border-bottom: 0;
}
.pq-line__thumb {
    display: block;
    width: 100px;
    height: 100px;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-grey-100, #f0f0f0);
}
.pq-line__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pq-line__body {
    min-width: 0;
}
.pq-line__category {
    margin: 0 0 2px;
    font-family: var(--font-subheading);
    font-size: var(--text-xs);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-bronze-dark);
}
.pq-line__title {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    line-height: 1.3;
    color: var(--color-charcoal-dark);
    text-decoration: none;
    margin-bottom: var(--space-2);
}
.pq-line__title:hover {
    color: var(--color-bronze-dark);
}
.pq-line__attrs {
    list-style: none;
    margin: var(--space-2) 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px var(--space-4);
}
.pq-line__attrs li {
    font-family: var(--font-subheading);
    font-size: 0.8125rem;
    color: var(--color-charcoal-light);
}
.pq-line__attr-label {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
    color: var(--color-bronze-dark);
    margin-right: 4px;
}
.pq-line__attr-value {
    color: var(--color-charcoal);
}
.pq-line__note,
.pq-line__added {
    margin: var(--space-2) 0 0;
    font-family: var(--font-subheading);
    font-size: 0.75rem;
    color: var(--color-grey-500, #888);
    letter-spacing: 0.04em;
}
.pq-line__note {
    font-style: italic;
}

.pq-line__qty {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
    min-width: 72px;
}
.pq-line__qty .type-overline {
    color: var(--color-bronze-dark);
    font-size: 0.625rem;
}
.pq-qty-input {
    width: 64px;
    padding: 8px 10px;
    text-align: center;
    border: 1px solid var(--color-grey-300, #ccc);
    border-radius: var(--radius-sm);
    font-family: var(--font-subheading);
    font-size: 0.9375rem;
    color: var(--color-charcoal);
    background: #fff;
    transition: border-color 200ms ease;
}
.pq-qty-input:focus {
    outline: none;
    border-color: var(--color-bronze);
    box-shadow: 0 0 0 3px var(--color-bronze-20);
}
.pq-qty-locked {
    font-family: var(--font-subheading);
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-charcoal);
}

.pq-line__remove-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--color-grey-200, #e5e5e5);
    background: #fff;
    color: var(--color-charcoal-light);
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
    transition: border-color 200ms ease, color 200ms ease, background 200ms ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.pq-line__remove-btn:hover {
    border-color: var(--color-bronze);
    color: var(--color-bronze-dark);
    background: var(--color-bronze-10);
}
.pq-line__locked-tag {
    font-family: var(--font-subheading);
    font-size: 0.6875rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-grey-500, #888);
}

/* ── Action panels (Save / Saved / Request / Done) ───────────────────────── */
.pq-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
}
.pq-panel {
    background: #fff;
    border: 1px solid var(--color-grey-200, #e5e5e5);
    border-radius: var(--radius-md);
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.pq-panel .type-overline {
    color: var(--color-bronze-dark);
    margin: 0;
}
.pq-panel h3 {
    margin: 0;
}
.pq-panel__lead {
    margin: 0;
    color: var(--color-charcoal-light);
    font-size: 0.9375rem;
    line-height: 1.6;
}
.pq-panel--request {
    background: var(--color-cream, #f7f3ec);
    border-color: transparent;
}
.pq-panel--saved,
.pq-panel--done {
    background: var(--color-charcoal-dark);
    border-color: var(--color-charcoal-dark);
    color: #fff;
}
.pq-panel--saved .type-overline,
.pq-panel--done .type-overline {
    color: var(--color-bronze-light);
}
.pq-panel--saved h3,
.pq-panel--done h3 {
    color: #fff;
}
.pq-panel--saved .pq-panel__lead,
.pq-panel--done .pq-panel__lead {
    color: rgba(255,255,255,0.8);
}
.pq-panel__actions {
    display: flex;
    gap: var(--space-4);
    align-items: center;
    flex-wrap: wrap;
    margin-top: var(--space-2);
}
.pq-panel--saved .btn--primary {
    background: var(--color-bronze);
    border-color: var(--color-bronze);
    color: #fff;
}
.pq-panel--saved .btn--primary:hover {
    background: var(--color-bronze-dark);
    border-color: var(--color-bronze-dark);
}

.pq-link {
    background: none;
    border: 0;
    padding: 0;
    font-family: var(--font-subheading);
    font-size: 0.8125rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.7);
    cursor: pointer;
    border-bottom: 1px solid rgba(255,255,255,0.3);
    padding-bottom: 2px;
    transition: color 200ms ease, border-color 200ms ease;
}
.pq-link:hover {
    color: #fff;
    border-color: #fff;
}
.pq-panel--save .pq-link,
.pq-retrieve .pq-link {
    color: var(--color-bronze-dark);
    border-color: var(--color-bronze);
}
.pq-panel--save .pq-link:hover,
.pq-retrieve .pq-link:hover {
    color: var(--color-charcoal-dark);
    border-color: var(--color-charcoal-dark);
}

/* ── Forms (Save / Retrieve) ─────────────────────────────────────────────── */
.pq-form {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.pq-form--inline {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: var(--space-4);
    align-items: end;
}
.pq-field {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.pq-field label {
    font-family: var(--font-subheading);
    font-size: var(--text-xs);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-bronze-dark);
    font-weight: 500;
}
.pq-field__optional {
    font-family: var(--font-subheading);
    font-size: 0.6875rem;
    letter-spacing: 0.08em;
    text-transform: none;
    color: var(--color-grey-500, #888);
    margin-left: 4px;
}
.pq-field input[type="text"],
.pq-field input[type="email"] {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--color-grey-300, #ccc);
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-charcoal);
    background: #fff;
    transition: border-color 200ms ease, box-shadow 200ms ease;
}
.pq-field input:focus {
    outline: none;
    border-color: var(--color-bronze);
    box-shadow: 0 0 0 3px var(--color-bronze-20);
}
.pq-field--submit {
    margin-top: var(--space-2);
}
.pq-form__result {
    font-family: var(--font-subheading);
    font-size: 0.9375rem;
    color: var(--color-charcoal);
    min-height: 1em;
}
.pq-form__result:not(:empty) {
    margin-top: var(--space-4);
    padding: var(--space-4);
    border-radius: var(--radius-sm);
    background: var(--color-cream, #f7f3ec);
    border-left: 3px solid var(--color-bronze);
}
.pq-form__note {
    font-family: var(--font-subheading);
    font-size: 0.875rem;
    color: var(--color-charcoal-light);
}

/* Gravity Forms inside the request panel — tone down default chrome */
.pq-panel--request .gform_wrapper {
    margin: 0;
}
.pq-panel--request .gform_wrapper .gfield_label,
.pq-panel--request .gform_wrapper label.gfield_label {
    font-family: var(--font-subheading);
    font-size: var(--text-xs);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-bronze-dark);
    font-weight: 500;
}
.pq-panel--request .gform_wrapper input[type="text"],
.pq-panel--request .gform_wrapper input[type="email"],
.pq-panel--request .gform_wrapper input[type="tel"],
.pq-panel--request .gform_wrapper input[type="number"],
.pq-panel--request .gform_wrapper textarea,
.pq-panel--request .gform_wrapper select {
    padding: 12px 14px;
    border: 1px solid var(--color-grey-300, #ccc);
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 1rem;
    background: #fff;
    width: 100%;
}
.pq-panel--request .gform_wrapper input:focus,
.pq-panel--request .gform_wrapper textarea:focus,
.pq-panel--request .gform_wrapper select:focus {
    outline: none;
    border-color: var(--color-bronze);
    box-shadow: 0 0 0 3px var(--color-bronze-20);
}
.pq-panel--request .gform_wrapper .gform_button,
.pq-panel--request .gform_wrapper button[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 40px;
    font-family: var(--font-subheading);
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    line-height: 1.4;
    border: 2px solid var(--color-charcoal);
    background: var(--color-charcoal);
    color: var(--color-offwhite);
    border-radius: var(--btn-radius);
    cursor: pointer;
    transition: all 300ms var(--ease-out-expo);
}
.pq-panel--request .gform_wrapper .gform_button:hover,
.pq-panel--request .gform_wrapper button[type="submit"]:hover {
    background: var(--color-charcoal-dark);
    border-color: var(--color-charcoal-dark);
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

/* ── Retrieve panel (full width, cream background) ───────────────────────── */
.pq-retrieve {
    background: var(--color-cream, #f7f3ec);
    border-radius: var(--radius-md);
    padding: var(--space-10) var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}
.pq-retrieve__intro {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-width: 640px;
}
.pq-retrieve__intro .type-overline {
    color: var(--color-bronze-dark);
    margin: 0;
}
.pq-retrieve__intro h3 {
    margin: 0;
}
.pq-retrieve__lead {
    margin: 0;
    color: var(--color-charcoal-light);
    font-size: 0.9375rem;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 960px) {
    .pq-actions {
        grid-template-columns: 1fr;
    }
    .pq-form--inline {
        grid-template-columns: 1fr;
    }
    .pq-line {
        grid-template-columns: 80px 1fr auto;
        grid-template-areas:
            "thumb body remove"
            "qty qty qty";
        gap: var(--space-4);
    }
    .pq-line__thumb {
        grid-area: thumb;
        width: 80px;
        height: 80px;
    }
    .pq-line__body { grid-area: body; }
    .pq-line__remove { grid-area: remove; }
    .pq-line__qty {
        grid-area: qty;
        flex-direction: row;
        justify-content: flex-start;
        align-items: center;
        gap: var(--space-3);
        padding-top: var(--space-3);
        border-top: 1px dashed var(--color-grey-200, #e5e5e5);
    }
}
@media (max-width: 600px) {
    .pq-builder__inner {
        padding: 0 var(--space-4);
        gap: var(--space-8);
    }
    .pq-items__head,
    .pq-line {
        padding: var(--space-4) var(--space-5);
    }
    .pq-panel,
    .pq-retrieve {
        padding: var(--space-6);
    }
    .pq-empty {
        padding: var(--space-12) var(--space-5);
    }
}

/* ===== 39. WC: Catalogue Add-to-Quote (wcqb-) ===== */
/* Renders inside .pdp-actions via WCQB_Product::render_quote_button       */
/* Matches .bop-actions add-to-basket treatment                            */

.pdp-actions .wcqb-add-to-quote-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: stretch;
  width: 100%;
}

/* Quantity block */
.pdp-actions .wcqb-quantity-wrapper {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--color-grey-300);
  background: #fff;
  flex-shrink: 0;
  height: 52px;
  box-sizing: border-box;
  margin: 0;
}
.pdp-actions .wcqb-qty-label {
  display: inline-flex;
  align-items: center;
  padding: 0 var(--space-3);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-bronze-dark);
  border-right: 1px solid var(--color-grey-300);
  margin: 0;
}
.pdp-actions .wcqb-quantity-input {
  width: 60px;
  height: auto;
  text-align: center;
  font-family: var(--font-body-alt);
  font-size: var(--text-base);
  color: var(--color-charcoal);
  border: none;
  outline: none;
  background: transparent;
  -moz-appearance: textfield;
  -webkit-appearance: none;
  padding: 0;
  border-radius: 0;
}
.pdp-actions .wcqb-quantity-input::-webkit-outer-spin-button,
.pdp-actions .wcqb-quantity-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Add to Quote — primary button (charcoal, matches Add to Basket).
   Padding-based height to mirror .single_add_to_cart_button so the two
   buttons render at the same height when either stacks on mobile. */
.pdp-actions .wcqb-add-to-quote {
  flex: 1;
  width: auto;
  min-width: 200px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 40px;
  font-family: var(--font-subheading);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  line-height: 1.4;
  border: 2px solid var(--color-charcoal);
  border-radius: var(--btn-radius);
  cursor: pointer;
  text-decoration: none;
  transition: all 300ms var(--ease-out-expo);
  background: var(--color-charcoal);
  color: var(--color-offwhite);
  white-space: nowrap;
  margin: 0;
  box-sizing: border-box;
}
.pdp-actions .wcqb-add-to-quote:hover {
  background: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  color: var(--color-offwhite);
}
.pdp-actions .wcqb-add-to-quote.loading {
  opacity: 0.6;
  cursor: wait;
}

/* After adding: button swaps class to .wcqb-view-quote-btn (bronze) */
.pdp-actions .wcqb-view-quote-btn {
  flex: 1;
  width: auto;
  min-width: 200px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 40px;
  font-family: var(--font-subheading);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  line-height: 1;
  border: 2px solid var(--color-bronze);
  background: var(--color-bronze);
  color: #fff;
  border-radius: var(--btn-radius);
  cursor: pointer;
  text-decoration: none;
  transition: all 300ms var(--ease-out-expo);
  white-space: nowrap;
  height: 52px;
  box-sizing: border-box;
}
.pdp-actions .wcqb-view-quote-btn:hover {
  background: var(--color-bronze-dark);
  border-color: var(--color-bronze-dark);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  color: #fff;
}

/* Remove-from-quote button (shown alongside View Quote after adding) */
.pdp-actions .wcqb-remove-from-quote {
  padding: 0 var(--space-3);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-grey-600);
  background: none;
  border: 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 200ms ease;
  align-self: center;
}
.pdp-actions .wcqb-remove-from-quote:hover {
  color: var(--color-charcoal-dark);
}

/* "Find out more" tooltip */
.pdp-actions .wcqb-tooltip-wrapper {
  width: 100%;
  position: relative;
  margin-top: var(--space-1);
  z-index: 20;
}
.pdp-actions .wcqb-tooltip-trigger,
.bop-quote-link .wcqb-tooltip-trigger {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-bronze-dark);
  cursor: pointer;
  text-decoration: none;
  border-bottom: 1px solid var(--color-bronze);
  padding-bottom: 2px;
  transition: color 200ms ease, border-color 200ms ease;
}
.pdp-actions .wcqb-tooltip-trigger:hover,
.bop-quote-link .wcqb-tooltip-trigger:hover {
  color: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
}
.bop-quote-link {
  margin-top: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}
/* All lifecycle states (add → view → remove) styled as the same small inline link */
.bop-quote-link .wcqb-add-to-quote,
.bop-quote-link .wcqb-view-quote-btn,
.bop-quote-link .wcqb-remove-from-quote {
  display: inline-block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--color-bronze);
  border-radius: 0;
  padding: 0 0 2px 0;
  margin: 0;
  height: auto;
  line-height: 1.4;
  box-shadow: none;
  transition: color 200ms ease, border-color 200ms ease;
}
.bop-quote-link .wcqb-add-to-quote,
.bop-quote-link .wcqb-view-quote-btn {
  color: var(--color-bronze-dark);
}
.bop-quote-link .wcqb-add-to-quote:hover,
.bop-quote-link .wcqb-view-quote-btn:hover {
  color: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
  background: transparent;
}
.bop-quote-link .wcqb-remove-from-quote {
  color: var(--color-grey-600);
  border-bottom-color: var(--color-grey-400);
}
.bop-quote-link .wcqb-remove-from-quote:hover {
  color: #a04040;
  border-bottom-color: #a04040;
  background: transparent;
}
.bop-quote-link .wcqb-quote-message {
  flex-basis: 100%;
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: var(--space-2) 0 0 0;
  border-left: 2px solid var(--color-bronze);
  padding-left: var(--space-3) !important;
  line-height: 1.6;
}
.bop-quote-link .wcqb-success-message {
  color: var(--color-charcoal);
  margin-right: var(--space-3);
}
.bop-quote-link .wcqb-view-quote {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-bronze-dark);
  text-decoration: none;
  border-bottom: 1px solid var(--color-bronze);
  padding-bottom: 1px;
  transition: color 200ms ease, border-color 200ms ease;
}
.bop-quote-link .wcqb-view-quote:hover {
  color: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
}
.pdp-actions .wcqb-tooltip-content {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  bottom: auto;
  left: 0;
  z-index: 100;
  width: auto;
  max-width: 360px;
  min-width: 260px;
  margin-top: 0;
  padding: var(--space-4) var(--space-5);
  background: var(--color-charcoal-dark);
  border: 0;
  color: rgba(255, 255, 255, 0.92);
  font-family: var(--font-body-alt, var(--font-body));
  font-size: var(--text-sm);
  font-style: normal;
  line-height: 1.5;
  border-radius: var(--radius-sm);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}
.pdp-actions .wcqb-tooltip-content::after {
  content: '';
  position: absolute;
  bottom: 100%;
  top: auto;
  left: 20px;
  border: 6px solid transparent;
  border-bottom-color: var(--color-charcoal-dark);
}

/* Success message after clicking Add to Quote */
.pdp-actions .wcqb-quote-message {
  width: 100%;
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-left: 3px solid var(--color-bronze);
  background: var(--color-cream, #f7f3ec);
  font-family: var(--font-subheading);
  font-size: var(--text-sm);
  color: var(--color-charcoal);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.pdp-actions .wcqb-success-message {
  flex: 1;
}
.pdp-actions .wcqb-view-quote {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-bronze-dark);
  border-bottom: 1px solid var(--color-bronze);
  padding-bottom: 2px;
  text-decoration: none;
  white-space: nowrap;
}
.pdp-actions .wcqb-view-quote:hover {
  color: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
}

@media (max-width: 600px) {
  .pdp-actions .wcqb-add-to-quote-wrapper {
    flex-direction: column;
  }
  .pdp-actions .wcqb-quantity-wrapper,
  .pdp-actions .wcqb-add-to-quote,
  .pdp-actions .wcqb-view-quote-btn {
    width: 100%;
  }
}
