/* =========================================================================
   Lumière Haven Blocks — WooCommerce styles (Design-System aligned).
   Bridges WooCommerce blocks into the DS component classes from style.css
   (.product-card, .pc-*, .btn, scent meter). Tokens come from style.css :root
   and theme.json presets.
   ========================================================================= */

/* ---- Shop hero ------------------------------------------------------- */
.lh-shop-hero { padding-block: clamp(3rem,6vw,5rem) clamp(1.6rem,3vw,2.4rem); }
.lh-shop-title { font-family: var(--font-display); font-weight: 500; font-size: clamp(2.4rem,5vw,4rem); line-height: 1.05; margin: 0 0 .6rem; color: var(--ink); }
.lh-term-desc { max-width: 50ch; margin-inline: auto; color: var(--muted); }

/* ---- Filter bar + sorting ------------------------------------------- */
.lh-filter-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-block: 1rem; }
.lh-shop-body { padding-top: clamp(2rem,4vw,3rem); padding-bottom: clamp(4rem,8vw,7rem); }
.lh-shop-bar { align-items: center; gap: 1rem; margin-bottom: clamp(1.4rem,3vw,2rem); }
.lh-shop-bar .wc-block-product-template__results-count,
.lh-shop-bar .woocommerce-result-count { font-size: .82rem; letter-spacing: .04em; color: var(--muted); margin: 0; }
.lh-shop-bar select,
.wc-block-catalog-sorting select,
.lh-shop-bar .orderby {
  appearance: none; -webkit-appearance: none; font-family: var(--font-sans); font-size: .82rem; letter-spacing: .04em;
  color: var(--ink); background: transparent; border: 1px solid var(--line-strong); border-radius: var(--radius-pill);
  padding: .65rem 2.6rem .65rem 1.2rem; cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%239C6644' d='M0 0h12L6 8z'/></svg>");
  background-repeat: no-repeat; background-position: right 1rem center;
}

/* ---- Product grid + card (bridges WC blocks → .product-card) -------- */
.lh-products .wp-block-woocommerce-product-template {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.2rem,2.4vw,2.2rem); list-style: none; margin: 0; padding: 0;
}
.lh-products .wc-block-product, .lh-products li.product { margin: 0; padding: 0; width: auto; min-width: 0; background: transparent; }
.product-card { height: 100%; }
.product-card .pc-media { position: relative; }
.product-card .pc-media .wp-block-woocommerce-product-image,
.product-card .pc-media .wc-block-components-product-image { margin: 0; height: 100%; }
.product-card .pc-media .wp-block-woocommerce-product-image a,
.product-card .pc-media a { display: block; height: 100%; }
.product-card .pc-media img { width: 100%; height: 100%; object-fit: cover; }
.product-card .pc-info { padding-top: 1rem; }
.product-card .pc-collection { display: block; }
.product-card .pc-collection a { color: var(--muted); text-decoration: none; }
.product-card .pc-name { margin: 0; }
.product-card .pc-name a { color: var(--ink); text-decoration: none; }
.product-card .pc-name a:hover { color: var(--amber-700); }
.product-card .pc-price { margin-top: .2rem; }
.product-card .pc-price .woocommerce-Price-amount,
.product-card .pc-price .wc-block-components-product-price { font-family: var(--font-sans); font-size: .95rem; color: var(--body); }

/* Quick-add overlay */
.product-card .pc-quickadd { position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 3; margin: 0; opacity: 0; transform: translateY(8px); transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); }
.product-card:hover .pc-quickadd, .product-card:focus-within .pc-quickadd { opacity: 1; transform: none; }
.product-card .pc-quickadd .wp-block-button__link,
.product-card .pc-quickadd a.button { width: 100%; display: block; text-align: center; font-size: .68rem; padding: .75em 1em; }

/* Pagination */
.lh-products .wp-block-query-pagination { gap: .4rem; }
.lh-products .wp-block-query-pagination a, .lh-products .wp-block-query-pagination .page-numbers { color: var(--muted); font-size: .9rem; padding: .3rem .6rem; }
.lh-products .wp-block-query-pagination .current { color: var(--amber); border-bottom: 1px solid var(--amber); }

/* ===================================================== PDP (charcoal) ===
   The single-product layout/colours live in style.css (.lh-pdp ...).
   These rules bridge WooCommerce single-product blocks into that world. */
