/* ============================================================
   LACE — Single product
   Loaded only on single product pages via
   integrations/woocommerce-shop.php (priority 100).
   !important is used on the related/up-sell li width to override
   WooCommerce core's higher-specificity `.columns-N li.product` rule.
   ============================================================ */

main { padding: 0 !important; }

article.product.type-product {
  padding: clamp(110px, 12vw, 180px) clamp(20px, 4vw, 64px) clamp(40px, 6vw, 80px) !important;
  max-width: 1500px !important;
  margin: 0 auto !important;
  background: var(--warm-white);
}
article.product > h1 {
  font-family: var(--serif) !important;
  font-weight: 500 !important;
  font-size: clamp(40px, 6vw, 80px) !important;
  line-height: 1.05 !important;
  color: var(--charcoal) !important;
  margin: 0 0 48px !important;
  letter-spacing: -0.005em !important;
}
article.product > h1::before {
  content: "Drop 01";
  display: block;
  font-family: var(--sans);
  font-size: 11px; font-weight: 500; letter-spacing: 4px;
  text-transform: uppercase; color: var(--burgundy); margin-bottom: 18px;
}

article.product .woocommerce, article.product .single-product { width: 100%; max-width: none; }

.woocommerce-notices-wrapper { margin: 0 0 32px; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  background: var(--cream) !important;
  border: 1px solid var(--rule) !important;
  border-left: 3px solid var(--charcoal) !important;
  color: var(--charcoal) !important;
  padding: 18px 24px !important;
  font-family: var(--sans) !important; font-size: 14px !important;
  display: flex !important; justify-content: space-between; align-items: center;
  gap: 16px; list-style: none !important;
}
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { display: none !important; }
.woocommerce-message a.button, .woocommerce-info a.button {
  background: var(--charcoal) !important; color: var(--warm-white) !important;
  font-family: var(--sans) !important; font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  padding: 10px 20px !important; border-radius: 0 !important; text-decoration: none !important;
  border: 0 !important; min-height: auto !important; white-space: nowrap;
}
.woocommerce-message a.button:hover { background: var(--burgundy) !important; }

/* Desktop: gallery left, summary right, tabs full, related full. */
article.product div[id^="product-"] {
  display: grid !important;
  grid-template-columns: 1.2fr 1fr !important;
  gap: clamp(40px, 5vw, 80px) clamp(40px, 5vw, 80px) !important;
  align-items: start !important;
}
article.product .woocommerce-product-gallery { grid-column: 1; grid-row: 1; }
article.product .lace-thumbs { grid-column: 1; grid-row: 2; }
article.product .summary.entry-summary { grid-column: 2; grid-row: 1 / span 2; }
article.product .woocommerce-tabs.wc-tabs-wrapper { grid-column: 1 / -1; grid-row: 3; }
article.product div[id^="product-"] .related.products,
article.product div[id^="product-"] .up-sells.products { grid-column: 1 / -1; grid-row: 4; }

.woocommerce-product-gallery { width: 100% !important; float: none !important; margin: 0 !important; padding: 0 !important; position: relative; }
.woocommerce-product-gallery__wrapper { display: block; margin: 0; }
.woocommerce-product-gallery--without-images {
  background: linear-gradient(160deg, var(--sand-light) 0%, var(--sand) 60%, var(--warm-grey) 100%) !important;
  aspect-ratio: 4/5; position: relative; overflow: hidden;
}
.woocommerce-product-gallery--without-images::before {
  content: "L A C E";
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 22px; font-weight: 400; letter-spacing: 14px;
  color: rgba(26,23,20,.16); z-index: 2; pointer-events: none;
}
.woocommerce-product-gallery--without-images .woocommerce-product-gallery__wrapper,
.woocommerce-product-gallery--without-images .woocommerce-product-gallery__image--placeholder { width: 100%; height: 100%; }
.woocommerce-product-gallery--without-images img { display: none !important; }
.woocommerce-product-gallery--without-images .woocommerce-product-gallery__trigger { display: none !important; }

