/* =========================================================================
   Cercle de Présence — WooCommerce
   Habille la boutique réelle (catalogue, fiche produit, panier, commande)
   avec la palette et la typographie de la maison.
   ========================================================================= */

.woocommerce, .woocommerce-page { color: var(--cacao); }
.cdp-shop-body { padding: 32px 0 100px; background: var(--ivory); }
.cdp-shop-body .wrap { max-width: var(--maxw); }

/* --- En-têtes --- */
.woocommerce-products-header__title,
.woocommerce h1.entry-title,
.woocommerce .product_title {
  font-family: var(--serif);
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -0.015em;
}
.woocommerce-result-count {
  font-family: ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--cacao-soft);
  text-transform: uppercase;
}
.woocommerce .woocommerce-ordering select {
  border: 1px solid rgba(75,55,42,.18);
  background: var(--ivory);
  padding: 10px 16px;
  border-radius: 999px;
  font: inherit;
  font-size: 13px;
  color: var(--cacao);
}

/* --- Grille catalogue --- */
/* Neutralise la collision avec la grille générique .products de la maison
   (les sections « related »/« up-sells » de Woo portent la classe .products). */
.woocommerce .related.products,
.woocommerce .up-sells.products,
.woocommerce-page .related.products,
.woocommerce-page .up-sells.products { display: block; }
.woocommerce .related.products > h2,
.woocommerce .up-sells.products > h2 { margin-bottom: 28px; }

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (max-width: 1100px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  text-align: left;
}
.woocommerce ul.products li.product a img {
  margin: 0 0 18px;
  border: 1px solid rgba(75,55,42,.08);
  background: var(--ivory-deep);
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--serif);
  font-weight: 700;
  color: var(--blue);
  font-size: 17px;
  letter-spacing: -0.005em;
  padding: 0 0 4px;
}
.woocommerce ul.products li.product .price {
  color: var(--gold) !important;
  font-weight: 600;
  font-size: 14px;
}
.woocommerce ul.products li.product .price del { color: var(--cacao-soft); opacity: .6; font-weight: 400; }
.woocommerce span.onsale {
  background: var(--terracotta);
  color: var(--ivory);
  border-radius: 999px;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
  min-height: auto;
  min-width: auto;
  padding: 6px 12px;
  top: 12px; left: 12px;
  margin: 0;
}

/* --- Boutons --- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
  background: var(--blue);
  color: var(--ivory);
  border-radius: 999px;
  padding: 14px 26px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  border: none;
  transition: background .3s ease;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--gold);
  color: var(--blue);
}

/* --- Fiche produit --- */
.woocommerce div.product { margin-top: 8px; }
.woocommerce div.product .woocommerce-product-gallery { border: 1px solid rgba(75,55,42,.08); }
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--blue);
  font-family: var(--serif);
  font-weight: 700;
  font-size: 32px;
  letter-spacing: -0.02em;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  font-family: var(--italic);
  font-style: italic;
  font-size: 18px;
  color: var(--cacao);
  line-height: 1.55;
}
.woocommerce .quantity .qty {
  border: 1px solid rgba(75,55,42,.18);
  border-radius: 999px;
  padding: 12px;
  background: var(--ivory);
  color: var(--blue);
  font-weight: 700;
  font-family: var(--serif);
}
.woocommerce div.product form.cart .button {
  padding: 14px 32px;
}
.woocommerce div.product .product_meta {
  font-size: 12px;
  color: var(--cacao-soft);
  border-top: 1px solid rgba(75,55,42,.12);
  padding-top: 18px;
  margin-top: 8px;
}

/* --- Onglets --- */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border: none;
  padding: 0;
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: rgba(75,55,42,.15); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-size: 11.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--cacao-soft);
  padding: 14px 2px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--blue); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom: 1px solid var(--gold); }
.woocommerce #reviews #comments ol.commentlist li .star-rating,
.woocommerce .star-rating span::before { color: var(--gold); }

/* --- Titres de section --- */
.woocommerce .related > h2,
.woocommerce .upsells > h2,
.woocommerce h2 {
  font-family: var(--serif);
  font-weight: 700;
  color: var(--blue);
  letter-spacing: -0.01em;
}

/* --- Panier & commande --- */
.woocommerce table.shop_table {
  border: 1px solid rgba(75,55,42,.12);
  border-radius: 6px;
}
.woocommerce table.shop_table th {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cacao-soft);
}
.woocommerce .cart-collaterals .cart_totals h2,
.woocommerce-checkout h3 {
  font-family: var(--serif);
  color: var(--blue);
}
.woocommerce-info,
.woocommerce-message {
  border-top-color: var(--gold);
  background: var(--ivory-warm);
  color: var(--cacao);
}
.woocommerce-info::before,
.woocommerce-message::before { color: var(--gold); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid rgba(75,55,42,.18);
  border-radius: 8px;
  padding: 12px 14px;
  background: var(--ivory);
  font: inherit;
  color: var(--cacao);
}
.woocommerce .price ins { text-decoration: none; }

/* =========================================================================
   Mise en page « Cercle » de la fiche produit (surcharge content-single-product)
   ========================================================================= */
.woocommerce div.product.product-detail {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
  float: none;
  margin-top: 24px;
}
@media (max-width: 980px) {
  .woocommerce div.product.product-detail { grid-template-columns: 1fr; }
}
.woocommerce div.product.product-detail .cdp-pd-media,
.woocommerce div.product.product-detail .summary {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
}
.woocommerce div.product.product-detail .woocommerce-product-gallery {
  width: 100% !important;
  margin: 0;
  border: 1px solid rgba(75,55,42,.08);
  background: var(--ivory-deep);
}
.woocommerce div.product.product-detail .summary.pd-info { padding-top: 0; }
.woocommerce div.product.product-detail .pd-info .product_title {
  font-family: var(--serif);
  font-weight: 700;
  color: var(--blue);
  font-size: clamp(30px, 4vw, 52px);
  letter-spacing: -0.02em;
  line-height: 1.04;
  margin: 0 0 16px;
}
.woocommerce div.product.product-detail .pd-info .woocommerce-product-rating { margin-bottom: 22px; }
.woocommerce div.product.product-detail .pd-info .woocommerce-product-rating .star-rating span::before { color: var(--gold); }
.woocommerce div.product.product-detail .pd-info > .price { display: block; margin: 0 0 24px; }
.woocommerce div.product.product-detail .pd-info form.cart { margin: 10px 0 26px; }
.woocommerce div.product.product-detail .pd-info .product_meta { margin-top: 6px; }

/* Barre de tri du catalogue */
.cdp-shop-bar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 20px; margin-bottom: 32px; padding-bottom: 18px;
  border-bottom: 1px solid rgba(75,55,42,.12); flex-wrap: wrap;
}
.cdp-shop-bar .woocommerce-result-count,
.cdp-shop-bar form.woocommerce-ordering { margin: 0; }

/* Fil d'Ariane */
.woocommerce-breadcrumb.crumb {
  font-family: ui-monospace, monospace;
  font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--cacao-soft); margin: 0; padding: 0;
}
.woocommerce-breadcrumb.crumb a { color: var(--cacao-soft); }
.woocommerce-breadcrumb.crumb a:hover { color: var(--gold); }
.woocommerce-breadcrumb.crumb .sep { opacity: .4; }
