/* ==========================================================================
   Baby Gift Shop — Scandinavian / Natural WooCommerce Theme
   Palette: beige, sage green, off-white, blush, warm gold, dark sage
   Fonts:  Playfair Display (headings) + Inter (body)
   ========================================================================== */

/* --- Google Fonts -------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

/* --- Custom Properties --------------------------------------------------- */
:root {
  /* palette */
  --color-beige:      #F5F0EB;
  --color-sage:       #A8B5A0;
  --color-sage-light: #c3ccbc;
  --color-sage-dark:  #8a9b80;
  --color-off-white:  #FAFAF7;
  --color-blush:      #E8D5D0;
  --color-blush-light:#f2e8e4;
  --color-gold:       #D4A574;
  --color-gold-dark:  #b88a5a;
  --color-dark-sage:  #2C3E2E;
  --color-dark-sage-light: #3d5340;
  --color-white:      #FFFFFF;

  /* semantic */
  --color-primary:    var(--color-sage);
  --color-secondary:  var(--color-blush);
  --color-accent:     var(--color-gold);
  --color-bg:         var(--color-beige);
  --color-surface:    var(--color-off-white);
  --color-text:       var(--color-dark-sage);
  --color-text-muted: #5a6e5c;
  --color-border:     #ddd5ce;

  /* typography */
  --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* spacing */
  --space-xs:  0.25rem;
  --space-sm:  0.5rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;

  /* radii */
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-pill: 50px;

  /* shadows */
  --shadow-sm:   0 1px 3px rgba(44,62,46,0.06);
  --shadow-md:   0 4px 12px rgba(44,62,46,0.08);
  --shadow-lg:   0 8px 30px rgba(44,62,46,0.12);
  --shadow-lift: 0 12px 36px rgba(44,62,46,0.15);

  /* transitions */
  --transition-fast: 0.2s ease;
  --transition-base: 0.3s ease;
}

/* --- Reset / Base -------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-dark-sage);
  margin-top: 0;
}

h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }

p {
  margin-top: 0;
  margin-bottom: var(--space-md);
}

a {
  color: var(--color-sage-dark);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-gold);
}

img {
  max-width: 100%;
  height: auto;
}

/* --- Layout -------------------------------------------------------------- */
.site-content,
.woocommerce-page .site-content {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

/* --- Site Header --------------------------------------------------------- */
.site-header {
  background-color: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
}

.site-header .site-branding {
  padding: var(--space-md) 0;
}

.site-header .site-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-dark-sage);
  letter-spacing: -0.02em;
}

.site-header .site-title a {
  color: inherit;
}

.site-header .site-title a:hover {
  color: var(--color-sage);
}

.site-header .site-description {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  font-style: italic;
  margin: 0;
}

/* Navigation */
.main-navigation {
  background-color: var(--color-sage);
}

.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: var(--space-xs);
}

.main-navigation li a {
  display: block;
  padding: var(--space-sm) var(--space-lg);
  color: var(--color-white);
  font-size: 0.9rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: background-color var(--transition-fast);
}

.main-navigation li a:hover,
.main-navigation li.current-menu-item a {
  background-color: var(--color-sage-dark);
  color: var(--color-white);
}

/* Header cart icon */
.site-header-cart .cart-contents {
  color: var(--color-dark-sage);
  position: relative;
}

.site-header-cart .cart-contents .count {
  background-color: var(--color-gold);
  color: var(--color-white);
  font-size: 0.7rem;
  font-weight: 700;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -6px;
  right: -8px;
}

/* --- Trust Bar ----------------------------------------------------------- */
.trust-bar {
  background-color: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-sm) 0;
}

.trust-bar__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: flex;
  justify-content: center;
  gap: var(--space-2xl);
  flex-wrap: wrap;
}

.trust-bar__item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.trust-bar__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.trust-bar__icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: var(--color-sage);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* --- Hero / Collection Banners ------------------------------------------- */
.collection-banner {
  background: linear-gradient(135deg, var(--color-sage) 0%, var(--color-blush) 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl) var(--space-2xl);
  text-align: center;
  margin-bottom: var(--space-2xl);
  position: relative;
  overflow: hidden;
}

.collection-banner::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 60%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(255,255,255,0.12) 0%, transparent 70%);
  pointer-events: none;
}

.collection-banner h1,
.collection-banner h2 {
  color: var(--color-white);
  text-shadow: 0 2px 8px rgba(44,62,46,0.15);
  margin-bottom: var(--space-sm);
  position: relative;
}

.collection-banner p {
  color: rgba(255,255,255,0.9);
  font-size: 1.1rem;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
}

/* --- Product Cards ------------------------------------------------------- */
.products,
ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-xl);
  list-style: none;
  padding: 0;
  margin: var(--space-xl) 0;
}

.products .product,
ul.products li.product {
  background-color: var(--color-surface);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  position: relative;
}

.products .product:hover,
ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lift);
}

.products .product .woocommerce-LoopProduct-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* Product image */
.products .product img,
ul.products li.product img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-base);
}

.products .product:hover img {
  transform: scale(1.03);
}

.products .product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--color-dark-sage);
  padding: var(--space-md) var(--space-md) var(--space-xs);
  margin: 0;
  line-height: 1.4;
}

/* Product price */
.products .product .price,
ul.products li.product .price {
  padding: 0 var(--space-md);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-sage-dark);
}

.products .product .price del {
  color: var(--color-text-muted);
  font-weight: 400;
  font-size: 0.9rem;
}

.products .product .price ins {
  text-decoration: none;
  color: var(--color-gold-dark);
}

/* Star rating */
.products .product .star-rating,
.star-rating {
  color: var(--color-gold);
  font-size: 0.85rem;
  padding: var(--space-xs) var(--space-md);
}

.star-rating span::before {
  color: var(--color-gold);
}

/* Add to cart button (loop) */
.products .product .button,
ul.products li.product .add_to_cart_button {
  display: block;
  margin: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-sage);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.products .product .button:hover,
ul.products li.product .add_to_cart_button:hover {
  background-color: var(--color-sage-dark);
  transform: scale(1.02);
}

/* --- Sale Badge ---------------------------------------------------------- */
.onsale,
.products .product .onsale,
span.onsale {
  position: absolute;
  top: var(--space-md);
  left: var(--space-md);
  z-index: 10;
  background-color: var(--color-gold);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 4px 14px;
  border-radius: var(--radius-pill);
  line-height: 1.4;
  box-shadow: 0 2px 6px rgba(212,165,116,0.35);
  min-height: auto;
  min-width: auto;
}

/* --- Buttons (Global WooCommerce) ---------------------------------------- */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button {
  background-color: var(--color-sage);
  color: var(--color-white);
  border: 2px solid var(--color-sage);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  padding: 12px 28px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all var(--transition-fast);
  line-height: 1.4;
}

.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button:hover {
  background-color: var(--color-sage-dark);
  border-color: var(--color-sage-dark);
  color: var(--color-white);
}

/* Alt / CTA buttons — warm gold */
.woocommerce .button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.button.alt,
.woocommerce .checkout-button,
.woocommerce #place_order {
  background-color: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-white);
}

.woocommerce .button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce .checkout-button:hover,
.woocommerce #place_order:hover {
  background-color: var(--color-gold-dark);
  border-color: var(--color-gold-dark);
  color: var(--color-white);
}

/* Outline / secondary button */
.woocommerce .button.wc-forward,
.woocommerce a.button.wc-forward {
  background-color: transparent;
  color: var(--color-sage);
  border: 2px solid var(--color-sage);
}

.woocommerce .button.wc-forward:hover,
.woocommerce a.button.wc-forward:hover {
  background-color: var(--color-sage);
  color: var(--color-white);
}

/* --- Single Product Page ------------------------------------------------- */
.single-product .product {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-md);
  margin: var(--space-xl) 0;
}

.single-product .product .woocommerce-product-gallery {
  border-radius: var(--radius-md);
  overflow: hidden;
}

.single-product .product .woocommerce-product-gallery img {
  border-radius: var(--radius-md);
}

.single-product .product .product_title {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 600;
  color: var(--color-dark-sage);
  margin-bottom: var(--space-sm);
}

.single-product .product .price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-sage-dark);
  margin-bottom: var(--space-lg);
}

.single-product .product .price del {
  font-size: 1.1rem;
  color: var(--color-text-muted);
  font-weight: 400;
}

.single-product .product .price ins {
  text-decoration: none;
  color: var(--color-gold-dark);
}

.single-product .product .woocommerce-product-details__short-description {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}

/* Quantity input */
.single-product .product .quantity .qty {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-size: 1rem;
  font-family: var(--font-body);
  color: var(--color-text);
  width: 70px;
  text-align: center;
}

.single-product .product .quantity .qty:focus {
  border-color: var(--color-sage);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

/* Add to cart on single */
.single-product .product .single_add_to_cart_button {
  background-color: var(--color-gold);
  border-color: var(--color-gold);
  font-size: 1rem;
  padding: 14px 36px;
}

.single-product .product .single_add_to_cart_button:hover {
  background-color: var(--color-gold-dark);
  border-color: var(--color-gold-dark);
}

/* Tabs */
.single-product .woocommerce-tabs {
  margin-top: var(--space-2xl);
}

.single-product .woocommerce-tabs ul.tabs {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-lg) 0;
  display: flex;
  gap: var(--space-xs);
  border-bottom: 2px solid var(--color-border);
}

.single-product .woocommerce-tabs ul.tabs li {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
}

.single-product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: var(--space-sm) var(--space-lg);
  font-weight: 500;
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--transition-fast);
}

.single-product .woocommerce-tabs ul.tabs li.active a {
  color: var(--color-sage-dark);
  border-bottom-color: var(--color-sage);
}

.single-product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-sage);
}

/* Related products heading */
.single-product .related.products > h2,
.single-product .upsells.products > h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  text-align: center;
  margin: var(--space-2xl) 0 var(--space-lg);
  color: var(--color-dark-sage);
}

/* --- Cart Page ----------------------------------------------------------- */
.woocommerce-cart .woocommerce {
  margin: var(--space-xl) 0;
}

.woocommerce table.shop_table {
  border: none;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: var(--color-surface);
}

.woocommerce table.shop_table thead {
  background-color: var(--color-sage);
}

.woocommerce table.shop_table thead th {
  color: var(--color-white);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--space-md) var(--space-lg);
  border: none;
}

.woocommerce table.shop_table td {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

.woocommerce table.shop_table td.product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: var(--radius-sm);
}

.woocommerce table.shop_table td.product-name a {
  font-weight: 500;
  color: var(--color-dark-sage);
}

.woocommerce table.shop_table td.product-name a:hover {
  color: var(--color-sage);
}

/* Cart totals */
.woocommerce .cart-collaterals .cart_totals {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  box-shadow: var(--shadow-sm);
}

.woocommerce .cart-collaterals .cart_totals h2 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  margin-bottom: var(--space-lg);
}

/* Coupon */
.woocommerce .coupon .input-text {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-family: var(--font-body);
}

.woocommerce .coupon .input-text:focus {
  border-color: var(--color-sage);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

/* --- Checkout Page ------------------------------------------------------- */
.woocommerce-checkout .woocommerce {
  margin: var(--space-xl) 0;
}

.woocommerce form .form-row label {
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--color-dark-sage);
  margin-bottom: var(--space-xs);
}

.woocommerce form .form-row .input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-text);
  background-color: var(--color-white);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--color-sage);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

/* Order review */
.woocommerce-checkout #order_review {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  box-shadow: var(--shadow-md);
}

.woocommerce-checkout #order_review_heading {
  font-family: var(--font-heading);
  font-size: 1.5rem;
}

/* Payment methods */
.woocommerce-checkout .wc_payment_methods {
  list-style: none;
  padding: 0;
}

.woocommerce-checkout .wc_payment_method {
  background: var(--color-white);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  transition: border-color var(--transition-fast);
}

.woocommerce-checkout .wc_payment_method:has(input:checked) {
  border-color: var(--color-sage);
}

.woocommerce-checkout .wc_payment_method label {
  font-weight: 600;
  cursor: pointer;
}

/* --- Notices / Messages -------------------------------------------------- */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--color-sage);
  background-color: var(--color-surface);
  color: var(--color-text);
  border-radius: var(--radius-sm);
}

.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--color-sage);
}

.woocommerce-error {
  border-top-color: #c44;
  background-color: #fdf2f2;
  border-radius: var(--radius-sm);
}

/* --- Breadcrumbs --------------------------------------------------------- */
.woocommerce .woocommerce-breadcrumb {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  padding: var(--space-md) 0;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--color-sage-dark);
}

.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--color-gold);
}

/* --- Pagination ---------------------------------------------------------- */
.woocommerce nav.woocommerce-pagination {
  text-align: center;
  margin: var(--space-2xl) 0;
}

.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  gap: var(--space-xs);
  border: none;
}

.woocommerce nav.woocommerce-pagination ul li {
  border: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  font-weight: 500;
  color: var(--color-text);
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  transition: all var(--transition-fast);
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--color-sage);
  border-color: var(--color-sage);
  color: var(--color-white);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--color-sage);
  border-color: var(--color-sage);
  color: var(--color-white);
  font-weight: 700;
}

/* --- Widgets / Sidebar --------------------------------------------------- */
.widget {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  box-shadow: var(--shadow-sm);
}

.widget .widget-title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-dark-sage);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-sage);
}

.widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.widget ul li {
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--color-border);
}

.widget ul li:last-child {
  border-bottom: none;
}

.widget ul li a {
  color: var(--color-text);
  font-size: 0.9rem;
}

.widget ul li a:hover {
  color: var(--color-sage);
}

/* Price filter widget */
.woocommerce .widget_price_filter .ui-slider {
  background: var(--color-border);
  border-radius: var(--radius-pill);
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  background: var(--color-sage);
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  background: var(--color-sage);
  border-color: var(--color-sage-dark);
  border-radius: 50%;
}

/* --- Footer -------------------------------------------------------------- */
.site-footer {
  background-color: var(--color-dark-sage);
  color: rgba(255,255,255,0.8);
  margin-top: var(--space-3xl);
}

.site-footer a {
  color: rgba(255,255,255,0.8);
  transition: color var(--transition-fast);
}

.site-footer a:hover {
  color: var(--color-gold);
}

.site-footer .footer-widgets {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-3xl) var(--space-xl) var(--space-2xl);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-2xl);
}

.site-footer .widget {
  background: transparent;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
}

.site-footer .widget .widget-title {
  color: var(--color-white);
  font-size: 1rem;
  border-bottom-color: rgba(255,255,255,0.15);
}

.site-footer .widget ul li {
  border-bottom-color: rgba(255,255,255,0.08);
}

.site-footer .widget ul li a {
  color: rgba(255,255,255,0.7);
  font-size: 0.85rem;
}