.lh-pdp-top { padding-top: clamp(1.5rem,4vw,2.5rem); }
.lh-pdp-cols { align-items: flex-start; }
.lh-pdp-gallery { position: sticky; top: 100px; }
.lh-pdp-info { display: flex; flex-direction: column; gap: 1.1rem; padding-top: .5rem; }
.lh-pdp-info > * { margin: 0; }
.lh-pdp-title { font-family: var(--font-display); font-weight: 500; font-size: clamp(2.4rem,4.5vw,3.6rem); line-height: 1.02; color: var(--glow); }
.lh-pdp-summary { color: rgba(245,240,230,0.84); font-size: 1.05rem; line-height: 1.6; max-width: 46ch; }
.lh-pdp-rating { display: flex; align-items: center; gap: .6rem; }
.lh-stars { color: var(--gold-400); letter-spacing: .1em; }
.lh-stars-lg { font-size: 1.4rem; display: block; margin-bottom: 1.2rem; }
.lh-rating-count { font-size: .82rem; color: rgba(245,240,230,0.7); }
.lh-story-head { font-family: var(--font-display); font-weight: 500; font-size: 1.5rem; color: var(--glow); margin-top: .6rem; }
.lh-pdp-story { color: rgba(245,240,230,0.78); line-height: 1.7; max-width: 60ch; }
.lh-pdp-story h3 { font-family: var(--font-display); color: var(--gold-400); font-size: 1.15rem; margin: 1.4rem 0 .6rem; }
.lh-pdp-story ul { padding-left: 1.1rem; margin: 0 0 1rem; }
.lh-pdp-story li { margin-bottom: .3rem; }
.lh-pdp .wc-block-components-breadcrumbs, .lh-pdp .wc-block-components-breadcrumbs a { color: rgba(245,240,230,0.6); }
.lh-pdp .wc-block-components-breadcrumbs a:hover { color: var(--gold-400); }
.lh-review-inner { max-width: 760px; margin-inline: auto; text-align: center; padding-block: clamp(3rem,6vw,5rem); }
.lh-pdp .wp-block-woocommerce-product-image-gallery img,
.lh-pdp .wc-block-components-product-image img { border-radius: var(--radius-lg); }
.lh-pdp .wc-block-components-product-image, .lh-pdp figure { margin: 0; }
.lh-pdp .woocommerce-product-gallery { box-shadow: var(--shadow-lg); border-radius: var(--radius-lg); overflow: hidden; }
.lh-pdp .wp-block-add-to-cart-form, .lh-pdp .wc-block-components-product-add-to-cart { margin-top: 1rem; }

