/* ==========================================================================
   SIGN MAX — WOOCOMMERCE OVERRIDES
   Shop archive, product card, single product, cart, checkout.
   ========================================================================== */

/* Hide default WooCommerce noise we replace */
.woocommerce-breadcrumb { display: none; } /* replaced by themed breadcrumbs */

/* ---- Product grid (bulletproof) -------------------------------------------
   WooCommerce ships a FLOAT grid (woocommerce-layout.css: width:22%; float:left).
   We override it completely with CSS grid. The critical detail is
   `minmax(0, 1fr)` — plain `1fr` tracks have an implicit `min-width:auto`, so a
   wide image or a long unbroken SKU blows out one column and squeezes the rest
   into narrow cards (which is what made the buttons collapse into red circles).
   minmax(0,1fr) forces equal, content-independent column widths. ------------- */
.woocommerce ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important; /* default 3-up */
  gap: var(--smx-space-5) !important;
  align-items: stretch;
  margin: 0 !important;
  padding: 0 !important;
}
.smx-shop-grid.columns-2 ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.smx-shop-grid.columns-3 ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.smx-shop-grid.columns-4 ul.products { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
/* neutralise the plugin's float/width/margin so li's behave as grid items */
.woocommerce ul.products li.product,
ul.products li.product {
  width: auto !important; max-width: none !important; min-width: 0 !important;
  margin: 0 !important; padding: 0 !important; float: none !important; clear: none !important;
  display: flex; /* card fills the cell -> equal heights, alignment survives AJAX */
}
ul.products li.product > .smx-product-card { width: 100%; min-width: 0; }
ul.products::before, ul.products::after { display: none !important; } /* kill clearfix */

.smx-product-card {
  position: relative; background: #fff; border: 1px solid var(--smx-border);
  border-radius: var(--smx-radius-lg); overflow: hidden; height: 100%;
  display: flex; flex-direction: column;
  transition: transform var(--smx-dur) var(--smx-ease), box-shadow var(--smx-dur) var(--smx-ease), border-color var(--smx-dur);
}
.smx-product-card:hover { transform: translateY(-6px); box-shadow: var(--smx-shadow-lg); border-color: transparent; }
.smx-product-card__media { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--smx-bg-soft); }
.smx-product-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--smx-dur-slow) var(--smx-ease); }
.smx-product-card:hover .smx-product-card__media img { transform: scale(1.06); }
.smx-product-card__badges { position: absolute; top: var(--smx-space-3); left: var(--smx-space-3); display: flex; flex-direction: column; gap: 0.4rem; z-index: 2; }
.smx-product-card__actions {
  position: absolute; top: var(--smx-space-3); right: var(--smx-space-3); display: flex; flex-direction: column; gap: 0.5rem; z-index: 2;
  opacity: 0; transform: translateX(10px); transition: all var(--smx-dur) var(--smx-ease);
}
.smx-product-card:hover .smx-product-card__actions,
.smx-product-card:focus-within .smx-product-card__actions { opacity: 1; transform: none; } /* :focus-within = keyboard parity */
.smx-product-card__actions button, .smx-product-card__actions a {
  width: 44px; height: 44px; border-radius: var(--smx-radius-pill); background: #fff; color: var(--smx-ink); /* 44px = min touch target */
  display: grid; place-items: center; box-shadow: var(--smx-shadow-sm); transition: all var(--smx-dur-fast);
}
.smx-product-card__actions button:hover, .smx-product-card__actions a:hover { background: var(--smx-primary); color: #fff; }
.smx-product-card__actions svg { width: 18px; height: 18px; }
.smx-product-card__actions .is-active { background: var(--smx-primary); color: #fff; }
.smx-product-card__body { padding: var(--smx-space-4); display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
/* Muted category label: with 12+ cards per view, red labels created accent
   noise — gray lets the title, price and CTA carry the hierarchy (red is
   reserved for emphasis). */
/* --smx-text (#717171, 4.88:1) not --smx-text-soft (#7A7A7A, 4.29:1): at this xs
   uppercase size the softer gray fails WCAG AA, so use the AA-safe body gray. */
.smx-product-card__cat { font-size: var(--smx-fs-xs); text-transform: uppercase; letter-spacing: 0.07em; color: var(--smx-text); font-weight: 600; }
.smx-product-card__title { font-family: var(--smx-font-body); font-size: var(--smx-fs-base); font-weight: 600; color: var(--smx-ink); line-height: 1.35; }
.smx-product-card__title a { color: inherit; }
.smx-product-card__title a:hover { color: var(--smx-primary); }
.smx-product-card__price { font-family: var(--smx-font-head); font-weight: 700; color: var(--smx-ink); font-size: var(--smx-fs-md); margin-top: auto; }
.smx-product-card__price del { color: var(--smx-text); font-weight: 400; font-size: var(--smx-fs-sm); margin-right: 0.4em; }
.smx-product-card__price ins { text-decoration: none; color: var(--smx-primary); }
.smx-product-card__foot { display: flex; align-items: center; justify-content: space-between; gap: var(--smx-space-3); margin-top: 0.6rem; }
.smx-product-card .smx-add-to-cart { flex: 1; }

/* quick-view button on hover */
.smx-product-card__quickview {
  position: absolute; left: 50%; bottom: var(--smx-space-3); transform: translate(-50%, 16px);
  opacity: 0; transition: all var(--smx-dur) var(--smx-ease); z-index: 2;
}
.smx-product-card__media:hover .smx-product-card__quickview { opacity: 1; transform: translateX(-50%); }

/* ---- Shop toolbar ---- */
.smx-shop-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--smx-space-4); flex-wrap: wrap; margin-bottom: var(--smx-space-5); }
.smx-shop-toolbar__count { font-size: var(--smx-fs-sm); }
.smx-shop-toolbar__right { display: flex; align-items: center; gap: var(--smx-space-3); }
.smx-shop-layout { display: grid; grid-template-columns: 280px 1fr; gap: var(--smx-space-6); align-items: start; }

/* ---- Shop sidebar / filters ---- */
.smx-filters { position: sticky; top: calc(var(--smx-header-h) + 16px); display: flex; flex-direction: column; gap: var(--smx-space-5); }
.smx-filter { border: 1px solid var(--smx-border); border-radius: var(--smx-radius); padding: var(--smx-space-4); background: #fff; margin: 0 0 15px ;}
.smx-filter h4 { font-size: var(--smx-fs-sm); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--smx-space-3); }
.smx-filter__list { display: flex; flex-direction: column; gap: 0.6rem; max-height: 280px; overflow-y: auto; }
.smx-filter__item { display: flex; align-items: center; gap: 0.5rem; font-size: var(--smx-fs-sm); cursor: pointer; }
.smx-filter__item input { accent-color: var(--smx-primary); width: 18px; height: 18px; }
.smx-filter__item .count { margin-left: auto; color: var(--smx-text); font-size: var(--smx-fs-xs); }
.smx-price-range { display: flex; align-items: center; gap: 0.5rem; }
.smx-price-range input { width: 100%; }

/* Dual-handle price range slider */
.smx-range__values { display: flex; justify-content: space-between; font-weight: 600; color: var(--smx-ink); font-size: var(--smx-fs-sm); margin-bottom: var(--smx-space-3); }
.smx-range__track { position: relative; height: 6px; background: var(--smx-border); border-radius: var(--smx-radius-pill); margin: 0 8px; }
.smx-range__fill { position: absolute; top: 0; bottom: 0; background: linear-gradient(90deg, var(--smx-secondary), var(--smx-primary)); border-radius: var(--smx-radius-pill); }
.smx-range__input { position: absolute; top: 50%; left: -8px; right: -8px; width: calc(100% + 16px); transform: translateY(-50%); margin: 0; background: none; pointer-events: none; -webkit-appearance: none; appearance: none; min-height: 0; height: 6px; padding: 0; border: 0; box-shadow: none; }
.smx-range__input:focus { outline: none; box-shadow: none; }
.smx-range__input::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; pointer-events: auto; width: 22px; height: 22px; border-radius: 50%; background: #fff; border: 3px solid var(--smx-primary); box-shadow: var(--smx-shadow-sm); cursor: grab; transition: transform var(--smx-dur-fast); }
.smx-range__input::-webkit-slider-thumb:active { cursor: grabbing; transform: scale(1.12); }
.smx-range__input::-moz-range-thumb { pointer-events: auto; width: 22px; height: 22px; border-radius: 50%; background: #fff; border: 3px solid var(--smx-primary); box-shadow: var(--smx-shadow-sm); cursor: grab; }
.smx-range__input:focus-visible::-webkit-slider-thumb { outline: 3px solid var(--smx-accent); outline-offset: 2px; }

.smx-shop-results { position: relative; min-height: 300px; }
.smx-shop-results.is-loading { opacity: 0.5; pointer-events: none; }
.smx-shop-loader { display: none; }
.smx-shop-results.is-loading .smx-shop-loader { display: grid; place-items: center; position: absolute; inset: 0; }
.smx-spinner { width: 44px; height: 44px; border: 3px solid var(--smx-border); border-top-color: var(--smx-primary); border-radius: 50%; animation: smx-spin 0.8s linear infinite; }
@keyframes smx-spin { to { transform: rotate(360deg); } }
.smx-loadmore-wrap { text-align: center; margin-top: var(--smx-space-7); }

/* ---- Single product ---- */
.smx-single-product { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--smx-space-7); align-items: start; }
.smx-pgallery { position: sticky; top: calc(var(--smx-header-h) + 16px); }
.smx-pgallery__main { border: 1px solid var(--smx-border); border-radius: var(--smx-radius-lg); overflow: hidden; aspect-ratio: 1/1; background: var(--smx-bg-soft); }
.smx-pgallery__main img { width: 100%; height: 100%; object-fit: cover; }
.smx-pgallery__thumbs { display: flex; gap: var(--smx-space-2); margin-top: var(--smx-space-3); flex-wrap: wrap; }
.smx-pgallery__thumbs button { width: 76px; height: 76px; border-radius: var(--smx-radius-sm); overflow: hidden; border: 2px solid transparent; }
.smx-pgallery__thumbs button.is-active { border-color: var(--smx-primary); }

/* ---- Native WooCommerce gallery, themed --------------------------------- */
/* WC plugin makes .woocommerce-product-gallery 48% + float:left — make it fill
   our gallery column and never stay invisible if the gallery JS is slow. */
.smx-pgallery .woocommerce-product-gallery {
  width: 100% !important; float: none !important; margin: 0 !important; opacity: 1 !important;
}
.smx-pgallery .woocommerce-product-gallery__wrapper { margin: 0; }
.smx-pgallery .woocommerce-product-gallery__image,
.smx-pgallery .woocommerce-product-gallery__image--placeholder {
  border: 1px solid var(--smx-border); border-radius: var(--smx-radius-lg); overflow: hidden;
  background: var(--smx-bg-soft); margin: 0;
}
.smx-pgallery .woocommerce-product-gallery__image a { display: block; }
.smx-pgallery .woocommerce-product-gallery__image img,
.smx-pgallery .woocommerce-product-gallery img { width: 100%; height: auto; display: block; border-radius: inherit; }
/* zoom/lightbox trigger button */
.smx-pgallery .woocommerce-product-gallery__trigger {
  top: var(--smx-space-4); right: var(--smx-space-4); z-index: 5;
  width: 46px; height: 46px; border-radius: var(--smx-radius-pill); background: #fff;
  box-shadow: var(--smx-shadow-sm); display: grid; place-items: center; text-indent: 0; color: var(--smx-ink);
}
.smx-pgallery .woocommerce-product-gallery__trigger::before { width: 16px; height: 16px; border-color: currentColor; top: 12px; left: 12px; }
.smx-pgallery .woocommerce-product-gallery__trigger::after { background: currentColor; top: 26px; left: 24px; }
/* thumbnail strip (flexslider control nav) */
.smx-pgallery .flex-control-thumbs { display: flex !important; flex-wrap: wrap; gap: var(--smx-space-2); margin: var(--smx-space-3) 0 0; padding: 0; list-style: none; }
.smx-pgallery .flex-control-thumbs li { width: 78px !important; height: 78px; margin: 0 !important; list-style: none; float: none !important; }
.smx-pgallery .flex-control-thumbs li img {
  width: 78px; height: 78px; object-fit: cover; border-radius: var(--smx-radius-sm);
  border: 2px solid transparent; opacity: 0.6; transition: opacity var(--smx-dur-fast), border-color var(--smx-dur-fast); cursor: pointer;
}
.smx-pgallery .flex-control-thumbs li img.flex-active,
.smx-pgallery .flex-control-thumbs li img:hover { opacity: 1; border-color: var(--smx-primary); }

/* Sale flash — restyle WC's circular "Sale!" into our pill badge */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.woocommerce div.product .onsale {
  position: absolute; top: var(--smx-space-3); left: var(--smx-space-3); right: auto; min-height: 0; min-width: 0;
  margin: 0; padding: 0.35em 0.7em; border-radius: var(--smx-radius-sm);
  background: var(--smx-primary); color: #fff; font-family: var(--smx-font-body);
  font-size: var(--smx-fs-xs); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; line-height: 1;
}
.smx-pgallery .onsale { z-index: 4; }

.smx-psummary__cat { font-size: var(--smx-fs-sm); text-transform: uppercase; letter-spacing: 0.06em; color: var(--smx-primary); font-weight: 600; }
.smx-psummary h1 { font-size: var(--smx-fs-2xl); margin: var(--smx-space-2) 0; }
.smx-psummary__meta { display: flex; align-items: center; gap: var(--smx-space-4); flex-wrap: wrap; font-size: var(--smx-fs-sm); }
.smx-psummary__price { font-family: var(--smx-font-head); font-size: var(--smx-fs-xl); font-weight: 700; color: var(--smx-ink); margin: var(--smx-space-4) 0; }
.smx-psummary__price del { color: var(--smx-text); font-size: 0.65em; font-weight: 400; margin-right: 0.4em; }
.smx-psummary__price ins { text-decoration: none; color: var(--smx-primary); }
.smx-psummary__excerpt { margin: var(--smx-space-4) 0; }
.smx-psummary__cart { display: flex; gap: var(--smx-space-3); align-items: center; flex-wrap: wrap; margin: var(--smx-space-5) 0; }
.smx-psummary__trust { display: flex; flex-wrap: wrap; gap: var(--smx-space-4); padding-top: var(--smx-space-5); border-top: 1px solid var(--smx-border); margin-top: var(--smx-space-5); }
.smx-psummary__trust div { display: flex; align-items: center; gap: 0.5rem; font-size: var(--smx-fs-sm); }
.smx-psummary__trust svg { width: 22px; height: 22px; color: var(--smx-accent); }

/* Native product_meta: SKU + category already live in the themed summary head —
   hide the duplicates, keep what's unique here (brand, tags) as a subtle row. */
.smx-psummary .product_meta { margin-top: var(--smx-space-4); font-size: var(--smx-fs-sm); color: var(--smx-text-soft); display: flex; flex-wrap: wrap; gap: var(--smx-space-4); }
.smx-psummary .product_meta .sku_wrapper,
.smx-psummary .product_meta .posted_in { display: none; }
.smx-psummary .product_meta a { color: var(--smx-ink); font-weight: 500; }
.smx-psummary .product_meta a:hover { color: var(--smx-primary); }

/* product tabs */
.smx-ptabs { margin-top: var(--smx-space-8); }
.smx-ptabs__nav { display: flex; gap: var(--smx-space-2); flex-wrap: wrap; border-bottom: 1px solid var(--smx-border); margin-bottom: var(--smx-space-5); }
.smx-ptabs__nav button { padding: 0.9rem 1.2rem; font-weight: 600; color: var(--smx-text); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.smx-ptabs__nav button.is-active { color: var(--smx-primary); border-color: var(--smx-primary); }
.smx-ptabs__panel { display: none; max-width: 100%; }
.smx-ptabs__panel.is-active { display: block; animation: smx-fade var(--smx-dur) var(--smx-ease); }
@keyframes smx-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.smx-spec-table { width: 100%; border-collapse: collapse; }
.smx-spec-table th, .smx-spec-table td { text-align: left; padding: 0.85rem 1rem; border-bottom: 1px solid var(--smx-border); font-size: var(--smx-fs-sm); }
.smx-spec-table th { width: 35%; color: var(--smx-ink); font-weight: 600; background: var(--smx-bg-soft); }

/* ---- Cart ---- */
.smx-cart-layout { display: grid; grid-template-columns: 1fr 380px; gap: var(--smx-space-6); align-items: start; }
.smx-free-ship { background: var(--smx-bg-soft); border: 1px solid var(--smx-border); border-radius: var(--smx-radius); padding: var(--smx-space-4); margin-bottom: var(--smx-space-5); }
.smx-free-ship__bar { height: 8px; background: var(--smx-border); border-radius: var(--smx-radius-pill); overflow: hidden; margin-top: 0.6rem; }
.smx-free-ship__fill { height: 100%; background: linear-gradient(90deg, var(--smx-secondary), var(--smx-primary)); transition: width var(--smx-dur-slow) var(--smx-ease); }
.smx-cart-summary { position: sticky; top: calc(var(--smx-header-h) + 16px); background: #fff; border: 1px solid var(--smx-border); border-radius: var(--smx-radius-lg); padding: var(--smx-space-5); }
.smx-cart-summary h3 { font-size: var(--smx-fs-md); margin-bottom: var(--smx-space-4); }

/* ---- Checkout ---- */
.smx-checkout-layout { display: grid; grid-template-columns: 1fr 400px; gap: var(--smx-space-7); align-items: start; }
.smx-checkout-steps { display: flex; gap: var(--smx-space-2); margin-bottom: var(--smx-space-6); }
.smx-checkout-step { display: flex; align-items: center; gap: 0.6rem; padding: 0.6rem 1rem; border-radius: var(--smx-radius-pill); background: var(--smx-bg-soft); font-size: var(--smx-fs-sm); font-weight: 600; color: var(--smx-text); }
.smx-checkout-step.is-active { background: var(--smx-primary); color: #fff; }
.smx-checkout-step__num { width: 24px; height: 24px; border-radius: 50%; background: rgba(0,0,0,0.08); display: grid; place-items: center; font-size: 12px; }
.smx-checkout-step.is-active .smx-checkout-step__num { background: rgba(255,255,255,0.25); }
.smx-trust-badges { display: flex; gap: var(--smx-space-3); flex-wrap: wrap; margin-top: var(--smx-space-4); }
.smx-trust-badges div { display: flex; align-items: center; gap: 0.4rem; font-size: var(--smx-fs-xs); color: var(--smx-text); }
.smx-trust-badges svg { width: 18px; height: 18px; color: var(--smx-success); }

/* ---- Compare: sticky bar + comparison table ---- */
.smx-compare-bar {
  position: fixed; left: 50%; bottom: 1.25rem; transform: translateX(-50%); z-index: var(--smx-z-header);
  display: flex; align-items: center; gap: var(--smx-space-4);
  background: var(--smx-ink); color: #fff; padding: 0.7rem 0.9rem 0.7rem 1.25rem;
  border-radius: var(--smx-radius-pill); box-shadow: var(--smx-shadow-lg);
  animation: smx-fade var(--smx-dur) var(--smx-ease);
}
.smx-compare-bar[hidden] { display: none; }
.smx-compare-bar__info { display: inline-flex; align-items: center; gap: 0.55rem; font-size: var(--smx-fs-sm); font-weight: 600; white-space: nowrap; }
.smx-compare-bar__info svg { color: var(--smx-secondary); }
.smx-compare-bar__clear { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; color: rgba(255,255,255,0.7); transition: all var(--smx-dur-fast); }
.smx-compare-bar__clear:hover { background: rgba(255,255,255,0.12); color: #fff; }
@media (max-width: 560px) { .smx-compare-bar { left: 1rem; right: 1rem; transform: none; justify-content: space-between; } }

.smx-compare-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--smx-border); border-radius: var(--smx-radius-lg); background: #fff; }
.smx-compare-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.smx-compare-table th {
  text-align: left; padding: 1rem 1.25rem; width: 180px; min-width: 150px;
  font-family: var(--smx-font-body); font-size: var(--smx-fs-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--smx-text); /* AA-safe at xs */
  background: var(--smx-bg-soft); vertical-align: middle;
}
.smx-compare-table td { padding: 1rem 1.25rem; border-left: 1px solid var(--smx-border); vertical-align: middle; min-width: 200px; }
.smx-compare-table tr + tr th, .smx-compare-table tr + tr td { border-top: 1px solid var(--smx-border); }
.smx-compare-prod { position: relative; }
.smx-compare-prod a { display: block; color: var(--smx-ink); }
.smx-compare-prod img { width: 84px; height: 84px; object-fit: cover; border-radius: var(--smx-radius-sm); border: 1px solid var(--smx-border); margin-bottom: 0.6rem; }
.smx-compare-prod__title { display: block; font-weight: 600; line-height: 1.35; }
.smx-compare-prod a:hover .smx-compare-prod__title { color: var(--smx-primary); }
.smx-compare-remove {
  position: absolute; top: -6px; right: 0; width: 30px; height: 30px; border-radius: 50%;
  background: var(--smx-bg-soft); border: 1px solid var(--smx-border); color: var(--smx-text);
  font-size: 1rem; line-height: 1; transition: all var(--smx-dur-fast);
}
.smx-compare-remove:hover { background: var(--smx-primary); border-color: var(--smx-primary); color: #fff; }
.smx-compare-price { font-family: var(--smx-font-head); font-weight: 700; color: var(--smx-ink); }
.smx-compare-price del { color: var(--smx-text-soft); font-weight: 400; font-size: 0.85em; margin-right: 0.3em; }
.smx-compare-price ins { text-decoration: none; color: var(--smx-primary); }
.smx-compare-dash { color: var(--smx-border-strong); }
.smx-compare-actions { margin-top: var(--smx-space-4); text-align: right; }
/* status badges (shared with the account area, needed here for availability) */
.smx-status { display: inline-flex; align-items: center; gap: 0.4em; font-size: var(--smx-fs-xs); font-weight: 700; padding: 0.35em 0.75em; border-radius: var(--smx-radius-pill); text-transform: capitalize; white-space: nowrap; }
.smx-status::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.smx-status--completed { background: #e4f6ec; color: #1f7a48; }
.smx-status--pending { background: #fff4e3; color: #b5750a; }

/* ---- Wishlist page ---- */
.smx-wishlist-empty {
  text-align: center; padding: var(--smx-space-8) var(--smx-space-5);
  max-width: 560px; margin-inline: auto;
  display: flex; flex-direction: column; align-items: center; gap: var(--smx-space-3);
}
.smx-wishlist-empty:hover { transform: none; box-shadow: none; border-color: var(--smx-border); } /* static card */
.smx-wishlist-empty__icon {
  width: 88px; height: 88px; border-radius: 50%; display: grid; place-items: center;
  background: var(--smx-primary-050); color: var(--smx-primary); margin-bottom: var(--smx-space-2);
}
.smx-wishlist-empty h3 { font-size: var(--smx-fs-lg); }
.smx-wishlist-empty .smx-btn { margin-top: var(--smx-space-3); }
.smx-wishlist-loading { display: grid; place-items: center; padding: var(--smx-space-8) 0; }
.smx-wishlist-loading[hidden] { display: none; } /* CSS display beats the UA [hidden] rule */

/* ==========================================================================
   NATIVE WOOCOMMERCE HEADING NORMALIZATION
   WC section titles inherit our large h2/h3 scale and dwarf everything. Hide the
   ones that duplicate our themed card titles; size the rest to the design system.
   ========================================================================== */
/* redundant with our "Order summary" card titles */
.woocommerce .cart_totals > h2,
.woocommerce-order-details__title { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }

/* size the remaining native section headings consistently */
.woocommerce-column__title,
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields h3#ship-to-different-address,
.woocommerce-shipping-fields > h3,
.woocommerce-additional-fields > h3,
.woocommerce-checkout-review-order > h3,
#order_review_heading,
.cross-sells > h2,
.up-sells > h2,
.woocommerce-Addresses .woocommerce-Address-title h3,
.woocommerce-order-downloads__title {
  font-family: var(--smx-font-head); font-size: var(--smx-fs-md) !important; font-weight: 600;
  line-height: 1.2; letter-spacing: var(--smx-tracking-tight); margin: 0 0 var(--smx-space-3) !important;
  color: var(--smx-ink);
}
/* "Ship to a different address?" is a checkbox label wrapped in an <h3> */
.woocommerce-shipping-fields h3#ship-to-different-address label { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600; cursor: pointer; }
.woocommerce-shipping-fields h3#ship-to-different-address { display: block; padding-top: var(--smx-space-2); }

/* ==========================================================================
   SHARED WOOCOMMERCE ELEMENT NORMALIZATION (forms, inputs, checkboxes, radios,
   notices, buttons) — loaded on ALL WooCommerce pages so shop/product/cart/
   checkout/account are visually consistent with the design system.
   ========================================================================== */
.woocommerce form .form-row,
.woocommerce-page form .form-row { padding: 0; margin: 0 0 var(--smx-space-4); }
.woocommerce form .form-row label,
.smx-field label,
.woocommerce-account .woocommerce label {
  display: block; font-size: var(--smx-fs-sm); font-weight: 600; color: var(--smx-ink); margin-bottom: 0.4rem;
}
.woocommerce .input-text,
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="password"],
.woocommerce input[type="number"],
.woocommerce textarea,
.woocommerce select,
.select2-container .select2-selection--single {
  width: 100%; min-height: 52px; padding: 0.8em 1.05em;
  border: 1.5px solid var(--smx-border); border-radius: var(--smx-radius-sm);
  background: var(--smx-bg); color: var(--smx-ink); font-size: var(--smx-fs-base);
  transition: border-color var(--smx-dur-fast), box-shadow var(--smx-dur-fast); box-shadow: none;
}
.woocommerce .input-text:focus,
.woocommerce input:focus,
.woocommerce textarea:focus,
.woocommerce select:focus {
  outline: none; border-color: var(--smx-accent); box-shadow: 0 0 0 4px rgba(0,90,169,0.12);
}
.woocommerce .input-text::placeholder { color: #b4b4b4; }
.select2-container--default .select2-selection--single { border-color: var(--smx-border) !important; height: 52px !important; }
.select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 50px !important; padding-left: 1.05em; color: var(--smx-ink); }
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 50px; }
.select2-container--open .select2-dropdown { border-color: var(--smx-accent); border-radius: var(--smx-radius-sm); overflow: hidden; box-shadow: var(--smx-shadow); }
.woocommerce form .form-row .required { color: var(--smx-primary); border: 0; }

/* Custom checkbox & radio (scoped to forms; shop filter checkboxes keep their own style) */
.woocommerce-form__label-for-checkbox,
.smx-check { display: inline-flex; align-items: center; gap: 0.55rem; font-weight: 500; cursor: pointer; color: var(--smx-text); }
.woocommerce form input[type="checkbox"], .woocommerce form input[type="radio"], .smx-check input {
  appearance: none; -webkit-appearance: none; width: 20px; height: 20px; min-height: 0;
  border: 1.5px solid var(--smx-border-strong); border-radius: 6px; background: #fff; position: relative; flex-shrink: 0; padding: 0; cursor: pointer;
  transition: border-color var(--smx-dur-fast), background var(--smx-dur-fast);
}
.woocommerce form input[type="radio"], .smx-check input[type="radio"] { border-radius: 50%; }
.woocommerce form input[type="checkbox"]:checked, .woocommerce form input[type="radio"]:checked, .smx-check input:checked { background: var(--smx-primary); border-color: var(--smx-primary); }
.woocommerce form input[type="checkbox"]:checked::after { content: ""; position: absolute; left: 6px; top: 2px; width: 5px; height: 10px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.woocommerce form input[type="radio"]:checked::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: #fff; }
.woocommerce form input[type="checkbox"]:focus-visible, .woocommerce form input[type="radio"]:focus-visible { outline: 3px solid var(--smx-accent); outline-offset: 2px; }

/* Validation / notices */
.woocommerce form .woocommerce-invalid input.input-text,
.woocommerce form .woocommerce-invalid select { border-color: var(--smx-primary); box-shadow: 0 0 0 4px rgba(235,28,35,0.1); }
.woocommerce form .woocommerce-validated input.input-text { border-color: var(--smx-success); }
.woocommerce-NoticeGroup, .woocommerce-notices-wrapper { margin-bottom: var(--smx-space-4); }
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
  border: 1px solid var(--smx-border); border-left: 4px solid var(--smx-accent);
  background: var(--smx-bg-soft); border-radius: var(--smx-radius-sm);
  padding: 1rem 1.25rem; list-style: none; display: flex; align-items: center; flex-wrap: wrap; gap: 0.75rem;
  font-size: var(--smx-fs-sm); color: var(--smx-ink);
}
.woocommerce-message { border-left-color: var(--smx-success); }
.woocommerce-error { border-left-color: var(--smx-primary); }
.woocommerce-error li { width: 100%; }
/* WC prints its icon font in an absolutely-positioned ::before — it collides
   with our flex layout (and shows a tofu box if the font hasn't loaded). */
.woocommerce-message::before, .woocommerce-message::after,
.woocommerce-info::before, .woocommerce-info::after,
.woocommerce-error::before, .woocommerce-error::after,
.woocommerce-noreviews::before { display: none !important; content: none !important; }
/* WC focuses fresh notices programmatically (tabindex="-1"); a focus ring on
   them reads as a giant blue border. Keyboard users can't tab to them anyway. */
.woocommerce-message:focus, .woocommerce-info:focus, .woocommerce-error:focus,
[tabindex="-1"]:focus-visible { outline: none !important; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { padding-left: 1.25rem; position: static; }
.woocommerce-message .button, .woocommerce-info .button, .woocommerce-error .button {
  margin-left: auto; padding: 0.55em 1.1em; border-radius: var(--smx-radius-pill);
  background: var(--smx-ink); color: #fff; font-weight: 600; font-size: var(--smx-fs-sm);
}

/* WooCommerce default buttons -> brand pill buttons (but never override .smx-btn) */
.woocommerce #respond input#submit,
.woocommerce a.button:not(.smx-btn),
.woocommerce button.button:not(.smx-btn),
.woocommerce input.button:not(.smx-btn),
.woocommerce #place_order,
.woocommerce .button:not(.smx-btn) {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5em;
  font-family: var(--smx-font-body); font-weight: 600; line-height: 1;
  padding: 0.95em 1.7em; border-radius: var(--smx-radius-pill);
  background: var(--smx-ink); color: #fff; border: 1.5px solid transparent;
  transition: transform var(--smx-dur-fast) var(--smx-ease), box-shadow var(--smx-dur) var(--smx-ease), background var(--smx-dur-fast); text-decoration: none; cursor: pointer;
}
.woocommerce a.button:not(.smx-btn):hover, .woocommerce button.button:not(.smx-btn):hover, .woocommerce input.button:not(.smx-btn):hover, .woocommerce .button:not(.smx-btn):hover { transform: translateY(-2px); box-shadow: var(--smx-shadow); color: #fff; }
.woocommerce .button.alt:not(.smx-btn), .woocommerce #place_order, .woocommerce button.button.alt:not(.smx-btn), .woocommerce .single_add_to_cart_button { background: var(--smx-primary); }
.woocommerce .button.alt:not(.smx-btn):hover, .woocommerce #place_order:hover, .woocommerce .single_add_to_cart_button:hover { background: var(--smx-primary-600); box-shadow: var(--smx-shadow-primary); }
.woocommerce .button[disabled]:not(.smx-btn), .woocommerce .button:disabled:not(.smx-btn) { opacity: 0.55; cursor: not-allowed; transform: none; }

/* Single product: native qty + add-to-cart layout */
.woocommerce div.product form.cart { display: flex; flex-wrap: wrap; align-items: center; gap: var(--smx-space-3); margin: var(--smx-space-5) 0; }
.woocommerce div.product form.cart .quantity { margin: 0; }
.woocommerce .quantity input.qty {
  width: 88px; min-height: 52px; text-align: center; border: 1.5px solid var(--smx-border); border-radius: var(--smx-radius-pill);
}
.woocommerce div.product form.cart .button { flex: 1 1 auto; }
.woocommerce div.product form.cart .variations { width: 100%; border-collapse: separate; border-spacing: 0 0.5rem; }
.woocommerce div.product form.cart .variations td, .woocommerce div.product form.cart .variations th { display: block; text-align: left; padding: 0; }
.woocommerce div.product .quantity .qty { -moz-appearance: textfield; }

/* Quantity stepper (progressive enhancement; buttons injected by main.js) */
.smx-qtywrap { display: inline-flex; align-items: center; border: 1.5px solid var(--smx-border); border-radius: var(--smx-radius-pill); overflow: hidden; background: #fff; }
.smx-qtywrap button {
  width: 44px; height: 48px; min-width: 44px; display: grid; place-items: center; /* 44px = min touch target */
  font-size: 1.15rem; font-weight: 600; color: var(--smx-ink); background: transparent; border: 0;
  cursor: pointer; transition: background var(--smx-dur-fast), color var(--smx-dur-fast);
}
.smx-qtywrap button:hover { background: var(--smx-bg-soft); color: var(--smx-primary); }
.smx-qtywrap .quantity { margin: 0 !important; }
.smx-qtywrap input.qty {
  width: 56px !important; min-height: 48px; text-align: center;
  border: 0 !important; border-radius: 0 !important; box-shadow: none !important; background: transparent;
  -moz-appearance: textfield; appearance: textfield;
}
.smx-qtywrap input.qty::-webkit-outer-spin-button,
.smx-qtywrap input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* "Price on request" fallback for products with no price (quote-driven) */
.smx-psummary__price:empty::before { content: "Price on request"; color: var(--smx-accent); font-size: var(--smx-fs-md); }
.smx-product-card__price:empty::before { content: "Request a quote"; color: var(--smx-accent); font-weight: 600; font-size: var(--smx-fs-sm); }