.site-footer .widget ul li a:hover {
  color: var(--color-gold);
}

.site-footer .site-info {
  text-align: center;
  padding: var(--space-lg) var(--space-xl);
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
}

/* --- Responsive ---------------------------------------------------------- */
@media (max-width: 768px) {
  :root {
    --space-xl: 1rem;
    --space-2xl: 1.5rem;
    --space-3xl: 2rem;
  }

  body {
    font-size: 15px;
  }

  h1 { font-size: 1.8rem; }
  h2 { font-size: 1.5rem; }
  h3 { font-size: 1.25rem; }

  .site-content,
  .woocommerce-page .site-content {
    padding: 0 var(--space-md);
  }

  /* Navigation stacks on mobile */
  .main-navigation ul {
    flex-direction: column;
    align-items: stretch;
  }

  .main-navigation li a {
    text-align: center;
    padding: var(--space-sm) var(--space-md);
  }

  /* Trust bar scrolls horizontally on mobile */
  .trust-bar__inner {
    justify-content: flex-start;
    gap: var(--space-lg);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--space-sm);
  }

  /* Product grid 1 or 2 columns */
  .products,
  ul.products {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--space-md);
  }

  .products .product img,
  ul.products li.product img {
    height: 200px;
  }

  /* Collection banner */
  .collection-banner {
    padding: var(--space-2xl) var(--space-lg);
    border-radius: var(--radius-md);
  }

  .collection-banner h1,
  .collection-banner h2 {
    font-size: 1.5rem;
  }

  /* Single product */
  .single-product .product {
    padding: var(--space-lg);
  }

  .single-product .product .product_title {
    font-size: 1.5rem;
  }

  .single-product .product .price {
    font-size: 1.25rem;
  }

  /* Tabs stack on mobile */
  .single-product .woocommerce-tabs ul.tabs {
    flex-direction: column;
    border-bottom: none;
    gap: 0;
  }

  .single-product .woocommerce-tabs ul.tabs li a {
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 0;
  }

  .single-product .woocommerce-tabs ul.tabs li.active a {
    background-color: var(--color-sage);
    color: var(--color-white);
    border-bottom-color: var(--color-sage);
    border-radius: var(--radius-sm);
  }

  /* Cart table becomes block on mobile */
  .woocommerce table.shop_table thead {
    display: none;
  }

  .woocommerce table.shop_table tr {
    display: block;
    margin-bottom: var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
  }

  .woocommerce table.shop_table td {
    display: block;
    text-align: right;
    padding: var(--space-sm) var(--space-md);
  }

  .woocommerce table.shop_table td::before {
    content: attr(data-title);
    float: left;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.8rem;
    letter-spacing: 0.03em;
  }

  /* Footer grid stacks */
  .site-footer .footer-widgets {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }

  /* Checkout order review full width */
  .woocommerce-checkout #order_review {
    padding: var(--space-md);
  }
}

/* --- Utility Classes ----------------------------------------------------- */
.text-center { text-align: center; }
.text-sage   { color: var(--color-sage); }
.text-gold   { color: var(--color-gold); }
.bg-surface  { background-color: var(--color-surface); }
.bg-beige    { background-color: var(--color-beige); }
.rounded     { border-radius: var(--radius-md); }
.shadow      { box-shadow: var(--shadow-md); }

/* --- Print --------------------------------------------------------------- */
@media print {
  .site-header,
  .site-footer,
  .trust-bar,
  .main-navigation {
    display: none;
  }

  body {
    background: #fff;
    color: #000;
    font-size: 12pt;
  }
}

/* ==========================================================================
   STOREFRONT THEME OVERRIDES
   Force Storefront's default classes to match our Scandinavian baby shop design.
   Added 2026-03-09.
   ========================================================================== */

/* -------------------------------------------------------------------------
   1. GLOBAL / LAYOUT — Override Storefront container & body defaults
   ------------------------------------------------------------------------- */
#page {
  background-color: var(--color-bg);
}

.col-full {
  max-width: 1280px;
  padding-left: var(--space-xl);
  padding-right: var(--space-xl);
}

/* Storefront applies its own font stack via inline customiser CSS */
body.storefront,
body.woocommerce,
body.woocommerce-page {
  font-family: var(--font-body) !important;
  color: var(--color-text);
  background-color: var(--color-bg);
}

/* -------------------------------------------------------------------------
   2. HEADER — .site-header, .site-branding, search, cart icon
   ------------------------------------------------------------------------- */
.site-header,
#masthead {
  background-color: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
  padding-top: 0;
  padding-bottom: 0;
  margin-bottom: 0;
}

/* Storefront inner header flex row */
.site-header .col-full {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* Branding / logo */
.site-branding,
.site-header .site-branding {
  padding: var(--space-md) 0;
  margin: 0;
  float: none;
  width: auto;
}

.site-branding h1,
.site-branding .beta,
.site-branding p.site-title,
.site-header .site-title {
  font-family: var(--font-heading) !important;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-dark-sage);
  letter-spacing: -0.02em;
  margin: 0;
}

.site-branding h1 a,
.site-branding .beta a,
.site-branding p.site-title a,
.site-header .site-title a {
  color: inherit;
  text-decoration: none;
}

.site-branding h1 a:hover,
.site-branding p.site-title a:hover {
  color: var(--color-sage);
}

.site-branding .site-description,
.site-header .site-description {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  font-style: italic;
  margin: 0;
}

/* Storefront header cart */
.site-header-cart,
.site-header .site-header-cart {
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-header-cart .cart-contents,
.site-header .site-header-cart .cart-contents {
  color: var(--color-dark-sage);
  text-decoration: none;
}

.site-header-cart .cart-contents:hover {
  color: var(--color-sage);
}

/* Storefront product search in header */
.site-header .widget_product_search input[type="search"],
.site-header .site-search input[type="search"] {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-pill);
  padding: 8px 16px;
  font-family: var(--font-body);
  font-size: 0.9rem;
  background-color: var(--color-white);
  transition: border-color var(--transition-fast);
}

.site-header .widget_product_search input[type="search"]:focus,
.site-header .site-search input[type="search"]:focus {
  border-color: var(--color-sage);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

/* -------------------------------------------------------------------------
   3. NAVIGATION — .storefront-primary-navigation, .main-navigation,
      .secondary-navigation, .handheld-navigation
   ------------------------------------------------------------------------- */
.storefront-primary-navigation,
.main-navigation,
.secondary-navigation,
#site-navigation {
  background-color: var(--color-sage) !important;
}

.storefront-primary-navigation .col-full {
  padding: 0;
}

/* Links in the nav bar */
.main-navigation ul.menu > li > a,
.main-navigation ul.nav-menu > li > a,
.storefront-primary-navigation .main-navigation ul.menu > li > a,
.secondary-navigation ul.menu > li > a {
  color: var(--color-white) !important;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 12px 20px;
  transition: background-color var(--transition-fast);
}

.main-navigation ul.menu > li > a:hover,
.main-navigation ul.nav-menu > li > a:hover,
.main-navigation ul.menu > li.current-menu-item > a,
.main-navigation ul.menu > li.current_page_item > a {
  background-color: var(--color-sage-dark) !important;
  color: var(--color-white) !important;
}

/* Centered nav */
.main-navigation ul.menu,
.main-navigation ul.nav-menu {
  display: flex;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Sub-menus / dropdowns */
.main-navigation ul.menu ul.sub-menu,
.main-navigation ul.nav-menu ul.sub-menu {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
  padding: var(--space-xs) 0;
}

.main-navigation ul.menu ul.sub-menu li a,
.main-navigation ul.nav-menu ul.sub-menu li a {
  color: var(--color-dark-sage) !important;
  font-size: 0.85rem;
  text-transform: none;
  letter-spacing: 0;
  padding: 8px 20px;
}

.main-navigation ul.menu ul.sub-menu li a:hover {
  background-color: var(--color-beige) !important;
  color: var(--color-sage-dark) !important;
}

/* -------------------------------------------------------------------------
   4. PRODUCT GRID — Storefront specificity overrides for product cards
   ------------------------------------------------------------------------- */

/* Storefront uses high-specificity selectors on .columns-* wrappers */
.woocommerce .site-main ul.products,
.storefront-sorting .woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-xl);
}

/* Override Storefront's product li width/margin */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  background-color: var(--color-surface);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  border: none;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lift);
}

/* Product image in grid */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  margin: 0 !important;
  border-radius: 0;
  display: block;
  transition: transform var(--transition-base);
}

.woocommerce ul.products li.product:hover a img {
  transform: scale(1.03);
}

/* Product title in grid — Storefront marks it as h2 */
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-heading) !important;
  font-size: 1.05rem !important;
  font-weight: 500;
  color: var(--color-dark-sage);
  padding: var(--space-md) var(--space-md) var(--space-xs);
  margin: 0;
  line-height: 1.4;
}

/* Product price in grid */
.woocommerce ul.products li.product .price {
  padding: 0 var(--space-md);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-sage-dark);
}

/* Add-to-cart in grid */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.product_type_simple {
  display: block;
  margin: var(--space-md) !important;
  padding: var(--space-sm) var(--space-md);
  background-color: var(--color-sage) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.6;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover {
  background-color: var(--color-sage-dark) !important;
  transform: scale(1.02);
}

/* Sale badge — Storefront positions absolutely */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.storefront span.onsale {
  position: absolute;
  top: var(--space-md) !important;
  left: var(--space-md) !important;
  right: auto !important;
  z-index: 10;
  background-color: var(--color-gold) !important;
  color: var(--color-white) !important;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 4px 14px !important;
  border-radius: var(--radius-pill) !important;
  line-height: 1.4;
  box-shadow: 0 2px 6px rgba(212,165,116,0.35);
  min-height: auto !important;
  min-width: auto !important;
  margin: 0 !important;
}

/* Star rating color */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
  color: var(--color-gold) !important;
}

/* Ordering / result count bar */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  color: var(--color-text-muted);
  font-size: 0.85rem;
}

.woocommerce .woocommerce-ordering select {
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 6px 12px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-text);
  background-color: var(--color-white);
}

.woocommerce .woocommerce-ordering select:focus {
  border-color: var(--color-sage);
  outline: none;
}

/* -------------------------------------------------------------------------
   5. SINGLE PRODUCT — Storefront specificity boosts
   ------------------------------------------------------------------------- */
.single-product div.product,
.single-product .type-product {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-md);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-xl);
}

.single-product div.product .product_title,
.single-product div.product h1.product_title {
  font-family: var(--font-heading) !important;
  font-size: 2rem;
  font-weight: 600;
  color: var(--color-dark-sage);
}

.single-product div.product p.price,
.single-product div.product span.price {
  font-size: 1.5rem !important;
  font-weight: 700;
  color: var(--color-sage-dark) !important;
}

/* Gallery */
.single-product div.product .woocommerce-product-gallery .flex-viewport,
.single-product div.product .woocommerce-product-gallery .woocommerce-product-gallery__image {
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* Tabs — Storefront wraps in .woocommerce-tabs */
.single-product div.product .woocommerce-tabs ul.tabs {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 var(--space-lg) 0 !important;
  display: flex;
  border-bottom: 2px solid var(--color-border);
}

.single-product div.product .woocommerce-tabs ul.tabs li {
  background: none !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.single-product div.product .woocommerce-tabs ul.tabs li::before,
.single-product div.product .woocommerce-tabs ul.tabs li::after {
  display: none !important;
}

.single-product div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: var(--space-sm) var(--space-lg);
  font-weight: 500;
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}

.single-product div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--color-sage-dark);
  border-bottom-color: var(--color-sage);
}

.single-product div.product .woocommerce-tabs .panel {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: var(--space-lg) 0;
}

.single-product div.product .woocommerce-tabs .panel h2 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  color: var(--color-dark-sage);
}

/* -------------------------------------------------------------------------
   6. CART & CHECKOUT — Storefront specificity
   ------------------------------------------------------------------------- */
/* Storefront wraps cart items in a higher-specificity selector */
.woocommerce-cart table.shop_table,
.woocommerce-page table.shop_table {
  border: none !important;
  border-collapse: collapse;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: var(--color-surface);
}

.woocommerce-cart table.shop_table thead,
.woocommerce-page table.shop_table thead {
  background-color: var(--color-sage) !important;
}

.woocommerce-cart table.shop_table thead th {
  color: var(--color-white) !important;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  border: none !important;
  padding: var(--space-md) var(--space-lg);
}

.woocommerce-cart table.shop_table td {
  border-bottom: 1px solid var(--color-border) !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  padding: var(--space-md) var(--space-lg);
  vertical-align: middle;
}

/* Cart collaterals / totals panel */
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  box-shadow: var(--shadow-sm);
}

.woocommerce-cart .cart-collaterals .cart_totals table {
  border: none !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table th,
.woocommerce-cart .cart-collaterals .cart_totals table td {
  border: none !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: var(--space-sm) 0;
}

/* Checkout form fields */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea,
#billing_country_field .select2-selection,
#shipping_country_field .select2-selection,
.woocommerce .select2-container--default .select2-selection--single {
  border: 2px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-text);
  background-color: var(--color-white) !important;
  min-height: 44px;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  border-color: var(--color-sage) !important;
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

/* Checkout order review */
.woocommerce-checkout #order_review,
.woocommerce-checkout #order_review_heading + #order_review {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  box-shadow: var(--shadow-md);
  border: none;
}

/* Checkout place-order button */
.woocommerce-checkout #place_order {
  background-color: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  color: var(--color-white) !important;
  border-radius: var(--radius-pill) !important;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  padding: 14px 36px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  width: 100%;
}

.woocommerce-checkout #place_order:hover {
  background-color: var(--color-gold-dark) !important;
  border-color: var(--color-gold-dark) !important;
}

/* My Account pages */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: var(--space-sm) var(--space-md);
  color: var(--color-dark-sage);
  border-radius: var(--radius-sm);
  font-weight: 500;
  transition: background-color var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background-color: var(--color-sage);
  color: var(--color-white);
}

/* -------------------------------------------------------------------------
   7. FOOTER — .site-footer Storefront overrides
   ------------------------------------------------------------------------- */
.site-footer,
footer.site-footer,
#colophon {
  background-color: var(--color-dark-sage) !important;
  color: rgba(255,255,255,0.8);
  margin-top: var(--space-3xl);
  border-top: none;
}

.site-footer .col-full {
  max-width: 1280px;
}

/* Footer widgets grid */
.site-footer .footer-widget-region,
.site-footer .footer-widgets {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-3xl) var(--space-xl) var(--space-2xl);
}

.footer-widget-region .col-full {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-2xl);
}

.site-footer .widget {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.site-footer .widget .widget-title,
.site-footer .widget .widgettitle,
.site-footer .widget h4 {
  color: var(--color-white) !important;
  font-family: var(--font-heading);
  font-size: 1rem;
  border-bottom: 2px solid rgba(255,255,255,0.15) !important;
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-md);
}