/* Variable products: scent + colour selectors (on the dark PDP) */
.lh-pdp table.variations { width: 100%; border-collapse: collapse; margin: 0 0 1rem; }
.lh-pdp table.variations tr { display: block; margin-bottom: 1rem; }
.lh-pdp table.variations th, .lh-pdp table.variations td { display: block; text-align: left; padding: 0; }
.lh-pdp table.variations th.label label { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-400); font-weight: 500; margin-bottom: .45rem; display: block; }
.lh-pdp table.variations select {
  appearance: none; -webkit-appearance: none; font-family: var(--font-sans); font-size: .95rem; color: var(--glow);
  width: 100%; max-width: 24rem; padding: .85rem 2.4rem .85rem 1rem;
  background-color: rgba(245,240,230,0.06); border: 1px solid var(--on-dark-line); border-radius: var(--radius-sm); cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23D4AF88' d='M0 0h12L6 8z'/></svg>");
  background-repeat: no-repeat; background-position: right 1rem center;
}
.lh-pdp table.variations select option { color: #211F1C; }
.lh-pdp table.variations select:focus { outline: none; border-color: var(--gold-500); }
.lh-pdp .reset_variations { display: inline-block; margin: .1rem 0 1rem; font-size: .75rem; color: rgba(245,240,230,0.6); text-decoration: none; }
.lh-pdp .woocommerce-variation-price .price { font-family: var(--font-display); font-size: 1.6rem; color: var(--gold-400); }
.lh-pdp .woocommerce-variation-add-to-cart { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; margin-top: .5rem; }

/* Add-to-cart (simple + variable) buttons → gold gradient pill */
.lh-pdp .single_add_to_cart_button, .lh-pdp .wp-block-button__link {
  font-family: var(--font-sans); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase;
  background: linear-gradient(135deg,var(--gold-400),var(--gold-600)); color: var(--amber-900);
  border: 0; border-radius: var(--radius-pill); padding: 1.05rem 2.2rem; min-height: 52px; cursor: pointer;
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.lh-pdp .single_add_to_cart_button:hover { box-shadow: 0 6px 22px rgba(196,158,114,0.45); transform: translateY(-1px); }
.lh-pdp .quantity input.qty {
  font-family: var(--font-sans); height: 52px; width: 4.5rem; text-align: center;
  border: 1px solid var(--on-dark-line); border-radius: var(--radius-pill); background: rgba(245,240,230,0.06); color: var(--glow);
}

/* ===================================================== CART / CHECKOUT ===
   Keep WooCommerce block cart/checkout on the warm light surface, brand-styled. */
.lh-page-wc { max-width: 1140px; margin-inline: auto; padding-left: var(--gutter); padding-right: var(--gutter); }
.wp-block-woocommerce-cart, .wp-block-woocommerce-checkout { font-family: var(--font-sans); color: var(--body); }

/* Section / step titles → serif */
.wc-block-components-title, .wc-block-cart__totals-title, .wc-block-components-checkout-step__title {
  font-family: var(--font-display) !important; font-weight: 500 !important; color: var(--ink) !important;
}

/* ---- Line items -------------------------------------------------------- */
.wc-block-cart-items__header {
  text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; color: var(--muted);
}
.wc-block-cart-items__row td, .wc-block-cart-items__row { border-color: var(--line) !important; }
.wc-block-components-product-name {
  font-family: var(--font-display) !important; font-size: 1.25rem !important;
  line-height: 1.25 !important; color: var(--ink) !important; text-decoration: none !important;
}
.wc-block-components-product-name:hover { color: var(--amber-600) !important; }
.wc-block-cart-item__image img, td.wc-block-cart-item__image img { border-radius: var(--radius-md); }
.wc-block-components-product-price__value,
.wc-block-cart-item__total-price-and-sale-badge-wrapper .wc-block-components-formatted-money-amount {
  font-family: var(--font-display); color: var(--ink);
}
.wc-block-cart-item__remove-link { color: var(--muted) !important; }
.wc-block-cart-item__remove-link:hover { color: var(--burgundy-900) !important; }

/* Quantity stepper → soft pill */
.wc-block-components-quantity-selector {
  border: 1px solid var(--line) !important; border-radius: var(--radius-pill) !important;
  background: var(--card); overflow: hidden;
}
.wc-block-components-quantity-selector__button { color: var(--amber-600) !important; }
.wc-block-components-quantity-selector__button:hover { background: rgba(140,126,104,0.10) !important; }
.wc-block-components-quantity-selector__input { color: var(--ink) !important; }

/* ---- Totals sidebar → ONE cohesive card (kills the nested rounded boxes) - */
.wc-block-components-sidebar {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 1.5rem 1.5rem 1.6rem;
  box-shadow: 0 18px 44px rgba(74,46,28,.07);
}
.wc-block-components-sidebar .wc-block-components-totals-wrapper {
  background: transparent !important; border-radius: 0 !important;
  padding: 1rem 0 !important; border-top: 1px solid var(--line); margin: 0 !important;
}
/* Collapse empty totals rows (discount / fee) so they don't draw blank bands */
.wc-block-components-sidebar .wc-block-components-totals-wrapper:empty { display: none !important; }
.wc-block-components-sidebar .wc-block-cart__totals-title { padding-bottom: .4rem; }
.wc-block-components-totals-item__label { color: var(--muted); }
.wc-block-components-totals-item__value { font-family: var(--font-display); color: var(--ink); }
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value { font-size: 1.4rem; }
.wc-block-components-totals-coupon .wc-block-components-panel__button {
  color: var(--amber-600) !important; font-family: var(--font-sans);
}

/* ---- Buttons ----------------------------------------------------------- */
.wc-block-cart__submit-container .wc-block-components-button,
.wc-block-components-button.contained,
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button {
  background: var(--amber-600) !important; color: var(--glow) !important;
  border-radius: var(--radius-pill) !important; font-size: .82rem !important;
  letter-spacing: .1em; text-transform: uppercase;
  transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.wc-block-cart__submit-container .wc-block-components-button:hover,
.wc-block-components-button.contained:hover,
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button:hover {
  background: var(--amber-700) !important; box-shadow: 0 8px 24px rgba(156,102,68,.30); transform: translateY(-1px);
}

/* ---- Inputs / selects -------------------------------------------------- */
.wc-block-components-text-input input, .wc-block-components-select select { border-radius: var(--radius-sm); }
.wc-block-components-text-input input:focus, .wc-block-components-text-input.is-active input {
  border-color: var(--amber-600) !important; box-shadow: 0 0 0 1px var(--amber-600) !important;
}
.wp-block-woocommerce-cart a, .wp-block-woocommerce-checkout a { color: var(--amber-600); }
/* Radios / checkboxes pick up the brand amber when selected */
.wp-block-woocommerce-checkout input[type="radio"],
.wp-block-woocommerce-checkout input[type="checkbox"],
.wp-block-woocommerce-cart input[type="checkbox"] { accent-color: var(--amber-600); }
/* Selected payment option → amber frame instead of stark black */
.wc-block-components-radio-control__option-checked {
  border-color: var(--amber-600) !important; box-shadow: 0 0 0 1px var(--amber-600) !important;
}

/* ===================================================== MINI-CART ===== */
.wc-block-mini-cart__button { color: inherit; }
.wc-block-mini-cart__badge { background: var(--gold-500); color: var(--amber-900); }

/* ---- Responsive ----------------------------------------------------- */
@media (max-width: 1024px) {
  .lh-products .wp-block-woocommerce-product-template { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 980px) {
  .lh-pdp-gallery { position: static; margin-bottom: 2rem; }
}
@media (max-width: 760px) {
  .lh-products .wp-block-woocommerce-product-template { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .product-card .pc-quickadd { opacity: 1; transform: none; }
}
/* Keep 2-up on phones (better browsing); single column only on very small screens */
@media (max-width: 360px) {
  .lh-products .wp-block-woocommerce-product-template { grid-template-columns: 1fr; }
}