.lace-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin: 0; width: 100%; }
.lace-thumb {
  position: relative; width: 100%; aspect-ratio: 1/1;
  border: 0; padding: 0; cursor: pointer; border-radius: 0;
  outline: 1px solid transparent; outline-offset: 2px;
}
.lace-thumb.is-active { outline-color: var(--charcoal); }
.lace-thumb::after {
  content: "L A C E"; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 8px; letter-spacing: 4px;
  color: rgba(26,23,20,.18); pointer-events: none;
}

.summary.entry-summary {
  width: 100% !important; float: none !important; margin: 0 !important;
  padding: clamp(8px, 3vw, 40px) 0 !important;
  display: flex !important; flex-direction: column !important; gap: 0 !important;
}
.summary .price, .summary p.price {
  font-family: var(--serif) !important; font-size: clamp(28px, 4vw, 36px) !important;
  color: var(--charcoal) !important; font-weight: 400 !important;
  margin: 0 0 16px !important;
}
.summary .price .amount, .summary .price .woocommerce-Price-amount,
.summary .price .woocommerce-Price-currencySymbol, .summary .price bdi { color: var(--charcoal) !important; }

.summary .price del, .summary .price del .amount, .summary .price del bdi,
.single_variation .price del, .single_variation .price del .amount {
  color: var(--warm-grey) !important; text-decoration: line-through !important;
  font-weight: 400 !important; font-size: .72em !important; margin-right: 12px !important;
}
.summary .price ins, .summary .price ins .amount, .summary .price ins bdi,
.single_variation .price ins, .single_variation .price ins .amount {
  color: var(--burgundy) !important; text-decoration: none !important; font-weight: 400 !important;
}

.woocommerce-product-details__short-description {
  font-family: var(--sans) !important; font-size: 15px !important;
  line-height: 1.85 !important; color: var(--taupe) !important;
  margin-bottom: 36px !important; padding-bottom: 32px !important;
  border-bottom: 1px solid var(--rule);
}
.woocommerce-product-details__short-description p,
.woocommerce-product-details__short-description * { color: var(--taupe) !important; text-decoration: none !important; }
.woocommerce-product-details__short-description p { margin: 0 0 12px !important; }

.stock {
  font-family: var(--sans) !important; font-size: 11px !important; font-weight: 500 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  color: var(--charcoal) !important; margin: 0 0 24px !important;
  display: inline-flex; align-items: center; gap: 10px;
}
.stock.in-stock::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: #4a7c59; display: inline-block; }

form.cart { display: flex !important; gap: 10px !important; align-items: stretch !important; margin: 0 0 32px !important; flex-wrap: wrap; }
.quantity { display: inline-flex !important; align-items: center !important; border: 1px solid var(--rule) !important; background: var(--warm-white) !important; padding: 0 !important; margin: 0 !important; border-radius: 0 !important; }
.quantity .screen-reader-text { display: none; }
.quantity input.qty {
  width: 64px !important; height: 56px !important; border: 0 !important;
  background: transparent !important; text-align: center !important;
  font-family: var(--sans) !important; font-size: 15px !important; font-weight: 500 !important;
  color: var(--charcoal) !important; outline: none !important;
  -moz-appearance: textfield !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important;
}
.quantity input.qty::-webkit-outer-spin-button,
.quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none !important; margin: 0 !important; }

.single_add_to_cart_button, button.single_add_to_cart_button {
  flex: 1 !important; background: var(--charcoal) !important; color: var(--warm-white) !important;
  border: 1px solid var(--charcoal) !important; border-radius: 0 0 20px 0 !important;
  padding: 0 32px !important; font-family: var(--sans) !important;
  font-size: 12px !important; font-weight: 600 !important; letter-spacing: 2.5px !important;
  text-transform: uppercase !important; cursor: pointer !important;
  min-height: 56px !important; transition: background-color .25s ease, border-color .25s ease !important;
}
.single_add_to_cart_button:hover { background: var(--burgundy) !important; border-color: var(--burgundy) !important; }