.site-footer .widget ul li {
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.site-footer .widget ul li a,
.site-footer .widget a {
  color: rgba(255,255,255,0.7) !important;
  font-size: 0.85rem;
}

.site-footer .widget ul li a:hover,
.site-footer .widget a:hover {
  color: var(--color-gold) !important;
}

/* Copyright / site-info bar */
.site-footer .site-info,
.site-info {
  text-align: center;
  padding: var(--space-lg) var(--space-xl);
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5) !important;
  background-color: transparent !important;
}

.site-info a {
  color: rgba(255,255,255,0.6) !important;
}

.site-info a:hover {
  color: var(--color-gold) !important;
}

/* -------------------------------------------------------------------------
   8. HIDE STOREFRONT-SPECIFIC ELEMENTS that clash with our design
   ------------------------------------------------------------------------- */
/* Handheld footer bar — hidden everywhere (redundant with header nav) */
.storefront-handheld-footer-bar {
  display: none !important;
}

/* Hide "Built with Storefront & WooCommerce" credit if present */
.site-info .powered-by-woocommerce,
.site-info .powered-by-wordpress {
  display: none !important;
}

/* Hide duplicate breadcrumbs (Storefront + Yoast/WooCommerce may double) */
.storefront-breadcrumb + .woocommerce-breadcrumb,
.woocommerce-breadcrumb + .storefront-breadcrumb {
  display: none !important;
}

/* Storefront breadcrumb wrapper */
.storefront-breadcrumb {
  background-color: transparent;
  border-bottom: none;
  margin-bottom: 0;
  padding: var(--space-sm) 0;
}

.storefront-breadcrumb .col-full {
  padding-top: var(--space-sm);
  padding-bottom: var(--space-sm);
}

.storefront-breadcrumb .woocommerce-breadcrumb {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin: 0;
  padding: 0;
}

.storefront-breadcrumb .woocommerce-breadcrumb a {
  color: var(--color-sage-dark);
}

.storefront-breadcrumb .woocommerce-breadcrumb a:hover {
  color: var(--color-gold);
}

/* -------------------------------------------------------------------------
   9. HOMEPAGE CONTENT BLOCKS — Hero, category grid, newsletter
   (Rendered via WP block editor / HTML blocks in page content)
   ------------------------------------------------------------------------- */

/* Hero banner — typically a cover block or custom HTML */
.wp-block-cover.hero-banner,
.hero-banner,
.home-hero {
  background: linear-gradient(135deg, var(--color-sage) 0%, var(--color-blush) 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl) var(--space-2xl);
  text-align: center;
  margin-bottom: var(--space-2xl);
  position: relative;
  overflow: hidden;
}

/* Hero full-width on mobile — break out of all parent padding */
@media (max-width: 768px) {
  .wp-block-cover.hero-banner,
  .hero-banner,
  .home-hero {
    border-radius: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    padding: var(--space-2xl) var(--space-lg) !important;
    box-sizing: border-box !important;
  }
}

.hero-banner::before,
.home-hero::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 60%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(255,255,255,0.12) 0%, transparent 70%);
  pointer-events: none;
}

.hero-banner h1,
.hero-banner h2,
.home-hero h1,
.home-hero h2 {
  color: var(--color-white) !important;
  text-shadow: 0 2px 8px rgba(44,62,46,0.15);
  margin-bottom: var(--space-sm);
  position: relative;
}

.hero-banner p,
.home-hero p {
  color: rgba(255,255,255,0.9);
  font-size: 1.1rem;
  max-width: 600px;
  margin: 0 auto var(--space-lg);
  position: relative;
}

.hero-banner .wp-block-button a,
.hero-banner .button,
.home-hero .button,
.home-hero .wp-block-button a {
  background-color: var(--color-gold) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  padding: 14px 36px;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
  position: relative;
}

.hero-banner .wp-block-button a:hover,
.hero-banner .button:hover,
.home-hero .button:hover,
.home-hero .wp-block-button a:hover {
  background-color: var(--color-gold-dark) !important;
  transform: scale(1.03);
}

/* Category grid on homepage */
.category-grid,
.home-categories {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-xl);
  margin: var(--space-2xl) 0;
  padding: 0;
  list-style: none;
}

.category-grid .category-card,
.home-categories .category-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  text-align: center;
  text-decoration: none;
  color: inherit;
  display: block;
}

.category-grid .category-card:hover,
.home-categories .category-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.category-grid .category-card img,
.home-categories .category-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}

.category-grid .category-card h3,
.category-grid .category-card h4,
.home-categories .category-card h3,
.home-categories .category-card h4 {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-dark-sage);
  padding: var(--space-md);
  margin: 0;
}

/* WooCommerce product categories on homepage (Storefront widget) */
.woocommerce ul.products li.product-category,
.woocommerce-page ul.products li.product-category {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.woocommerce ul.products li.product-category:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.woocommerce ul.products li.product-category a img {
  border-radius: 0;
  margin: 0 !important;
}

.woocommerce ul.products li.product-category a h2,
.woocommerce ul.products li.product-category a h3 {
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  padding: var(--space-md);
  margin: 0;
  color: var(--color-dark-sage);
}

.woocommerce ul.products li.product-category a h2 .count {
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 400;
}

/* Newsletter section */
.newsletter-section,
.home-newsletter {
  background: linear-gradient(135deg, var(--color-blush-light) 0%, var(--color-blush) 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl) var(--space-2xl);
  text-align: center;
  margin: var(--space-2xl) 0;
}

.newsletter-section h2,
.newsletter-section h3,
.home-newsletter h2,
.home-newsletter h3 {
  font-family: var(--font-heading);
  color: var(--color-dark-sage);
  margin-bottom: var(--space-sm);
}

.newsletter-section p,
.home-newsletter p {
  color: var(--color-text-muted);
  max-width: 500px;
  margin: 0 auto var(--space-lg);
}

.newsletter-section form,
.home-newsletter form {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
  max-width: 480px;
  margin: 0 auto;
}

.newsletter-section input[type="email"],
.home-newsletter input[type="email"] {
  flex: 1;
  min-width: 200px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-pill);
  padding: 12px 20px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  background-color: var(--color-white);
}

.newsletter-section input[type="email"]:focus,
.home-newsletter input[type="email"]:focus {
  border-color: var(--color-sage);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,181,160,0.2);
}

.newsletter-section button,
.newsletter-section input[type="submit"],
.home-newsletter button,
.home-newsletter input[type="submit"] {
  background-color: var(--color-sage);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-pill);
  padding: 12px 28px;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.newsletter-section button:hover,
.newsletter-section input[type="submit"]:hover,
.home-newsletter button:hover,
.home-newsletter input[type="submit"]:hover {
  background-color: var(--color-sage-dark);
}

/* -------------------------------------------------------------------------
   10. STOREFRONT HOMEPAGE SECTIONS — product rows, recent/featured/on-sale
   ------------------------------------------------------------------------- */
.storefront-product-section {
  margin: var(--space-2xl) 0;
  padding: var(--space-lg) 0;
}

.storefront-product-section .section-title,
.storefront-product-section > h2 {
  font-family: var(--font-heading) !important;
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-dark-sage);
  text-align: center;
  margin-bottom: var(--space-xl);
}

/* -------------------------------------------------------------------------
   11. GUTENBERG / BLOCK EDITOR — style overrides for WP blocks
   ------------------------------------------------------------------------- */
.wp-block-button .wp-block-button__link {
  background-color: var(--color-sage);
  color: var(--color-white);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 12px 28px;
  transition: background-color var(--transition-fast);
}

.wp-block-button .wp-block-button__link:hover {
  background-color: var(--color-sage-dark);
  color: var(--color-white);
}

.wp-block-button.is-style-outline .wp-block-button__link {
  background-color: transparent;
  color: var(--color-sage);
  border: 2px solid var(--color-sage);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background-color: var(--color-sage);
  color: var(--color-white);
}

/* Block columns / group */
.wp-block-group {
  border-radius: var(--radius-md);
}

.wp-block-separator {
  border-color: var(--color-border);
  opacity: 0.5;
}

.wp-block-quote {
  border-left: 4px solid var(--color-sage);
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-lg) 0;
  background: var(--color-surface);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-style: italic;
  color: var(--color-text-muted);
}

/* -------------------------------------------------------------------------
   12. WOOCOMMERCE NOTICES — higher specificity for Storefront
   ------------------------------------------------------------------------- */
.woocommerce-page .woocommerce-message,
.woocommerce-page .woocommerce-info,
body.woocommerce .woocommerce-message,
body.woocommerce .woocommerce-info {
  border-top-color: var(--color-sage) !important;
  background-color: var(--color-surface) !important;
  color: var(--color-text);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}

.woocommerce-page .woocommerce-message::before,
.woocommerce-page .woocommerce-info::before {
  color: var(--color-sage) !important;
}

.woocommerce-page .woocommerce-error,
body.woocommerce .woocommerce-error {
  border-top-color: #c44 !important;
  background-color: #fdf2f2 !important;
  border-radius: var(--radius-sm);
}

.woocommerce-message a.button,
.woocommerce-info a.button,
.woocommerce-error a.button {
  background-color: var(--color-sage) !important;
  color: var(--color-white) !important;
  border-radius: var(--radius-pill) !important;
  border: none !important;
  font-size: 0.8rem;
  padding: 8px 18px;
}

/* -------------------------------------------------------------------------
   13. STOREFRONT RESPONSIVE OVERRIDES
   ------------------------------------------------------------------------- */
@media (max-width: 768px) {
  .col-full {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  /* Storefront mobile nav toggle */
  .menu-toggle,
  .storefront-primary-navigation .menu-toggle {
    background-color: var(--color-sage-dark) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: var(--radius-sm);
    padding: 8px 16px;
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 0.04em;
  }

  .menu-toggle:hover {
    background-color: var(--color-dark-sage) !important;
  }

  /* Mobile nav dropdown panel */
  .main-navigation.toggled ul.menu,
  .main-navigation.toggled ul.nav-menu {
    flex-direction: column;
    align-items: stretch;
    background-color: var(--color-sage);
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  }

  .main-navigation.toggled ul.menu > li > a,
  .main-navigation.toggled ul.nav-menu > li > a {
    text-align: center;
    padding: var(--space-sm) var(--space-md);
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }

  /* Mobile product grid */
  .woocommerce .site-main ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
    gap: var(--space-md);
  }

  .woocommerce ul.products li.product a img {
    height: 200px;
  }

  /* Hero banner responsive */
  .hero-banner,
  .home-hero {
    padding: var(--space-2xl) var(--space-lg);
    border-radius: var(--radius-md);
  }

  .hero-banner h1,
  .hero-banner h2,
  .home-hero h1,
  .home-hero h2 {
    font-size: 1.5rem !important;
  }

  /* Newsletter responsive */
  .newsletter-section form,
  .home-newsletter form {
    flex-direction: column;
    align-items: center;
  }

  .newsletter-section input[type="email"],
  .home-newsletter input[type="email"] {
    width: 100%;
    min-width: auto;
  }

  /* Category grid responsive */
  .category-grid,
  .home-categories {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }

  /* Single product responsive */
  .single-product div.product {
    padding: var(--space-lg);
  }

  .single-product div.product .product_title,
  .single-product div.product h1.product_title {
    font-size: 1.5rem;
  }

  .single-product div.product p.price,
  .single-product div.product span.price {
    font-size: 1.25rem !important;
  }

  /* Tabs stacking */
  .single-product div.product .woocommerce-tabs ul.tabs {
    flex-direction: column;
    border-bottom: none;
  }

  .single-product div.product .woocommerce-tabs ul.tabs li a {
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 0;
  }

  .single-product div.product .woocommerce-tabs ul.tabs li.active a {
    background-color: var(--color-sage);
    color: var(--color-white);
    border-bottom-color: var(--color-sage);
    border-radius: var(--radius-sm);
  }

  /* Footer stacks */
  .footer-widget-region .col-full {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
}

@media (max-width: 480px) {
  .category-grid,
  .home-categories {
    grid-template-columns: 1fr;
  }
}

/* -------------------------------------------------------------------------
   14. SMOOTH SCROLLING & ACCESSIBILITY
   ------------------------------------------------------------------------- */
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* Focus outlines in our palette */
*:focus-visible {
  outline: 2px solid var(--color-sage);
  outline-offset: 2px;
}

/* Skip link (Storefront includes one) */
.skip-link:focus {
  background-color: var(--color-sage);
  color: var(--color-white);
  border-radius: var(--radius-sm);
  padding: 8px 16px;
  z-index: 10000;
}

/* =========================================================================
   15. HOMEPAGE CRITICAL FIXES — collections grid, hero, title, trust bar,
       product cards, add-to-cart buttons
   ========================================================================= */

/* --- Hide "Home" page title on front page -------------------------------- */
.home .entry-header,
.page-template-default.home .entry-header,
body.home article .entry-title,
body.page-id-65 .entry-header {
  display: none !important;
}

/* --- Hero section wrapper ------------------------------------------------ */
.hero-section {
  margin: 0 0 var(--space-2xl);
}

/* --- Trust bar SVG fix (Storefront may strip stroke) --------------------- */
.trust-bar__icon svg {
  width: 24px !important;
  height: 24px !important;
  fill: none !important;
  stroke: var(--color-sage) !important;
  stroke-width: 1.5 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  display: block !important;
}

/* --- Collections Grid (homepage) ----------------------------------------- */
.collections-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-xl) !important;
  margin: var(--space-xl) 0 var(--space-2xl) !important;
  padding: 0;
}

/* Remove parasitic <p> and <br> from wpautop inside the grid */
.collections-grid > p,
.collections-grid > br,
.collections-grid p:empty {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

/* Collection card link */
.collection-card {
  display: block !important;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
  text-decoration: none !important;
  color: inherit !important;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.collection-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.collection-card .collection-img,
.collection-card img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.collection-info {
  padding: var(--space-md);
  text-align: center;
}

.collection-info h3 {
  font-family: var(--font-heading) !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  color: var(--color-dark-sage) !important;
  margin: 0 0 var(--space-xs) !important;
}

.collection-count {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  font-weight: 400;
}

/* --- Section titles ------------------------------------------------------ */
.section-title,
.products-section h2.section-title {
  font-family: var(--font-heading) !important;
  font-size: 1.75rem !important;
  font-weight: 600 !important;
  color: var(--color-dark-sage) !important;
  text-align: center !important;
  margin-bottom: var(--space-sm) !important;
}

.section-subtitle,
.products-section .section-subtitle {
  text-align: center;
  color: var(--color-text-muted);
  font-size: 1rem;
  margin-bottom: var(--space-xl);
}

/* --- Products section ---------------------------------------------------- */
.products-section {
  margin: var(--space-2xl) 0;
}

/* --- WooCommerce Product Grid (Best Sellers shortcode output) ------------ */
/* Kill clearfix pseudo-elements that break CSS grid */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  display: none !important;
}

.woocommerce ul.products,
.woocommerce ul.products.columns-4,
.woocommerce-page ul.products,
.woocommerce-page ul.products.columns-4,
body.home ul.products {
  display: grid !important;
  gap: var(--space-xl) !important;
  padding: 0 !important;
  list-style: none;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

@media (min-width: 769px) {
  .woocommerce ul.products,
  .woocommerce ul.products.columns-4,
  .woocommerce-page ul.products,
  .woocommerce-page ul.products.columns-4,
  body.home ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--color-surface) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-sm) !important;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  padding: 0 !important;
  padding-bottom: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  float: none !important;
  text-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md) !important;
}

