/* =========================================================================
   Équipements Pro Goedert — WooCommerce shop/category/product enhancements
   Works on top of Divi. Brand: black + safety-yellow. Loaded after Divi.
   ========================================================================= */

:root {
  --gg-ink: #1a1a1a;
  --gg-muted: #6f6a60;          /* ≥4.5:1 on white/cream */
  --gg-yellow: #ffc400;
  --gg-yellow-d: #e6b000;
  --gg-line: #e7e4dc;
  --gg-line-2: #d8d4ca;
  --gg-surface: #ffffff;
  --gg-radius: 12px;
  --gg-ease: cubic-bezier(.22,1,.36,1);
}

/* Reclaim full width on WooCommerce pages (Divi reserves an empty right-sidebar column) */
.woocommerce #left-area,
.woocommerce-page #left-area { width: 100% !important; padding-right: 0 !important; }

/* ---- Category quick-filter (browse by type) ---- */
.gg-cat-nav {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin: 0 0 28px; padding: 0;
}
.gg-cat-nav a {
  display: inline-block; padding: 8px 16px;
  border: 1px solid var(--gg-line-2); border-radius: 999px;
  background: var(--gg-surface); color: #33312c;
  font-size: 14px; font-weight: 600; line-height: 1.2; text-decoration: none;
  transition: background .18s var(--gg-ease), color .18s var(--gg-ease), border-color .18s var(--gg-ease);
}
.gg-cat-nav a:hover { background: var(--gg-ink); color: #fff; border-color: var(--gg-ink); }
.gg-cat-nav a.active { background: var(--gg-yellow); color: #111; border-color: var(--gg-yellow); }

/* ---- Shop header row: result count + ordering ---- */
.woocommerce .woocommerce-result-count { color: var(--gg-muted); font-size: 14px; margin: 0 0 18px; }
.woocommerce .woocommerce-ordering { margin: 0 0 18px; }
.woocommerce .woocommerce-ordering select {
  border: 1px solid var(--gg-line-2); border-radius: 8px; padding: 8px 12px; background: #fff; color: var(--gg-ink);
}

/* ---- Product grid: responsive, dense, no float math ---- */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(195px, 1fr));
  gap: 22px;
  margin: 0 0 2.5rem !important;
  padding: 0;
  list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; display: none !important; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important; float: none !important; clear: none !important;
  margin: 0 !important; padding: 14px !important;
  display: flex; flex-direction: column;
  background: var(--gg-surface);
  border: 1px solid var(--gg-line); border-radius: var(--gg-radius);
  transition: transform .25s var(--gg-ease), box-shadow .25s var(--gg-ease), border-color .25s var(--gg-ease);
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px -14px rgba(0,0,0,.22);
  border-color: var(--gg-line-2);
}

/* Image: square, contained on white so the full glove shows */
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .et_shop_image img {
  width: 100% !important; aspect-ratio: 1 / 1; object-fit: contain;
  background: #fff; border-radius: 8px; margin: 0 0 12px !important; display: block;
}
.woocommerce ul.products li.product .et_shop_image { display: block; margin: 0 !important; box-shadow: none !important; }
.woocommerce ul.products li.product .et_overlay { border-radius: 8px; }

/* Title: 2-line clamp, consistent height */
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 15px !important; line-height: 1.32; font-weight: 600; color: var(--gg-ink);
  margin: 0 0 6px !important; padding: 0 !important;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.6em;
}

/* Price (carton price) + caption */
.woocommerce ul.products li.product .price {
  color: var(--gg-ink) !important; font-weight: 700; font-size: 16px; margin: auto 0 0 !important;
}
.woocommerce ul.products li.product .price del { color: var(--gg-muted); font-weight: 400; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.gg-carton-note { display: block; color: var(--gg-muted); font-size: 12px; font-weight: 500; margin-top: 2px; }

/* Card button → brand yellow, black text */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
  margin: 12px 0 0 !important; width: 100%; text-align: center;
  background: var(--gg-yellow) !important; color: #111 !important;
  border-radius: 8px !important; font-weight: 700 !important; text-transform: none !important;
  padding: .7em 1em !important; border: 0 !important; box-shadow: none !important;
  transition: background .2s var(--gg-ease), color .2s var(--gg-ease);
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .added_to_cart:hover { background: var(--gg-ink) !important; color: var(--gg-yellow) !important; }

/* ---- Pagination ---- */
.woocommerce nav.woocommerce-pagination ul { border: 0; gap: 6px; display: flex; justify-content: center; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border: 1px solid var(--gg-line-2); border-radius: 8px; min-width: 40px; padding: 8px 12px; color: var(--gg-ink);
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--gg-ink); color: #fff; border-color: var(--gg-ink); }
.woocommerce nav.woocommerce-pagination ul li a:hover { background: var(--gg-yellow); border-color: var(--gg-yellow); color: #111; }

/* ---- Single product page polish ---- */
.single-product div.product .product_title { font-weight: 700; letter-spacing: -0.01em; }
.single-product div.product p.price,
.single-product div.product .woocommerce-variation-price .price {
  color: var(--gg-ink) !important; font-weight: 800; font-size: clamp(22px, 3vw, 30px);
}
.single-product .woocommerce-product-gallery__image img { background: #fff; border-radius: 10px; }
.single-product table.variations { margin-bottom: 14px; }
.single-product table.variations td, .single-product table.variations th { padding: 8px 8px 8px 0; vertical-align: middle; }
.single-product table.variations select {
  border: 1px solid var(--gg-line-2); border-radius: 8px; padding: 10px 12px; background: #fff; min-width: 220px;
}
.single-product .single_add_to_cart_button.button {
  background: var(--gg-yellow) !important; color: #111 !important; border: 0 !important;
  border-radius: 10px !important; font-weight: 700 !important; text-transform: none !important;
  padding: .9em 1.8em !important; transition: background .2s var(--gg-ease), color .2s var(--gg-ease);
}
.single-product .single_add_to_cart_button.button:hover { background: var(--gg-ink) !important; color: var(--gg-yellow) !important; }

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
}
@media (max-width: 540px) {
  .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .woocommerce ul.products li.product { padding: 10px !important; }
  .woocommerce ul.products li.product h2,
  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 14px !important; }
}

@media (prefers-reduced-motion: reduce) {
  .woocommerce ul.products li.product,
  .gg-cat-nav a,
  .woocommerce ul.products li.product .button { transition: none; }
  .woocommerce ul.products li.product:hover { transform: none; }
}