/* Variable products — size / colour selectors */
form.cart.variations_form { display: block !important; }
.variations_form .variations { width: 100% !important; margin: 0 0 24px !important; border: 0 !important; }
.variations_form .variations tbody, .variations_form .variations tr { display: block !important; }
.variations_form .variations tr { margin-bottom: 18px !important; }
.variations_form .variations th.label {
  display: block !important; width: auto !important; padding: 0 0 8px !important;
  font-family: var(--sans) !important; font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important; color: var(--taupe) !important;
  text-align: left !important;
}
.variations_form .variations td.value { display: block !important; padding: 0 !important; }
.variations_form .variations select {
  width: 100%; max-width: 340px; height: 52px; padding: 0 44px 0 18px;
  font-family: var(--sans); font-size: 14px; letter-spacing: .5px; color: var(--charcoal);
  background-color: var(--warm-white); border: 1px solid var(--rule); border-radius: 0;
  outline: none; cursor: pointer; transition: border-color .2s ease;
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231A1714' stroke-width='1.5' d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 16px center; background-size: 12px;
}
.variations_form .variations select:focus { border-color: var(--charcoal); }
.variations_form .reset_variations {
  font-family: var(--sans); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--taupe); text-decoration: underline; text-underline-offset: 3px;
  display: inline-block; margin: 4px 0 0;
}
.single_variation_wrap { margin-top: 4px; }
.single_variation .price, .woocommerce-variation .price {
  font-family: var(--serif) !important; font-size: clamp(28px, 4vw, 36px) !important; font-weight: 400 !important;
  color: var(--charcoal) !important; margin: 0 0 16px !important;
}
.woocommerce-variation-availability .stock { margin: 0 0 20px !important; }
.woocommerce-variation-description { font-family: var(--sans); font-size: 14px; line-height: 1.8; color: var(--taupe); margin: 0 0 20px; }
.woocommerce-variation-add-to-cart { display: flex !important; gap: 10px !important; align-items: stretch !important; flex-wrap: wrap; margin: 0 0 32px !important; }
.woocommerce-variation-add-to-cart.woocommerce-variation-add-to-cart-disabled .single_add_to_cart_button { opacity: .4 !important; cursor: not-allowed !important; }

.product_meta {
  border-top: 1px solid var(--rule) !important; padding-top: 24px !important; margin: 0 !important;
  font-family: var(--sans) !important; font-size: 11px !important;
  letter-spacing: 1.5px !important; text-transform: uppercase !important; color: var(--taupe) !important;
}
.product_meta > span { display: block !important; margin-bottom: 8px !important; color: var(--taupe) !important; }
.product_meta a { color: var(--charcoal) !important; text-decoration: none !important; }

.woocommerce-tabs.wc-tabs-wrapper {
  margin-top: clamp(40px, 5vw, 80px) !important;
  border-top: 1px solid var(--rule) !important;
  padding-top: 56px !important; clear: both;
}
ul.tabs.wc-tabs {
  list-style: none !important; border: 0 !important;
  border-bottom: 1px solid var(--rule) !important; padding: 0 !important;
  margin: 0 0 48px !important; display: flex !important; gap: 36px !important;
  background: transparent !important; flex-wrap: wrap;
}
ul.tabs.wc-tabs::before, ul.tabs.wc-tabs::after { display: none !important; }
ul.tabs.wc-tabs li { background: transparent !important; border: 0 !important; border-bottom: 2px solid transparent !important; border-radius: 0 !important; margin: 0 0 -1px !important; padding: 0 !important; position: static !important; }
ul.tabs.wc-tabs li.active { border-bottom-color: var(--charcoal) !important; }
ul.tabs.wc-tabs li a {
  font-family: var(--sans) !important; font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 3px !important; text-transform: uppercase !important;
  color: var(--taupe) !important; padding: 14px 0 !important;
  display: inline-block !important; text-decoration: none !important; background: transparent !important;
}
ul.tabs.wc-tabs li.active a, ul.tabs.wc-tabs li a:hover { color: var(--charcoal) !important; }