/* Product image */
.woocommerce ul.products li.product a img {
  width: 100% !important;
  height: 220px !important;
  object-fit: cover !important;
  display: block !important;
  margin: 0 !important;
  border-radius: 0 !important;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: var(--font-heading) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--color-dark-sage) !important;
  padding: var(--space-md) var(--space-md) var(--space-xs) !important;
  margin: 0 !important;
}

/* Product price */
.woocommerce ul.products li.product .price {
  font-family: var(--font-body) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--color-gold-dark) !important;
  padding: 0 var(--space-md) var(--space-sm) !important;
  margin: 0 !important;
}

/* ADD TO CART BUTTON — high visibility, prominent placement */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.ajax_add_to_cart {
  display: block !important;
  width: auto !important;
  max-width: calc(100% - 24px) !important;
  align-self: stretch !important;
  margin: 0 12px 12px !important;
  padding: 12px 16px !important;
  box-sizing: border-box !important;
  background-color: var(--color-sage) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  font-family: var(--font-body) !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background-color var(--transition-fast), transform var(--transition-fast) !important;
  position: static !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover,
.woocommerce ul.products li.product a.ajax_add_to_cart:hover {
  background-color: var(--color-gold) !important;
  color: var(--color-white) !important;
  transform: translateY(-1px);
}

/* "Added" state */
.woocommerce ul.products li.product a.added_to_cart {
  display: block !important;
  text-align: center;
  color: var(--color-sage-dark);
  font-size: 0.8rem;
  margin: var(--space-xs) var(--space-md) var(--space-sm);
}

/* --- Newsletter section fix ---------------------------------------------- */
.newsletter-section {
  background: linear-gradient(135deg, var(--color-blush-light) 0%, var(--color-blush) 100%) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-3xl) var(--space-2xl) !important;
  text-align: center !important;
  margin: var(--space-2xl) 0 !important;
}

.newsletter-section h2 {
  font-family: var(--font-heading) !important;
  color: var(--color-dark-sage) !important;
}

.newsletter-section p {
  color: var(--color-text-muted);
  max-width: 500px;
  margin: 0 auto var(--space-lg);
}

.newsletter-section .button,
.newsletter-section button {
  background-color: var(--color-sage) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  padding: 12px 32px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.newsletter-section .button:hover,
.newsletter-section button:hover {
  background-color: var(--color-sage-dark) !important;
}

/* --- Responsive fixes for new homepage layout ---------------------------- */
@media (max-width: 768px) {
  .collections-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-md) !important;
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-md) !important;
  }

  .hero-banner h1 {
    font-size: 1.5rem !important;
  }

  .hero-banner p {
    font-size: 0.95rem !important;
  }
}

@media (max-width: 480px) {
  .collections-grid {
    grid-template-columns: 1fr !important;
  }

  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* --- Footer 4-column layout fix ------------------------------------------ */
/* Storefront uses .footer-widgets > .block.footer-widget-N (4 direct children) */
/* Kill Storefront .fix clearfix pseudo-elements that become grid items */
.footer-widgets.fix::before,
.footer-widgets.fix::after {
  display: none !important;
}

.footer-widgets {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-xl) !important;
}

@media (min-width: 769px) {
  .footer-widgets {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

.footer-widgets > .block {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 var(--space-md) !important;
}

.footer-widgets .widget-title,
.footer-widgets .gamma.widget-title {
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--color-off-white) !important;
  margin-bottom: var(--space-md) !important;
  text-transform: none;
}

.footer-widgets .widget ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-widgets .widget ul li {
  margin-bottom: var(--space-xs);
}

.footer-widgets .widget ul li a {
  color: var(--color-sage-light) !important;
  text-decoration: none;
  font-size: 0.9rem;
  transition: color var(--transition-fast);
}

.footer-widgets .widget ul li a:hover {
  color: var(--color-white) !important;
}

@media (max-width: 768px) {
  .footer-widgets {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 480px) {
  .footer-widgets {
    grid-template-columns: 1fr !important;
  }
}

/* --- Cart button in header (top right) ----------------------------------- */
.site-header-cart {
  position: relative;
}

.site-header-cart .cart-contents {
  color: var(--color-dark-sage) !important;
  text-decoration: none !important;
  font-weight: 500;
}

.site-header-cart .count {
  background-color: var(--color-gold) !important;
  color: var(--color-white) !important;
  border-radius: 50%;
  font-size: 0.7rem;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  line-height: 18px;
  text-align: center;
  display: inline-block;
}

/* ===== SECTION 16: AUDIT FIXES (2026-03-09) ===== */

/* --- A11y: Focus visible outlines (WCAG 2.4.7) --- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--color-sage) !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 4px rgba(168, 181, 160, 0.3) !important;
}

/* --- Header: Cart badge — overridden by FIX 1 in Section 18 --- */

/* Hide "items" text in cart count, show only number */
.site-header-cart .amount {
  font-size: 0.85rem !important;
}

/* --- Header: Hide empty secondary navigation --- */
.secondary-navigation:empty,
.secondary-navigation nav:empty {
  display: none !important;
}

/* --- Cart badge: Hide when empty --- */
.site-header-cart .cart-contents .count[data-count="0"],
.site-header-cart .cart-contents span.count:empty {
  display: none !important;
}

/* --- Mobile: Touch targets minimum 44px (WCAG) --- */
@media (max-width: 768px) {
  /* Footer links */
  .site-footer a {
    display: block !important;
    padding: 10px 0 !important;
    min-height: 44px !important;
    line-height: 24px !important;
  }

  /* Menu toggle button */
  .menu-toggle {
    min-height: 44px !important;
    padding: 10px 16px !important;
  }

  /* Site title */
  .site-header .site-title a {
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
  }

  /* Navigation links */
  .main-navigation ul li a {
    padding: 12px 16px !important;
    min-height: 44px !important;
  }
}

/* --- Newsletter form styling --- */
.newsletter-form {
  max-width: 500px;
  margin: var(--space-lg) auto 0;
}

.newsletter-input-group {
  display: flex;
  gap: var(--space-sm);
  align-items: stretch;
}

.newsletter-email {
  flex: 1;
  padding: 14px 20px !important;
  border: 2px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: var(--radius-full) !important;
  background: rgba(255, 255, 255, 0.15) !important;
  color: white !important;
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
}

.newsletter-email::placeholder {
  color: rgba(255, 255, 255, 0.7) !important;
}

.newsletter-email:focus {
  border-color: white !important;
  background: rgba(255, 255, 255, 0.25) !important;
  outline: none !important;
}

.newsletter-btn {
  background: white !important;
  color: var(--color-dark-sage) !important;
  border: none !important;
  padding: 14px 28px !important;
  border-radius: var(--radius-full) !important;
  font-weight: 600 !important;
  font-family: var(--font-body) !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: all var(--transition-base) !important;
}

.newsletter-btn:hover {
  background: var(--color-gold) !important;
  color: white !important;
  transform: translateY(-1px) !important;
}

@media (max-width: 480px) {
  .newsletter-input-group {
    flex-direction: column;
  }

  .newsletter-btn {
    width: 100%;
  }
}

/* --- Collection images: aspect ratio for CLS prevention --- */
.collection-img {
  aspect-ratio: 3 / 2 !important;
  object-fit: cover !important;
}

/* --- Product heading fix: demote visual weight --- */
.woocommerce ul.products li.product h2 {
  font-size: 1rem !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
}

/* --- Duplicate H1 "Home" fix --- */
.home .entry-title,
body.page-id-65 .entry-title {
  display: none !important;
}

/* --- Coming soon page override (in case it returns) --- */
.woocommerce-coming-soon {
  display: none !important;
}

/* ===== SECTION 17: VIDEO AUDIT FIXES (2026-03-09) ===== */

/* ── P0: MOBILE PRODUCT GRID — force 1 col on small, 2 col on medium ── */
@media (max-width: 768px) {
  .woocommerce ul.products {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--space-lg) !important;
  }

  .woocommerce ul.products li.product {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
  }

  /* Add to Cart buttons: full width, horizontal text */
  .woocommerce ul.products li.product .button,
  .woocommerce ul.products li.product a.add_to_cart_button {
    width: 100% !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
    font-size: 0.9rem !important;
    padding: 12px 20px !important;
    letter-spacing: 0.05em !important;
  }

  /* Product titles: readable */
  .woocommerce ul.products li.product h2,
  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 1rem !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    line-height: 1.4 !important;
  }

  /* Prices: single line */
  .woocommerce ul.products li.product .price {
    font-size: 1.1rem !important;
    white-space: nowrap !important;
  }

  /* Product image: proper sizing */
  .woocommerce ul.products li.product img {
    width: 100% !important;
    height: auto !important;
    max-height: 300px !important;
    object-fit: contain !important;
  }
}

/* 2 columns for tablets (481-768px) */
@media (min-width: 481px) and (max-width: 768px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ── P1: HEADER CART — separate from nav links ── */
.site-header-cart {
  position: relative !important;
}

.site-header-cart .cart-contents {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
  padding: 8px 12px !important;
  border-radius: var(--radius-full) !important;
  transition: background var(--transition-base) !important;
}

.site-header-cart .cart-contents:hover {
  background: rgba(168, 181, 160, 0.1) !important;
}

/* Cart amount in nav */
.site-header-cart .cart-contents .amount {
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--color-dark-sage) !important;
}

/* ── P1: CATEGORY + CART PAGES — reduce excessive whitespace ── */
.tax-product_cat .page-header,
.post-type-archive-product .page-header,
.woocommerce-cart .entry-header {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.tax-product_cat .page-header + *,
.woocommerce-page .entry-content {
  margin-top: var(--space-lg) !important;
}

/* Reduce gap between breadcrumb and category title */
.woocommerce-breadcrumb {
  margin-bottom: var(--space-sm) !important;
}

.tax-product_cat .woocommerce-products-header,
.post-type-archive-product .woocommerce-products-header {
  margin-bottom: var(--space-lg) !important;
}

.tax-product_cat .woocommerce-products-header__title,
.post-type-archive-product .woocommerce-products-header__title {
  margin-top: var(--space-md) !important;
  margin-bottom: var(--space-sm) !important;
}

/* Cart page: reduce top spacing */
.woocommerce-cart .entry-title {
  margin-top: var(--space-md) !important;
  margin-bottom: var(--space-lg) !important;
}

/* ── P1: HIDE "dropship" and "affiliate" tags on product pages ── */
.tagged_as,
.product_meta .tagged_as {
  display: none !important;
}

/* ── P2: TRUST BAR MOBILE — compact single row ── */
@media (max-width: 768px) {
  .trust-bar__inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    gap: var(--space-sm) !important;
    padding: 8px var(--space-md) !important;
    scrollbar-width: none !important;
  }

  .trust-bar__inner::-webkit-scrollbar {
    display: none !important;
  }

  .trust-bar__item {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    font-size: 0.75rem !important;
    padding: 4px 0 !important;
  }

  .trust-bar__icon {
    width: 16px !important;
    height: 16px !important;
  }
}

/* ── P2: MOBILE COLLECTIONS — nice 2-column grid ── */
@media (max-width: 768px) {
  .collections-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-md) !important;
  }
}

@media (max-width: 400px) {
  .collections-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ── P1: CATEGORY PAGE MOBILE — proper product grid ── */
@media (max-width: 768px) {
  .woocommerce .products .product {
    width: 100% !important;
    float: none !important;
  }

  /* Category page: 1 column on small mobile */
  .tax-product_cat .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }
}

@media (min-width: 481px) and (max-width: 768px) {
  .tax-product_cat .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ── PRODUCT PAGE: Placeholder image styling ── */
.woocommerce div.product div.images img.wp-post-image[src*="placeholder"] {
  background: var(--color-surface) !important;
  border: 2px dashed var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-xl) !important;
}

/* ===== SECTION 18: SCREENSHOT AUDIT FIXES (2026-03-09) ===== */

/* --- FIX 1: Desktop cart — show count badge on cart icon --- */
/* The .count contains "2 items" — we clip to show only the number */
.site-header-cart .cart-contents {
  position: relative !important;
  overflow: visible !important;
}
.site-header-cart .count,
.site-header .site-header-cart .count {
  display: inline-block !important;
  visibility: visible !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--color-white) !important;
  background: var(--color-gold) !important;
  border-radius: 50% !important;
  width: 20px !important;
  height: 20px !important;
  line-height: 20px !important;
  text-align: center !important;
  text-indent: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  word-spacing: -9999px !important;  /* hide "items" text, show only number */
  vertical-align: middle !important;
  margin-left: 6px !important;
  position: relative !important;
  top: auto !important;
  right: auto !important;
  padding: 0 !important;
}
/* Reset pseudo-elements — no longer needed */
.site-header-cart .count::before,
.site-header .site-header-cart .count::before,
.site-header-cart .count::after,
.site-header .site-header-cart .count::after {
  content: none !important;
  display: none !important;
}

/* --- FIX 2: Shop page — massive whitespace reduction --- */
/* Storefront .storefront-breadcrumb has huge padding + margin */
.storefront-breadcrumb {
  padding: 8px 0 !important;
  margin-bottom: 0 !important;
}

.post-type-archive-product .site-main,
.tax-product_cat .site-main {
  padding-top: 0 !important;
}

.post-type-archive-product .woocommerce-products-header,
.tax-product_cat .woocommerce-products-header {
  margin: 0 0 var(--space-md) !important;
  padding: 0 !important;
}

.post-type-archive-product .woocommerce-products-header__title,
.tax-product_cat .woocommerce-products-header__title {
  font-size: 1.8rem !important;
  margin: var(--space-sm) 0 var(--space-xs) !important;
  padding: 0 !important;
}

/* Reduce gap between breadcrumb and page title */
.woocommerce-breadcrumb {
  margin-bottom: var(--space-xs) !important;
  padding-bottom: 0 !important;
}

/* Sorting bar + result count — tighten up */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  margin-bottom: var(--space-sm) !important;
}

/* Remove excess padding in content area */
.post-type-archive-product .content-area,
.tax-product_cat .content-area {
  padding-top: 0 !important;
}

.post-type-archive-product article.page,
.post-type-archive-product .hentry,
.tax-product_cat .hentry {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Top pagination: bring closer to products */
.woocommerce-pagination {
  margin: var(--space-sm) 0 var(--space-md) !important;
}

/* --- FIX 3: Related products — broken narrow columns --- */
/* Kill Storefront's grid on the section wrapper — only the UL should be a grid */
.single-product .related.products,
.single-product .upsells.products {
  display: block !important;
}

.single-product .related.products ul.products,
.single-product .upsells.products ul.products {
  display: grid !important;
  gap: var(--space-xl) !important;
  width: 100% !important;
}

@media (min-width: 769px) {
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

@media (max-width: 768px) {
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 480px) {
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products {
    grid-template-columns: 1fr !important;
  }
}

.single-product .related.products ul.products li.product,
.single-product .upsells.products ul.products li.product {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

/* Related product titles — prevent char-by-char break */
.single-product .related.products li.product h2,
.single-product .related.products li.product .woocommerce-loop-product__title,
.single-product .upsells.products li.product h2,
.single-product .upsells.products li.product .woocommerce-loop-product__title {
  font-size: 0.9rem !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: auto !important;
  line-height: 1.3 !important;
  min-height: auto !important;
}

/* Related products: reduce whitespace above */
.single-product .related.products,
.single-product .upsells.products {
  margin-top: var(--space-xl) !important;
  padding-top: var(--space-lg) !important;
}

/* =====================================================================
   FIX 4: MOBILE HEADER — [☰] [Baby Gift Shop] [🛒] single row
   Technique: .site-header = visible 56px sticky row (position:relative).
   .storefront-primary-navigation collapses to height:0 + overflow:visible.
   ☰ and 🛒 are position:absolute with top:-56px to overlay onto header.
   NO pointer-events:none anywhere — everything stays clickable.
   ===================================================================== */
@media (max-width: 768px) {

  /* --- 4a. SITE-HEADER — sticky 56px row --- */
  .site-header,
  #masthead {
    position: sticky !important;
    top: 0 !important;
    z-index: 9999 !important;
    height: 56px !important;
    min-height: 56px !important;
    max-height: 56px !important;
    overflow: visible !important;
    background: #fff !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: none !important;
  }

  .site-header > .col-full {
    position: relative !important;
    height: 56px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 auto !important;
    max-width: 100% !important;
  }

  /* --- 4b. LOGO — centered with padding for ☰ and 🛒 --- */
  .site-branding,
  .site-header .site-branding {
    width: 100% !important;
    text-align: center !important;
    padding: 0 56px !important;
    margin: 0 !important;
  }

  .site-branding .beta.site-title,
  .site-branding h1,
  .site-branding p.site-title,
  .site-header .site-title {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 1.15rem !important;
    line-height: 56px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .site-branding .site-description,
  .site-header .site-description {
    display: none !important;
  }

  .site-header .secondary-navigation {
    display: none !important;
  }

  /* --- 4b-search. SEARCH 🔍 — icon in header, dropdown bar below --- */
  /* Container: just the icon area, 44x44 in the header row */
  .site-header .site-search {
    display: block !important;
    position: absolute !important;
    top: 6px !important;
    left: 56px !important;
    width: 44px !important;
    height: 44px !important;
    z-index: 10001 !important;
    overflow: visible !important;
    background: transparent !important;
  }

  /* Kill Storefront's native Font Awesome loupe on the form */
  .site-header .site-search .woocommerce-product-search::before,
  .site-header .site-search .woocommerce-product-search::after {
    content: none !important;
    display: none !important;
  }

  /* Our SVG loupe icon */
  .site-header .site-search::before {
    content: "" !important;
    position: absolute !important;
    top: 10px !important;
    left: 10px !important;
    width: 24px !important;
    height: 24px !important;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232c3e2e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat center center !important;
    background-size: 20px 20px !important;
    z-index: 1 !important;
    pointer-events: none !important;
  }

  /* Intermediate wrappers: fill 44x44 icon area */
  .site-header .site-search .widget_product_search {
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    overflow: visible !important;
  }
  .site-header .site-search .woocommerce-product-search {
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
    overflow: visible !important;
  }

  /* Hide label + submit button */
  .site-header .site-search .widget_product_search label,
  .site-header .site-search .widget_product_search button[type="submit"] {
    display: none !important;
  }

  /* Search input — collapsed: transparent 44x44 clickable area over the icon */
  .site-header .site-search input[type="search"] {
    display: block !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    color: transparent !important;
    cursor: pointer !important;
    font-size: 16px !important;
    border-radius: var(--radius-pill) !important;
    -webkit-appearance: none !important;
    outline: none !important;
    box-shadow: none !important;
    position: relative !important;
    z-index: 2 !important;
  }
  .site-header .site-search input[type="search"]::placeholder {
    color: transparent !important;
  }

  /* Expanded: search bar drops BELOW the header as a full-width strip */
  .site-header .site-search:focus-within .woocommerce-product-search {
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    width: 100vw !important;
    height: 52px !important;
    background: var(--color-white) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
    border-bottom: 2px solid var(--color-sage) !important;
    padding: 6px 12px !important;
    box-sizing: border-box !important;
    z-index: 10002 !important;
    display: flex !important;
    align-items: center !important;
  }

  .site-header .site-search:focus-within input[type="search"] {
    width: 100% !important;
    height: 40px !important;
    padding: 8px 16px !important;
    color: var(--color-dark-sage) !important;
    background: var(--color-cream, #f9f6f1) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-pill) !important;
    cursor: text !important;
    font-size: 16px !important;
  }
  .site-header .site-search:focus-within input[type="search"]::placeholder {
    color: var(--color-text-muted) !important;
  }
  /* Hide the icon when search is expanded */
  .site-header .site-search:focus-within::before {
    display: none !important;
  }

  /* --- 4c. NAV BAR — collapse to height:0, overflow:visible --- */
  .storefront-primary-navigation {
    position: relative !important;
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    overflow: visible !important;
    background: transparent !important;
    z-index: 10000 !important;
    box-shadow: none !important;
  }

  .storefront-primary-navigation > .col-full {
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    position: static !important;
    max-width: 100% !important;
  }

  .storefront-primary-navigation .main-navigation,
  .storefront-primary-navigation nav.main-navigation,
  .storefront-primary-navigation #site-navigation,
  nav#site-navigation.main-navigation {
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    position: static !important;
    background: transparent !important;
    background-color: transparent !important;
    clear: none !important;
    border: none !important;
    box-shadow: none !important;
  }

  /* --- 4d. HAMBURGER ☰ — absolute, top-left of header row --- */
  .storefront-primary-navigation .menu-toggle,
  .storefront-primary-navigation button.menu-toggle,
  #site-navigation-menu-toggle {
    position: absolute !important;
    top: -56px !important;
    left: 8px !important;
    width: 44px !important;
    height: 44px !important;
    margin: 6px 0 0 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    z-index: 10001 !important;
    pointer-events: auto !important;
    -webkit-tap-highlight-color: transparent !important;
    outline: none !important;
    color: var(--color-dark-sage) !important;
    font-size: 0 !important;
    min-width: 44px !important;
    border-radius: var(--radius-sm) !important;
  }

  /* Kill Storefront's built-in ::before/::after hamburger lines */
  .storefront-primary-navigation .menu-toggle::before,
  .storefront-primary-navigation .menu-toggle::after,
  #site-navigation-menu-toggle::before,
  #site-navigation-menu-toggle::after {
    display: none !important;
    content: none !important;
  }

  /* Hide "Menu" text, show hamburger via SVG background on span */
  .storefront-primary-navigation .menu-toggle span,
  #site-navigation-menu-toggle span {
    font-size: 0 !important;
    color: transparent !important;
    display: block !important;
    width: 44px !important;
    height: 44px !important;
    position: relative !important;
    /* SVG hamburger — 3 horizontal lines, color #2c3e2e */
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232c3e2e' stroke-width='2' stroke-linecap='round'%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cline x1='3' y1='12' x2='21' y2='12'/%3E%3Cline x1='3' y1='18' x2='21' y2='18'/%3E%3C/svg%3E") no-repeat center center !important;
    background-size: 22px 22px !important;
  }

  /* Kill any ::before content from icon fonts */
  .storefront-primary-navigation .menu-toggle span::before,
  #site-navigation-menu-toggle span::before {
    content: none !important;
    display: none !important;
  }

  .storefront-primary-navigation .menu-toggle:hover,
  .storefront-primary-navigation .menu-toggle:focus {
    background: rgba(168,181,160,0.15) !important;
    outline: none !important;
  }

  /* --- 4e. CART 🛒 — absolute, top-right of header row --- */
  /* Hide .site-header's own cart (we use the nav duplicate) */
  .site-header .site-header-cart {
    display: none !important;
  }

  #site-header-cart,
  .storefront-primary-navigation ul.site-header-cart {
    position: absolute !important;
    top: -56px !important;
    right: 8px !important;
    left: auto !important;
    width: 44px !important;
    height: 44px !important;
    margin: 6px 0 0 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    list-style: none !important;
    z-index: 10001 !important;
    pointer-events: auto !important;
    overflow: visible !important;
    background: transparent !important;
    float: none !important;
  }

  #site-header-cart > li:first-child {
    display: block !important;
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    position: relative !important;
  }

  /* Hide mini-cart dropdown li */
  #site-header-cart > li:nth-child(2) {
    display: none !important;
  }

  #site-header-cart .cart-contents {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    margin: 0 !important;
    text-decoration: none !important;
    color: var(--color-dark-sage) !important;
    font-size: 0 !important;
    position: relative !important;
  }

  /* Hide price text */
  #site-header-cart .cart-contents .woocommerce-Price-amount,
  #site-header-cart .cart-contents .woocommerce-Price-currencySymbol {
    display: none !important;
  }

  /* Cart icon via SVG background (emoji breaks with icon fonts) */
  #site-header-cart .cart-contents::before {
    content: "" !important;
    display: block !important;
    width: 24px !important;
    height: 24px !important;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232c3e2e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E") no-repeat center center !important;
    background-size: 22px 22px !important;
    pointer-events: none !important;
  }

  /* Cart count badge — mobile: gold circle with number, top-right of cart icon */
  #site-header-cart .cart-contents .count,
  .storefront-primary-navigation .site-header-cart .cart-contents .count {
    visibility: visible !important;
    font-size: 10px !important;
    background: var(--color-gold) !important;
    color: var(--color-white) !important;
    font-weight: 700 !important;
    border-radius: 50% !important;
    width: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    height: 18px !important;
    line-height: 18px !important;
    text-align: center !important;
    padding: 0 !important;
    position: absolute !important;
    top: -2px !important;
    right: -4px !important;
    display: block !important;
    z-index: 1 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    word-spacing: -9999px !important;  /* hide "items", show only number */
    text-indent: 0 !important;
  }
  /* Reset pseudo-elements for mobile */
  #site-header-cart .cart-contents .count::before,
  #site-header-cart .cart-contents .count::after {
    content: none !important;
    display: none !important;
  }

  /* --- 4f. NAV DROPDOWN — opens below header when toggled --- */
  .storefront-primary-navigation .primary-navigation {
    display: none !important;
  }

  .storefront-primary-navigation .handheld-navigation {
    display: none !important;
  }

  .main-navigation.toggled .handheld-navigation {
    display: block !important;
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-height: calc(100vh - 56px) !important;
    overflow-y: auto !important;
    background: var(--color-sage) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    z-index: 9998 !important;
    padding: 0 !important;
    margin: 0 !important;
    border-top: 1px solid rgba(255,255,255,0.1) !important;
  }

  .main-navigation.toggled .handheld-navigation ul.menu {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
  }

  .main-navigation.toggled .handheld-navigation ul.menu li {
    border-bottom: 1px solid rgba(255,255,255,0.1) !important;
    margin: 0 !important;
  }

  .main-navigation.toggled .handheld-navigation ul.menu li a {
    display: block !important;
    padding: 14px 20px !important;
    color: var(--color-white) !important;
    text-decoration: none !important;
    font-size: 15px !important;
    text-align: center !important;
  }

  .main-navigation.toggled .handheld-navigation ul.menu li a:active,
  .main-navigation.toggled .handheld-navigation ul.menu li a:hover {
    background: rgba(255,255,255,0.1) !important;
  }
}

/* --- FIX 5: TRUST BAR MOBILE — centered 2×2 grid, clean look --- */
@media (max-width: 768px) {
  .trust-bar__inner {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px 16px !important;
    padding: 12px 20px !important;
    flex-wrap: unset !important;
    overflow-x: visible !important;
    justify-items: center !important;
    max-width: 360px !important;
    margin: 0 auto !important;
  }

  .trust-bar__item {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    font-size: 0.72rem !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    padding: 4px 0 !important;
    color: var(--color-dark-sage) !important;
  }

  .trust-bar__icon svg {
    width: 16px !important;
    height: 16px !important;
    flex-shrink: 0 !important;
    opacity: 0.7 !important;
  }
}

/* --- FIX 6: Search bar in header — proper sizing --- */
.site-header .widget_product_search,
.site-header .site-search {
  max-width: 300px !important;
}

.site-header .widget_product_search input[type="search"],
.site-header .site-search input[type="search"] {
  width: 100% !important;
  max-width: 300px !important;
  height: 40px !important;
  font-size: 0.85rem !important;
}

@media (max-width: 768px) {
  .site-header .widget_product_search,
  .site-header .site-search {
    max-width: 100% !important;
  }

  .site-header .widget_product_search input[type="search"],
  .site-header .site-search input[type="search"] {
    max-width: 100% !important;
  }
}

/* =====================================================================
   FIX 6b: MOBILE — Breadcrumb responsive, prevent overflow
   ===================================================================== */
@media (max-width: 768px) {
  .storefront-breadcrumb,
  .woocommerce-breadcrumb,
  .storefront-breadcrumb .col-full {
    padding-left: var(--space-sm) !important;
    padding-right: var(--space-sm) !important;
    box-sizing: border-box !important;
    max-width: 100% !important;
    overflow-wrap: break-word !important;
    word-wrap: break-word !important;
  }
  .woocommerce-breadcrumb {
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
  }
}

/* =====================================================================
   FIX 7: MOBILE — Single product page, full-width images, no side gaps
   ===================================================================== */