.woocommerce-Tabs-panel, .wc-tab {
  font-family: var(--sans) !important; font-size: 15px !important;
  line-height: 1.85 !important; color: var(--charcoal) !important; max-width: 760px;
}
.woocommerce-Tabs-panel--description > h2:first-child,
#tab-description > h2:first-child { display: none !important; }
.woocommerce-Tabs-panel h2, .wc-tab h2 {
  font-family: var(--serif) !important; font-size: clamp(28px, 3vw, 40px) !important;
  font-weight: 500 !important; color: var(--charcoal) !important;
  margin: 0 0 24px !important;
}

.single_add_to_cart_button:focus-visible, .variations_form .variations select:focus-visible {
  outline: 2px solid var(--charcoal) !important; outline-offset: 2px !important;
}
.quantity input.qty:focus-visible { box-shadow: inset 0 0 0 1.5px var(--charcoal) !important; }

/* Express checkout (Stripe) hidden on the product page (still at checkout). */
#wc-stripe-express-checkout-element,
.wc-stripe-express-checkout-element,
.wc-stripe-product-checkout-container,
.wc-stripe-payment-request-wrapper,
.wc-stripe-payment-request-custom-button { display: none !important; }

/* Native colour <select> visually hidden behind the swatches. */
.lace-swatches__native {
  position: absolute !important; width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important; overflow: hidden !important;
  clip: rect(0 0 0 0) !important; clip-path: inset(50%) !important;
  white-space: nowrap !important; border: 0 !important;
}

/* ============================================================
   Related / up-sell products — proper cards, 4-up grid, no hover.
   Heading left-aligned per spec.
   ============================================================ */
.related.products,
.up-sells.products { clear: both; margin-top: clamp(56px, 7vw, 96px); }
.related.products > h2,
.up-sells.products > h2 {
  font-family: var(--serif); font-weight: 500; font-size: clamp(26px, 3vw, 38px);
  color: var(--charcoal); text-align: left; margin: 0 0 clamp(28px, 3vw, 40px);
}
.related.products ul.products,
.up-sells.products ul.products {
  display: grid !important; grid-template-columns: repeat(4, 1fr);
  gap: clamp(18px, 1.8vw, 30px); margin: 0; padding: 0; list-style: none; max-width: none;
}
.related.products ul.products::before, .related.products ul.products::after,
.up-sells.products ul.products::before, .up-sells.products ul.products::after { content: none; display: none; }
.related.products ul.products li.product,
.up-sells.products ul.products li.product {
  width: 100% !important; margin: 0 !important; padding: 0 !important; float: none !important; list-style: none;
  display: flex; flex-direction: column; text-align: left;
  background: var(--warm-white); border: 1px solid var(--rule); overflow: hidden;
}
.related.products li.product .woocommerce-LoopProduct-link,
.up-sells.products li.product .woocommerce-LoopProduct-link { display: block; text-decoration: none; color: var(--charcoal); }
.related.products li.product .woocommerce-LoopProduct-link::before,
.up-sells.products li.product .woocommerce-LoopProduct-link::before {
  content: "L A C E"; display: flex; align-items: center; justify-content: center;
  width: 100%; aspect-ratio: 4 / 5;
  background: linear-gradient(150deg, var(--sand-light) 0%, var(--sand) 60%, var(--warm-grey) 100%);
  font-family: var(--serif); font-size: 13px; letter-spacing: 9px; color: rgba(26,23,20,.18);
}
.related.products li.product .woocommerce-LoopProduct-link:has(img:not([src*="woocommerce-placeholder"]))::before,
.up-sells.products li.product .woocommerce-LoopProduct-link:has(img:not([src*="woocommerce-placeholder"]))::before { display: none; }
.related.products li.product .woocommerce-LoopProduct-link img,
.up-sells.products li.product .woocommerce-LoopProduct-link img { display: none !important; }
.related.products li.product .woocommerce-LoopProduct-link img:not([src*="woocommerce-placeholder"]),
.up-sells.products li.product .woocommerce-LoopProduct-link img:not([src*="woocommerce-placeholder"]) {
  display: block !important; width: 100% !important; height: auto !important; aspect-ratio: 4 / 5; object-fit: cover !important; margin: 0 !important;
}
.related.products li.product .woocommerce-loop-product__title,
.up-sells.products li.product .woocommerce-loop-product__title {
  font-family: var(--serif) !important; font-weight: 500 !important; font-size: clamp(15px, 1vw, 18px) !important; color: var(--charcoal) !important;
  line-height: 1.3 !important; letter-spacing: 0 !important; text-transform: none !important; margin: 0 !important; padding: 16px 18px 0 !important; text-align: left !important;
}
.related.products li.product .price,
.up-sells.products li.product .price {
  font-family: var(--serif) !important; font-size: 15px !important; color: var(--burgundy) !important; font-weight: 400 !important; margin: 0 !important; padding: 5px 18px 0 !important; display: block;
}
.related.products li.product .price .amount, .related.products li.product .price bdi,
.up-sells.products li.product .price .amount, .up-sells.products li.product .price bdi { color: inherit !important; background: none !important; font: inherit !important; }
.related.products li.product .button,
.related.products li.product .add_to_cart_button,
.up-sells.products li.product .button,
.up-sells.products li.product .add_to_cart_button {
  align-self: flex-start; display: inline-block; margin: 16px 18px 18px;
  background: transparent; color: var(--charcoal); border: 1px solid var(--charcoal);
  padding: 11px 22px; font-family: var(--sans); font-size: 10px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase; text-decoration: none; border-radius: 0;
  white-space: nowrap;
}
.related.products li.product .added_to_cart,
.up-sells.products li.product .added_to_cart { display: none; }

/* ============================================================
   MOBILE / TABLET
   ============================================================ */
@media (max-width: 1000px) {
  .related.products ul.products,
  .up-sells.products ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 960px) {
  /* Stack into natural source order: gallery → buy-box → tabs → related. */
  article.product div[id^="product-"] { display: block !important; }
  article.product .woocommerce-product-gallery { margin: 0 0 28px !important; }
  article.product .lace-thumbs { margin: 0 0 28px !important; }
  article.product .summary.entry-summary { margin: 0 0 8px !important; }
  article.product > h1 { font-size: clamp(34px, 8vw, 52px) !important; margin-bottom: 28px !important; }
}
@media (max-width: 560px) {
  /* Keep quantity small + inline beside Add to Cart (don't stack). */
  .quantity { align-self: stretch; }
  .quantity input.qty { width: 50px !important; }
  .single_add_to_cart_button { flex: 1 1 auto !important; width: auto !important; min-width: 0 !important; padding: 0 16px !important; }
  .variations_form .variations select { max-width: none; }
  ul.tabs.wc-tabs { gap: 20px !important; }
  .related.products li.product .woocommerce-loop-product__title,
  .up-sells.products li.product .woocommerce-loop-product__title { font-size: 14px !important; padding: 14px 14px 0 !important; }
  .related.products li.product .price,
  .up-sells.products li.product .price { padding: 4px 14px 0 !important; }
  /* Full-width related button so it never clips on narrow 2-up cards */
  .related.products li.product .button,
  .related.products li.product .add_to_cart_button,
  .up-sells.products li.product .button,
  .up-sells.products li.product .add_to_cart_button {
    align-self: stretch; text-align: center; margin: 14px 14px 16px;
    padding: 12px 8px; letter-spacing: 1.5px; white-space: normal;
  }
}