@media (max-width: 768px) {

  /* 7a. Single product page — remove padding/radius for full-width feel */
  .single-product .product {
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: var(--color-white) !important;
  }

  /* 7b. Product gallery — full width, no border-radius */
  .single-product .product .woocommerce-product-gallery,
  .single-product .woocommerce-product-gallery {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }

  .single-product .product .woocommerce-product-gallery img,
  .single-product .woocommerce-product-gallery img,
  .single-product .woocommerce-product-gallery .woocommerce-product-gallery__image img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    border-radius: 0 !important;
    display: block !important;
    margin: 0 !important;
  }

  /* 7c. Product info below image — add padding back */
  .single-product .product .summary,
  .single-product .product .entry-summary {
    padding: var(--space-md) var(--space-md) 0 !important;
    width: 100% !important;
  }

  .single-product .product .product_title {
    font-size: 1.4rem !important;
  }

  .single-product .product .price {
    font-size: 1.3rem !important;
  }

  /* 7d. Single product Add to Cart button — full width */
  .single-product .product .single_add_to_cart_button,
  .single-product .product button.single_add_to_cart_button {
    width: 100% !important;
    max-width: none !important;
    margin: var(--space-sm) 0 !important;
    padding: 14px 20px !important;
    font-size: 1rem !important;
    box-sizing: border-box !important;
  }

  /* 7e. Product tabs — full width, no side gaps */
  .single-product .woocommerce-tabs {
    padding: 0 var(--space-md) !important;
    margin-top: var(--space-lg) !important;
  }

  /* 7f. Related/upsell products — full width container */
  .single-product .related.products,
  .single-product .upsells.products {
    padding: 0 var(--space-md) !important;
    margin: var(--space-lg) 0 !important;
  }

  /* 7g. col-full containers — no excess side padding/margin */
  .single-product .col-full {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  /* 7h. Page content wrapper — kill side padding for full bleed */
  .single-product .site-main,
  .single-product #primary,
  .single-product .site-content,
  .single-product .content-area {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* 7i. entry-content inside single product — no side padding */
  .single-product .entry-content {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* =====================================================================
   FIX 8: MOBILE — Homepage content area, full-bleed sections
   ===================================================================== */
@media (max-width: 768px) {

  /* 8a. Main content — reduce excess side padding */
  .home .entry-content,
  .home .page-content,
  .home .site-main .col-full {
    padding-left: var(--space-sm) !important;
    padding-right: var(--space-sm) !important;
  }

  /* 8b. Product grid on homepage — smaller gap, full width */
  .home .woocommerce ul.products,
  .home ul.products {
    gap: var(--space-sm) !important;
    padding: 0 !important;
  }

  /* 8c. Prevent horizontal overflow on entire page */
  html, body {
    overflow-x: hidden !important;
  }

  .col-full {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* === PRODUCT GALLERY THUMBNAILS FIX (2026-03-11) === */
.woocommerce-product-gallery .flex-control-thumbs {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 10px 0 !important;
    list-style: none !important;
}
.woocommerce-product-gallery .flex-control-thumbs li {
    flex: 0 0 auto !important;
    width: 60px !important;
    height: 60px !important;
    margin: 0 !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    border: 2px solid transparent !important;
    transition: border-color 0.2s ease !important;
}
.woocommerce-product-gallery .flex-control-thumbs li img {
    border-radius: 6px !important;
    object-fit: cover !important;
    width: 100% !important;
    height: 100% !important;
    cursor: pointer !important;
}
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active,
.woocommerce-product-gallery .flex-control-thumbs li:hover img {
    border-color: #A8B5A0 !important;
}
.woocommerce-product-gallery .flex-control-thumbs li:hover {
    border-color: #A8B5A0 !important;
}

@media (max-width: 768px) {
    .woocommerce-product-gallery .flex-control-thumbs {
        justify-content: center !important;
    }
    .woocommerce-product-gallery .flex-control-thumbs li {
        width: 50px !important;
        height: 50px !important;
    }
    .woocommerce div.product div.images {
        margin-bottom: 1em !important;
    }
}
/* ==========================================================================
   VARIATION SWATCHES — Color & Size buttons (2026-03-12)
   Replaces default WooCommerce <select> dropdowns with styled buttons.
   ========================================================================== */

/* Hide the original select when swatches are active */
select.bg-swatch-hidden {
  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;
  border: 0 !important;
}

/* Swatch button wrapper */
.bg-swatch-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 4px 0;
  align-items: center;
}

/* Base button style */
.bg-swatch-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border: 2px solid var(--color-border, #ddd5ce);
  border-radius: var(--radius-pill, 50px);
  background: var(--color-surface, #FAFAF7);
  color: var(--color-text, #2C3E2E);
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  line-height: 1.2;
  white-space: nowrap;
  box-shadow: 0 1px 3px rgba(44, 62, 46, 0.04);
  -webkit-appearance: none;
  appearance: none;
  outline: none;
}

.bg-swatch-btn:hover {
  border-color: var(--color-sage, #A8B5A0);
  background: #f0efe9;
  box-shadow: 0 2px 6px rgba(44, 62, 46, 0.08);
}

.bg-swatch-btn:focus-visible {
  border-color: var(--color-sage, #A8B5A0);
  box-shadow: 0 0 0 3px rgba(168, 181, 160, 0.3);
}

.bg-swatch-btn.active {
  border-color: var(--color-sage-dark, #8a9b80);
  background: var(--color-sage, #A8B5A0);
  color: #fff;
  box-shadow: 0 2px 8px rgba(138, 155, 128, 0.25);
}

.bg-swatch-btn.active:hover {
  background: var(--color-sage-dark, #8a9b80);
  border-color: var(--color-sage-dark, #8a9b80);
}

/* --- Color swatch specifics --- */
.bg-swatch-color {
  padding: 7px 16px;
}

.bg-swatch-dot {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.bg-swatch-btn.active .bg-swatch-dot {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}

/* --- Size swatch specifics --- */
.bg-swatch-size {
  min-width: 52px;
  justify-content: center;
  padding: 8px 14px;
  border-radius: var(--radius-md, 12px);
  font-size: 0.8rem;
  letter-spacing: 0.02em;
}

/* --- Generic swatch (fallback) --- */
.bg-swatch-generic {
  padding: 8px 16px;
}

/* --- Variation table adjustments --- */
table.variations td.label {
  vertical-align: top !important;
  padding-top: 12px !important;
}

table.variations td.label label {
  font-family: var(--font-body, 'Inter', sans-serif);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted, #5a6e5c);
}

table.variations td.value {
  padding: 6px 0 !important;
}

/* Clear link styling */
.reset_variations {
  display: inline-block;
  margin-top: 8px;
  font-size: 0.8rem;
  color: var(--color-text-muted, #5a6e5c) !important;
  text-decoration: underline;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}

.reset_variations:hover {
  opacity: 1;
  color: var(--color-sage-dark, #8a9b80) !important;
}

/* --- Mobile adjustments --- */
@media (max-width: 768px) {
  .bg-swatch-buttons {
    gap: 8px;
  }

  .bg-swatch-btn {
    padding: 7px 14px;
    font-size: 0.8rem;
  }

  .bg-swatch-size {
    min-width: 46px;
    padding: 7px 12px;
    font-size: 0.75rem;
  }

  .bg-swatch-dot {
    width: 14px;
    height: 14px;
  }
}


/* ==========================================================================
   Product Page UX Improvements (2026-03-12)
   - Centered attributes, quantity +/- selector, full-width CTA, better spacing
   ========================================================================== */

/* --- Variation selector container: centered, grouped in subtle card --- */
.single-product .variations_form .variations {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.single-product .variations_form .variations tr {
  display: block;
  text-align: center;
  margin-bottom: var(--space-lg);
}

.single-product .variations_form .variations tr:last-child {
  margin-bottom: 0;
}

.single-product .variations_form .variations td.label,
.single-product .variations_form .variations td.value {
  display: block !important;
  text-align: center !important;
  padding: 0 !important;
  width: 100% !important;
}

.single-product .variations_form .variations td.label {
  padding-bottom: 6px !important;
}

.single-product .variations_form .variations td.label label {
  display: block;
  text-align: center;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted, #5a6e5c);
  margin-bottom: 4px;
}

/* Center the swatch buttons */
.single-product .bg-swatch-buttons {
  justify-content: center !important;
  padding: 4px 0 8px;
}

/* Variation form wrapper: subtle card feel */
.single-product .variations_form {
  background: var(--color-off-white, #FAFAF7);
  border: 1px solid var(--color-border, #ddd5ce);
  border-radius: var(--radius-md, 12px);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-lg) 0 var(--space-xl);
}

/* --- Active swatch: more prominent --- */
.single-product .bg-swatch-btn.active {
  border-color: var(--color-sage-dark, #8a9b80);
  background: var(--color-sage, #A8B5A0);
  color: #fff;
  box-shadow: 0 2px 8px rgba(138, 155, 128, 0.3), 0 0 0 2px rgba(168, 181, 160, 0.15);
  transform: scale(1.03);
}

/* --- Clear / Reset link: subtle --- */
.single-product .reset_variations {
  display: block !important;
  text-align: center;
  margin-top: 10px !important;
  font-size: 0.72rem !important;
  color: var(--color-text-muted, #8B8578) !important;
  opacity: 0.6;
  text-decoration: none;
  letter-spacing: 0.03em;
  text-transform: lowercase;
}

.single-product .reset_variations:hover {
  opacity: 1;
  color: var(--color-sage-dark, #7A8C6E) !important;
}

/* --- Quantity selector with +/- buttons (pill shape) --- */
.single-product .quantity-wrapper {
  display: inline-flex;
  align-items: center;
  border: 2px solid var(--color-border, #D4CFC5);
  border-radius: var(--radius-pill, 50px);
  background: var(--color-off-white, #F5F3EE);
  overflow: hidden;
  height: 48px;
  margin: 0 auto;
}

.single-product .quantity-wrapper .qty-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 100%;
  border: none;
  background: transparent;
  color: var(--color-text, #3D3D3D);
  font-size: 1.2rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  line-height: 1;
  padding: 0;
}

.single-product .quantity-wrapper .qty-btn:hover {
  background: var(--color-sage-light, #c3ccbc);
  color: var(--color-dark-sage, #2C3E2E);
}

.single-product .quantity-wrapper .qty-btn:active {
  background: var(--color-sage, #A8B5A0);
  color: #fff;
}

.single-product .quantity-wrapper .qty-btn.disabled,
.single-product .quantity-wrapper .qty-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.single-product .quantity-wrapper .qty-btn.disabled:hover {
  background: transparent;
}

.single-product .quantity-wrapper .qty {
  width: 48px !important;
  height: 100%;
  border: none !important;
  border-left: 1px solid var(--color-border, #D4CFC5) !important;
  border-right: 1px solid var(--color-border, #D4CFC5) !important;
  border-radius: 0 !important;
  background: transparent !important;
  text-align: center;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text, #3D3D3D);
  padding: 0;
  -moz-appearance: textfield;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  box-shadow: none !important;
}

.single-product .quantity-wrapper .qty::-webkit-inner-spin-button,
.single-product .quantity-wrapper .qty::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* --- Quantity + Add-to-cart row: stacked centered layout --- */
.single-product .variations_form .woocommerce-variation-add-to-cart,
.single-product form.cart:not(.variations_form) {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--color-border, #ddd5ce);
}

/* --- Price display: prominent near CTA --- */
.single-product .woocommerce-variation-price {
  text-align: center;
  margin-bottom: var(--space-sm);
}

.single-product .woocommerce-variation-price .price {
  font-size: 1.6rem !important;
  font-weight: 700;
  color: var(--color-dark-sage, #2C3E2E);
}

/* --- Stock status indicator --- */
.single-product .stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 500;
  padding: 4px 14px;
  border-radius: var(--radius-pill, 50px);
  margin-bottom: var(--space-sm);
}

.single-product .stock.in-stock {
  background: rgba(168, 181, 160, 0.15);
  color: var(--color-sage-dark, #7A8C6E);
}

.single-product .stock.in-stock::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-sage, #A8B5A0);
  display: inline-block;
}

.single-product .stock.out-of-stock {
  background: rgba(217, 136, 128, 0.15);
  color: #b85c52;
}

.single-product .stock.out-of-stock::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #D98880;
  display: inline-block;
}

/* --- Add to cart button: full-width, warm CTA --- */
.single-product .single_add_to_cart_button {
  width: 100% !important;
  max-width: 420px;
  display: block !important;
  background: var(--color-gold, #D4A574) !important;
  border: 2px solid var(--color-gold, #D4A574) !important;
  color: #fff !important;
  font-family: var(--font-body);
  font-size: 1rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 16px 32px !important;
  border-radius: var(--radius-pill, 50px) !important;
  cursor: pointer;
  transition: all 0.25s ease;
  box-shadow: 0 4px 14px rgba(212, 165, 116, 0.3);
  text-align: center;
}

.single-product .single_add_to_cart_button:hover {
  background: var(--color-gold-dark, #b88a5a) !important;
  border-color: var(--color-gold-dark, #b88a5a) !important;
  box-shadow: 0 6px 20px rgba(184, 138, 90, 0.35);
  transform: translateY(-1px);
}

.single-product .single_add_to_cart_button:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(184, 138, 90, 0.25);
}

/* --- Variation description: centered --- */
.single-product .woocommerce-variation-description {
  text-align: center;
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

/* --- Mobile responsive --- */
@media (max-width: 768px) {
  .single-product .variations_form {
    padding: var(--space-md) var(--space-md);
    margin: var(--space-md) 0 var(--space-lg);
  }

  .single-product .quantity-wrapper {
    height: 44px;
  }

  .single-product .quantity-wrapper .qty-btn {
    width: 40px;
    font-size: 1.1rem;
  }

  .single-product .quantity-wrapper .qty {
    width: 42px !important;
    font-size: 0.95rem;
  }

  .single-product .single_add_to_cart_button {
    max-width: 100%;
    padding: 14px 24px !important;
    font-size: 0.95rem !important;
  }

  .single-product .woocommerce-variation-price .price {
    font-size: 1.4rem !important;
  }
}

@media (max-width: 480px) {
  .single-product .variations_form .variations tr {
    margin-bottom: var(--space-md);
  }

  .single-product .quantity-wrapper .qty-btn {
    width: 36px;
  }

  .single-product .quantity-wrapper .qty {
    width: 38px !important;
  }
}


/* === AFFILIATE MODEL OVERRIDES === */
/* Hide cart icon in header */
.site-header-cart,
.storefront-handheld-footer-bar .cart,
a.cart-contents {
  display: none !important;
}

/* Hide quantity selector on product pages (external products) */
.single-product .quantity {
  display: none !important;
}

/* Style the Buy on Amazon button */
.product_type_external,
.single_add_to_cart_button {
  background-color: #FF9900 !important;
  color: #000 !important;
  font-weight: 600 !important;
  border: none !important;
}
.product_type_external:hover,
.single_add_to_cart_button:hover {
  background-color: #e88e00 !important;
}

/* === AFFILIATE MODE CSS (2026-03-19) === */

/* Hide cart icon in header completely */
.site-header-cart,
.woocommerce-cart-form,
.cart-contents,
a.cart-contents,
.widget_shopping_cart,
li.woocommerce-mini-cart,
.mini-cart,
.cart-collaterals,
.woocommerce-shipping-calculator,
.header-cart,
.site-header .cart { 
    display: none !important; 
}

/* Hide quantity selectors */
.quantity,
input.qty,
.woocommerce-grouped-product-list-item__quantity { 
    display: none !important; 
}

/* Style affiliate buttons on shop/archive pages */
a.product_type_external,
.product_type_external {
    background: #FF9900 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 10px 20px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    transition: background 0.3s !important;
}

a.product_type_external:hover,
.product_type_external:hover {
    background: #e68a00 !important;
    color: #fff !important;
}

/* Style single product affiliate button */
.single-product .single_add_to_cart_button,
.single-product button.single_add_to_cart_button {
    background: #FF9900 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 30px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    width: 100% !important;
    text-align: center !important;
}

.single-product .single_add_to_cart_button:hover {
    background: #e68a00 !important;
}

/* Recommended badge */
.affiliate-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--color-gold, #D4A574);
    color: #fff;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    z-index: 2;
}

/* Make product cards look more like review/recommendation cards */
ul.products li.product {
    position: relative;
    border: 1px solid #ebe6e0;
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow 0.3s, transform 0.2s;
}

ul.products li.product:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    transform: translateY(-3px);
}

/* Hide sale badge / on-sale flash */
.onsale,
span.onsale,
.woocommerce span.onsale {
    display: none !important;
}

/* Hide checkout and cart links everywhere */
a[href*='cart'],
a[href*='checkout'],
a[href*='panier'],
.woocommerce-error a.button.wc-forward,
.woocommerce-message a.button.wc-forward {
    display: none !important;
}

/* Hide WooCommerce notices about cart */
.woocommerce-message,
.woocommerce-info {
    display: none !important;
}

/* Remove price strikethrough (sale price) - keeps regular price visible */
del,
.price del {
    display: none !important;
}

/* Amazon-style star rating look */
.star-rating {
    color: #FF9900 !important;
}

/* === AFFILIATE DEEP CLEANUP v2 (2026-03-19) === */

/* Kill ALL cart references everywhere */
.site-header-cart,
.site-header-cart *,
.cart-contents,
a.cart-contents,
.footer-cart-contents,
a.footer-cart-contents,
.widget_shopping_cart,
.widget_shopping_cart_content,
.woocommerce-mini-cart,
.woocommerce-mini-cart__empty-message,
li.site-header-cart,
.cart-collaterals,
.wc-proceed-to-checkout,
.checkout-button,
.widget_price_filter,
.price_slider_wrapper { 
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    left: -9999px !important;
}

/* Hide WooCommerce ordering/sorting and result count */
.woocommerce-ordering,
.woocommerce-result-count,
form.woocommerce-ordering { 
    display: none !important; 
}

/* Hide sidebar on shop/category pages */
.woocommerce-page .widget-area,
.woocommerce-page #secondary,
.woocommerce-page aside { 
    display: none !important; 
}

/* Make shop page full-width without sidebar */
.woocommerce-page .content-area,
.woocommerce-page #primary { 
    width: 100% !important; 
    float: none !important; 
}

/* Style products as recommendation cards */
ul.products li.product {
    position: relative;
    border: 1px solid #ebe6e0;
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow 0.3s, transform 0.2s;
    padding-bottom: 15px;
}

ul.products li.product:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    transform: translateY(-3px);
}

/* Affiliate badge styling */
.affiliate-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: linear-gradient(135deg, #D4A574, #b88a5a);
    color: #fff;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    z-index: 2;
    box-shadow: 0 2px 8px rgba(212,165,116,0.3);
}

/* Amazon button on product cards */
a.button.product_type_external {
    background: linear-gradient(180deg, #FFB347, #FF9900) !important;
    color: #111 !important;
    border: 1px solid #e68a00 !important;
    border-radius: 20px !important;
    padding: 10px 24px !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 10px 15px !important;
    display: block !important;
    text-align: center !important;
    transition: all 0.2s !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1) !important;
}

a.button.product_type_external:hover {
    background: linear-gradient(180deg, #FFC266, #FFB347) !important;
    box-shadow: 0 4px 12px rgba(255,153,0,0.3) !important;
    transform: translateY(-1px) !important;
}

/* Single product page - Amazon button */
.single-product .single_add_to_cart_button {
    background: linear-gradient(180deg, #FFB347, #FF9900) !important;
    color: #111 !important;
    border: 1px solid #e68a00 !important;
    border-radius: 25px !important;
    padding: 16px 40px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    width: 100% !important;
    cursor: pointer !important;
    box-shadow: 0 3px 10px rgba(255,153,0,0.3) !important;
}

/* Price styling - make it look like from on Amazon */
.price {
    color: #b12704 !important;
    font-weight: 600 !important;
}

.price::before {
    content: 'From ';
    font-weight: 400;
    color: #5a6e5c;
    font-size: 0.85em;
}

/* Star ratings - Amazon orange */
.star-rating span::before,
.star-rating::before {
    color: #FF9900 !important;
}

/* Product title on cards */
.woocommerce-loop-product__title {
    font-family: var(--font-heading) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    padding: 0 15px !important;
}

/* Affiliate intro section */
.affiliate-intro {
    text-align: center;
}

/* Category cards look like curated collections */
.product-category a {
    border-radius: 12px;
    overflow: hidden;
}

/* === SELECTIVE BADGE VARIANTS (2026-03-22) === */
.badge-editor {
    background: linear-gradient(135deg, #D4A574, #b88a5a) !important;
}
.badge-premium {
    background: linear-gradient(135deg, #2C3E2E, #3d5340) !important;
}
.badge-value {
    background: linear-gradient(135deg, #FF9900, #e68a00) !important;
}

/* Editorial product description styling */
.product-editorial h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    color: #2C3E2E;
    margin-bottom: 12px;
}
.product-editorial p {
    color: #5a6e5c;
    line-height: 1.7;
    font-size: 15px;
}
.product-specs {
    background: #f9f7f4;
    padding: 16px 20px;
    border-radius: 8px;
    margin: 16px 0;
}
.product-specs h4 {
    font-size: 0.95rem;
    color: #2C3E2E;
    margin-bottom: 8px;
}
.product-specs ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.product-specs ul li {
    padding: 4px 0 4px 20px;
    position: relative;
    color: #5a6e5c;
    font-size: 14px;
}
.product-specs ul li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    color: #D4A574;
    font-weight: bold;
}
.product-verdict {
    border-left: 4px solid #D4A574;
    padding: 12px 16px;
    margin-top: 16px;
    background: #faf8f5;
    border-radius: 0 8px 8px 0;
}
.product-verdict p {
    margin: 4px 0;
    font-size: 14px;
}

/* Sticky Amazon button on mobile (2026-03-22) */
@media (max-width: 768px) {
    .single-product .single_add_to_cart_button {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 9999 !important;
        border-radius: 0 !important;
        margin: 0 !important;
        padding: 18px !important;
        font-size: 18px !important;
    }
    .single-product .site-main { padding-bottom: 70px !important; }
}

/* === FIXES V3 (2026-03-23) === */

/* Fix 2: Hide duplicate Amazon button on product cards */
ul.products li.product a.button.product_type_external + a.button.product_type_external {
    display: none !important;
}

/* Fix 3: Hide duplicate Why We Recommend section */
.why-recommend + .why-recommend,
div[style*="border-left:4px solid #D4A574"] + div[style*="border-left:4px solid #D4A574"] {
    display: none !important;
}

/* Fix 8: Force hide strikethrough prices everywhere */
.price del,
del .woocommerce-Price-amount,
.price .woocommerce-Price-amount del,
ins .woocommerce-Price-amount + del,
span[class*="Original price"],
span[class*="Current price"] {
    display: none !important;
    visibility: hidden !important;
}

/* Only show the current/sale price */
.price ins {
    text-decoration: none !important;
}

/* Fix 10: Hide SKU */
.product_meta .sku_wrapper {
    display: none !important;
}

/* Latest Guides section styling */
.latest-guides article:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,0.08) !important;
    transform: translateY(-3px);
}

/* Blog page improvements */
.blog .hentry,
.archive .hentry {
    border: 1px solid #ebe6e0;
    border-radius: 12px;
    padding: 25px;
    margin-bottom: 25px;
    background: white;
    transition: box-shadow 0.3s;
}

.blog .hentry:hover,
.archive .hentry:hover {
    box-shadow: 0 5px 20px rgba(0,0,0,0.06);
}

.blog .entry-title,
.archive .entry-title {
    font-size: 22px !important;
}

.blog .entry-title a,
.archive .entry-title a {
    color: #2C3E2E !important;
    text-decoration: none !important;
}

.blog .entry-meta,
.archive .entry-meta {
    color: #999 !important;
    font-size: 13px !important;
}

/* Blog read more button */
.blog .more-link,
.archive .more-link {
    display: inline-block !important;
    padding: 8px 20px !important;
    background: var(--color-gold, #D4A574) !important;
    color: white !important;
    border-radius: 20px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    margin-top: 10px !important;
}

/* Product page - single description tab only */
.woocommerce-Tabs-panel h2:first-child {
    display: none !important;
}

/* Add Blog to navigation highlight */
.menu-item a[href*="/blog/"] {
    position: relative;
}

/* === BLOG-FIRST REDESIGN (2026-03-23) === */

/* Site disclosure banner */
.site-disclosure {
    font-family: var(--font-body);
    letter-spacing: 0.3px;
}

/* Blog page - article cards */
.blog .hentry,
.archive .hentry {
    display: grid;
    grid-template-columns: 250px 1fr;
    gap: 25px;
    border: 1px solid #ebe6e0;
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 25px;
    background: white;
    transition: box-shadow 0.3s;
    align-items: start;
}

.blog .hentry:hover,
.archive .hentry:hover {
    box-shadow: 0 5px 20px rgba(0,0,0,0.06);
}

@media (max-width: 768px) {
    .blog .hentry,
    .archive .hentry {
        grid-template-columns: 1fr;
    }
}

/* Blog post featured image */
.blog .post-thumbnail,
.archive .post-thumbnail {
    border-radius: 8px;
    overflow: hidden;
}

.blog .post-thumbnail img,
.archive .post-thumbnail img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 8px;
}

/* Article content on blog page */
.blog .entry-content,
.archive .entry-content {
    font-size: 14px;
    line-height: 1.7;
    color: #5a6e5c;
}

/* Article titles */
.blog .entry-title,
.archive .entry-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 20px !important;
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
}

.blog .entry-title a,
.archive .entry-title a {
    color: #2C3E2E !important;
    text-decoration: none !important;
}

.blog .entry-title a:hover,
.archive .entry-title a:hover {
    color: #D4A574 !important;
}

/* Author and date meta */
.blog .entry-meta,
.archive .entry-meta {
    font-size: 12px !important;
    color: #999 !important;
    margin-bottom: 10px !important;
}

/* Read more link */
.blog .more-link,
.archive .more-link {
    display: inline-block !important;
    padding: 8px 20px !important;
    background: #2C3E2E !important;
    color: white !important;
    border-radius: 20px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    margin-top: 10px !important;
}

.blog .more-link:hover {
    background: #3d5340 !important;
}

/* Single article page styling */
.single-post .entry-content {
    font-size: 17px;
    line-height: 1.8;
    color: #2C3E2E;
}

.single-post .entry-content h2 {
    font-family: 'Playfair Display', serif;
    color: #2C3E2E;
    margin-top: 40px;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 2px solid #ebe6e0;
}

.single-post .entry-content h3 {
    color: #2C3E2E;
    margin-top: 30px;
}

/* Top picks table styling */
.top-picks-table {
    overflow-x: auto;
}

.top-picks-table table {
    min-width: 600px;
}

.top-picks-table th {
    font-weight: 700;
    color: #2C3E2E;
    font-size: 14px;
}

.top-picks-table td {
    font-size: 14px;
    vertical-align: middle;
}

/* Pros/Cons grid */
.single-post .entry-content ul {
    padding-left: 20px;
}

.single-post .entry-content ul li {
    margin-bottom: 5px;
}

/* FAQ section */
.single-post .entry-content h3 + p {
    margin-bottom: 25px;
}

/* Amazon CTA buttons in articles */
.single-post a[href*=amazon.com] {
    background: linear-gradient(180deg, #FFB347, #FF9900);
    color: #111 !important;
    padding: 8px 18px;
    border-radius: 20px;
    text-decoration: none;
    font-weight: 700;
    font-size: 13px;
    display: inline-block;
    border: 1px solid #e68a00;
    transition: all 0.2s;
}

.single-post a[href*=amazon.com]:hover {
    background: linear-gradient(180deg, #FFC266, #FFB347);
    box-shadow: 0 3px 10px rgba(255,153,0,0.3);
}

/* Homepage sections */
.hero-section a:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.2);
}

.how-we-review-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.08);
}

/* Latest reviews cards on homepage */
.review-card {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #ebe6e0;
    transition: all 0.3s;
}

.review-card:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    transform: translateY(-3px);
}

/* Category badge on article cards */
.category-badge {
    display: inline-block;
    background: #D4A574;
    color: white;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Trust bar update - more subtle */
.trust-bar {
    background: #f9f7f4 !important;
    border-bottom: 1px solid #ebe6e0 !important;
}

/* Hide WooCommerce page title Gift Guide on shop page (we add our own) */
.woocommerce-products-header__title {
    font-family: 'Playfair Display', serif !important;
}


/* === BLOG LAYOUT FIX (2026-03-23 v2) === */

/* Blog page - remove sidebar, go full width */
.blog #primary,
.blog .content-area {
    width: 100% !important;
    float: none !important;
    max-width: 900px !important;
    margin: 0 auto !important;
}

.blog #secondary,
.blog .widget-area {
    display: none !important;
}

/* Blog page header */
.blog .page-header,
.blog .page-title {
    text-align: center !important;
    font-family: 'Playfair Display', serif !important;
    font-size: 2em !important;
    color: #2C3E2E !important;
    margin-bottom: 10px !important;
}

/* Blog article cards - horizontal layout */
.blog .hentry {
    display: flex !important;
    flex-direction: row !important;
    gap: 25px !important;
    border: 1px solid #ebe6e0 !important;
    border-radius: 12px !important;
    padding: 0 !important;
    margin-bottom: 30px !important;
    background: white !important;
    overflow: hidden !important;
    transition: box-shadow 0.3s, transform 0.2s !important;
}

.blog .hentry:hover {
    box-shadow: 0 8px 25px rgba(0,0,0,0.08) !important;
    transform: translateY(-2px) !important;
}

/* Blog post thumbnail */
.blog .hentry .post-thumbnail,
.blog .hentry .entry-thumbnail {
    flex: 0 0 280px !important;
    max-width: 280px !important;
}

.blog .hentry .post-thumbnail img,
.blog .hentry .entry-thumbnail img {
    width: 100% !important;
    height: 100% !important;
    min-height: 200px !important;
    object-fit: cover !important;
    border-radius: 12px 0 0 12px !important;
}

/* Blog post content area */
.blog .hentry .entry-content,
.blog .hentry .entry-header {
    padding: 20px 25px 5px !important;
}

.blog .hentry .entry-content {
    padding-top: 0 !important;
}

/* Blog entry title */
.blog .hentry .entry-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.4em !important;
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
}

.blog .hentry .entry-title a {
    color: #2C3E2E !important;
    text-decoration: none !important;
}

.blog .hentry .entry-title a:hover {
    color: #D4A574 !important;
}

/* Blog entry meta (author, date) */
.blog .hentry .entry-meta {
    font-size: 13px !important;
    color: #999 !important;
    margin-bottom: 10px !important;
}

/* Blog read more */
.blog .hentry .more-link {
    display: inline-block !important;
    padding: 8px 22px !important;
    background: #2C3E2E !important;
    color: white !important;
    border-radius: 20px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    margin: 15px 0 20px !important;
    transition: background 0.3s !important;
}

.blog .hentry .more-link:hover {
    background: #D4A574 !important;
}

/* Hide post comments count on blog listing */
.blog .post-comments {
    display: none !important;
}

/* Mobile: stack vertically */
@media (max-width: 768px) {
    .blog .hentry {
        flex-direction: column !important;
    }
    .blog .hentry .post-thumbnail,
    .blog .hentry .entry-thumbnail {
        flex: none !important;
        max-width: 100% !important;
    }
    .blog .hentry .post-thumbnail img,
    .blog .hentry .entry-thumbnail img {
        border-radius: 12px 12px 0 0 !important;
        height: 200px !important;
    }
    .blog #primary {
        padding: 0 15px !important;
    }
}

/* Single article - also full width, no sidebar */
.single-post #primary,
.single-post .content-area {
    width: 100% !important;
    float: none !important;
    max-width: 800px !important;
    margin: 0 auto !important;
}

.single-post #secondary,
.single-post .widget-area {
    display: none !important;
}

/* Single article - better typography */
.single-post .entry-title {
    font-family: 'Playfair Display', serif !important;
    font-size: 2.2em !important;
    color: #2C3E2E !important;
    line-height: 1.2 !important;
    margin-bottom: 15px !important;
}

.single-post .entry-meta {
    font-size: 14px !important;
    color: #999 !important;
    margin-bottom: 25px !important;
    padding-bottom: 20px !important;
    border-bottom: 1px solid #ebe6e0 !important;
}

/* Category pages - also full width */
.tax-product_cat #primary,
.tax-product_cat .content-area {
    width: 100% !important;
    float: none !important;
}

.tax-product_cat #secondary {
    display: none !important;
}


/* === BLOG CARD STRUCTURE FIX (2026-03-23 v3) === */

/* Hide duplicate entry-header on blog listing (we use entry-header-card inside entry-summary-wrap) */
.blog .hentry > .entry-header {
    display: none !important;
}

/* Entry summary wrap - takes remaining space in flex row */
.blog .hentry .entry-summary-wrap {
    flex: 1 1 0% !important;
    padding: 20px 25px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

/* Fix: ensure entry-content inside card doesn't get weird padding */
.blog .hentry .entry-summary-wrap .entry-content {
    padding: 0 !important;
}

/* Category badge */
.blog .blog-category-badge {
    display: inline-block !important;
}

/* Fix for hentry with no thumbnail - still looks good */
.blog .hentry:not(:has(.post-thumbnail)) .entry-summary-wrap {
    padding: 25px 30px !important;
}

@media (max-width: 768px) {
    .blog .hentry .entry-summary-wrap {
        padding: 15px 20px !important;
    }
}


/* === HIDE DUPLICATE CATEGORY/TAG TAXONOMY ON BLOG LISTING (2026-03-23 v4) === */
.blog .hentry > .entry-taxonomy,
.blog .hentry > footer.entry-meta,
.blog .cat-links,
.blog .tags-links {
    display: none !important;
}

/* Also hide edit links on blog listing */
.blog .hentry .edit-link {
    display: none !important;
}


/* =================
   PREMIUM LAYOUT FIRXCS (2026-03-30)
   ================== */

/* FIX 1: HOMEPAGE HERO full viewport width */
.home .site-content {
  max-width: 100% !important;
  padding: 0 !important;
}
.home .site-content > .col-full {
  max-width: 100% !important;
  padding: 0 !important;
}
.home .hero-section,
.home .hero-banner,
.home .collection-banner {
  max-width: 100% !important;
  width: 100% !important;
  border-radius: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.home .entry-content > *:not(.hero-section):not(.hero-banner):not(.collection-banner) {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-xl);
  padding-right: var(--space-xl);
  box-sizing: border-box;
}
.home .newsletter-section,
.home .home-newsletter {
  max-width: 100% !important;
  padding-left: var(--space-xl) !important;
  padding-right: var(--space-xl) !important;
}
/* FIX 2: HIDE SIDEBAR */
.home .widget-area,
.home #secondary,
.page .widget-area,
.page #secondary {
  display: none !important;
}
.home .content-area,
.home #primary,
.page .content-area,
.page #primary {
  width: 100% !important;
  float: none !important;
}

/* FIX 3: CENTERED LAYOUT */
.site-content {
  margin-left: auto !important;
  margin-right: auto !important;
}
.content-area {
  width: 100% !important;
  float: none !important;
}
/* FIX 4: PRODUCT GRID 4 columns */
.woocommerce .site-main ul.products,
.storefront-sorting .woocommerce ul.products,
.woocommerce-page ul.products,
.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: var(--space-lg) !important;
  max-width: 100% !important;
}
@media (max-width: 1024px) {
  .woocommerce .site-main ul.products,
  .storefront-sorting .woocommerce ul.products,
  .woocommerce-page ul.products,
  .products,
  ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .woocommerce .site-main ul.products,
  .storefront-sorting .woocommerce ul.products,
  .woocommerce-page ul.products,
  .products,
  ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-sm) !important;
  }
}
/* FIX 5: PRODUCT CARDS premium */
ul.products li.product,
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--color-white) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-sm) !important;
  transition: transform var(--transition-base), box-shadow var(--transition-base) !important;
  display: flex !important;
  flex-direction: column !important;
  border: none !important;
}
ul.products li.product:hover,
.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-lg) !important;
}
ul.products li.product img,
ul.products li.product a img,
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: 250px !important;
  object-fit: contain !important;
  background: var(--color-off-white) !important;
  padding: var(--space-md) !important;
  display: block !important;
  border-radius: 0 !important;
  margin: 0 !important;
}ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2.woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  padding: var(--space-sm) var(--space-md) 0 !important;
  color: var(--color-dark-sage) !important;
  line-height: 1.4 !important;
  margin: 0 !important;
}
ul.products li.product .price,
.woocommerce ul.products li.product .price {
  padding: var(--space-xs) var(--space-md) !important;
  font-weight: 600 !important;
  color: var(--color-sage-dark) !important;
  font-size: 1.1rem !important;
}ul.products li.product .button,
ul.products li.product a.add_to_cart_button,
ul.products li.product a.product_type_simple,
ul.products li.product a.product_type_external,
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.product_type_simple,
.woocommerce ul.products li.product a.product_type_external {
  margin: auto var(--space-md) var(--space-md) !important;
  background: var(--color-sage) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  padding: var(--space-sm) var(--space-md) !important;
  font-weight: 600 !important;
  text-align: center !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: 0.85rem !important;
  transition: background var(--transition-fast) !important;
  display: block !important;
}
ul.products li.product .button:hover,
ul.products li.product a.add_to_cart_button:hover,
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover {
  background: var(--color-sage-dark) !important;
  transform: none !important;
}
/* FIX 6: MOBILE */
@media (max-width: 768px) {
  .site-content,
  .woocommerce-page .site-content {
    padding: 0 var(--space-md) !important;
  }
  .home .site-content {
    padding: 0 !important;
  }
  ul.products li.product,
  .woocommerce ul.products li.product {
    padding: 0 !important;
  }
  ul.products li.product img,
  ul.products li.product a img,
  .woocommerce ul.products li.product a img {
    height: 180px !important;
    padding: var(--space-sm) !important;
  }
  h1 { font-size: 1.75rem !important; }
  h2 { font-size: 1.5rem !important; }
  .collection-banner,
  .hero-banner,
  .home-hero {
    padding: var(--space-2xl) var(--space-md) !important;
    border-radius: 0 !important;
  }
  .home .entry-content > *:not(.hero-section):not(.hero-banner):not(.collection-banner) {
    padding-left: var(--space-md) !important;
    padding-right: var(--space-md) !important;
  }
  .collections-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-sm) !important;
  }
}
/* FIX 7: BLOG ARTICLE */
.single-post .entry-content {
  max-width: 900px !important;
  margin: 0 auto !important;
  padding: var(--space-xl) !important;
}
.single-post .content-area,
.single-post #primary {
  max-width: 900px !important;
}
.blog .hentry {
  background: var(--color-white) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-sm) !important;
  margin-bottom: var(--space-xl) !important;
}

/* ==========================================================================
   MOBILE FIXES — 2026-03-30
   ========================================================================== */

/* --- Fix 1: Trust bar overflow on mobile --- */
@media (max-width: 768px) {
  .trust-bar__inner {
    gap: var(--space-md) !important;
    justify-content: space-between !important;
    padding: 0 var(--space-sm) !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
  }
  .trust-bar__item {
    font-size: 0.7rem !important;
    gap: 4px !important;
    min-width: 0 !important;
    flex-shrink: 1 !important;
  }
  .trust-bar__icon, .trust-bar__icon svg {
    width: 18px !important;
    height: 18px !important;
  }
}

/* --- Fix 2: Hero bigger on mobile --- */
@media (max-width: 768px) {
  .collection-banner,
  .home .entry-content > div:first-child {
    padding: var(--space-2xl) var(--space-md) !important;
    min-height: 200px !important;
  }
  .collection-banner h1, .home .entry-content h1 {
    font-size: 1.6rem !important;
  }
  .collection-banner p {
    font-size: 0.9rem !important;
  }
}

/* --- Fix 3: Homepage category cards --- */
@media (max-width: 768px) {
  .home .entry-content a[href*="product-category"] img {
    height: 100px !important;
    object-fit: cover !important;
  }
  .home .entry-content a[href*="product-category"] h3 {
    font-size: 0.75rem !important;
    padding: var(--space-xs) !important;
    line-height: 1.2 !important;
  }
}

/* --- Fix 4: Product grid on collection pages mobile --- */
@media (max-width: 768px) {
  ul.products, .woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  ul.products li.product, .woocommerce ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
  }
  ul.products li.product img, ul.products li.product a > img {
    width: 100% !important;
    height: 140px !important;
    object-fit: contain !important;
    background: var(--color-off-white) !important;
    padding: 8px !important;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0 !important;
  }
  ul.products li.product .woocommerce-loop-product__title, ul.products li.product h2 {
    font-size: 0.75rem !important;
    line-height: 1.3 !important;
    padding: 6px 8px 2px !important;
    margin: 0 !important;
  }
  ul.products li.product .price {
    font-size: 0.85rem !important;
    padding: 0 8px 4px !important;
    font-weight: 600 !important;
  }
  ul.products li.product span[class*="badge"], ul.products li.product .onsale {
    font-size: 0.55rem !important;
    padding: 2px 6px !important;
  }
  ul.products li.product .button, ul.products li.product a.button {
    font-size: 0.7rem !important;
    padding: 6px 10px !important;
    margin: 4px 8px 8px !important;
    display: block !important;
    text-align: center !important;
  }
}

/* --- Fix 5: Collection page header on mobile --- */
@media (max-width: 768px) {
  .woocommerce-products-header {
    padding: 0 var(--space-sm) !important;
  }
  .woocommerce-products-header h1 {
    font-size: 1.5rem !important;
  }
  .woocommerce-products-header .term-description p {
    font-size: 0.8rem !important;
    line-height: 1.5 !important;
  }
}

/* --- Fix 6: Blog cards on mobile --- */
@media (max-width: 768px) {
  .home .entry-content article img {
    width: 100% !important;
    height: 180px !important;
    object-fit: cover !important;
  }
  .home .entry-content article h3 {
    font-size: 0.9rem !important;
    line-height: 1.3 !important;
  }
  .home .entry-content article p {
    font-size: 0.8rem !important;
  }
}

/* --- Fix 7: Newsletter mobile --- */
@media (max-width: 768px) {
  .home .entry-content input[type="email"] {
    width: 100% !important;
    margin-bottom: var(--space-sm) !important;
    padding: 12px !important;
  }
  .home .entry-content button[type="submit"] {
    width: 100% !important;
    padding: 12px !important;
  }
}

/* --- Fix 8: Footer cleaner on mobile --- */
@media (max-width: 768px) {
  .site-footer .footer-widgets, .site-footer > div > div {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-lg) !important;
    padding: var(--space-lg) var(--space-md) !important;
  }
  .site-footer .footer-widgets > div, .site-footer .widget {
    width: 100% !important;
  }
  .site-footer h4, .site-footer .widget-title {
    font-size: 0.9rem !important;
    border-bottom: 1px solid rgba(255,255,255,0.15) !important;
    padding-bottom: var(--space-xs) !important;
  }
  .site-footer li {
    font-size: 0.8rem !important;
    padding: 3px 0 !important;
  }
}

/* --- Fix 9: Disclosure bar mobile --- */
@media (max-width: 768px) {
  .site-header + div[style*="background"] {
    font-size: 0.7rem !important;
    padding: 6px var(--space-sm) !important;
    line-height: 1.3 !important;
  }
}

/* --- Fix 10: Prevent horizontal overflow + spacing --- */
@media (max-width: 768px) {
  body, .site-content, .col-full, main {
    overflow-x: hidden !important;
  }
  .home .entry-content > div {
    margin-bottom: var(--space-lg) !important;
  }
  .home h2 {
    font-size: 1.3rem !important;
  }
  .home h2 + p {
    font-size: 0.8rem !important;
  }
}

/* --- Fix 11: Breadcrumbs mobile --- */
@media (max-width: 768px) {
  .woocommerce-breadcrumb, nav.breadcrumbs {
    font-size: 0.75rem !important;
    padding: var(--space-xs) var(--space-sm) !important;
  }
}

/* --- Fix 12: Full width mobile, no sidebar --- */
@media (max-width: 768px) {
  #primary, .content-area {
    width: 100% !important;
    float: none !important;
  }
  #secondary, .widget-area {
    display: none !important;
  }
}
