/* ==========================================================================
   La Papeterie — WooCommerce overrides
   ========================================================================== */

/* ---- Messages WooCommerce ---- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-lg);
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  gap: var(--space-md);
  list-style: none;
}
.woocommerce-message { background: var(--color-primary-light); border-left: 3px solid var(--color-primary); color: var(--color-ink); }
.woocommerce-info    { background: #e8f4fd; border-left: 3px solid #0ea5e9; color: var(--color-ink); }
.woocommerce-error   { background: #fff0ee; border-left: 3px solid var(--color-sale); color: var(--color-ink); }
.woocommerce-message a, .woocommerce-info a, .woocommerce-error a {
  color: var(--color-primary-dark); font-weight: 500; text-decoration: underline;
}

/* ---- Catalog ordering (tri) ---- */
.woocommerce-ordering {
  margin: 0;
}
.woocommerce-ordering select {
  appearance: none; -webkit-appearance: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  padding: 11px 40px 11px 16px;
  font-size: 0.88rem;
  font-family: var(--font-sans);
  color: var(--color-ink);
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b6b6b'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 8px;
  transition: border-color var(--t-fast);
}
.woocommerce-ordering select:focus { outline: 2px solid var(--color-primary); outline-offset: 2px; border-color: var(--color-primary); }

/* ---- Result count ---- */
.woocommerce-result-count {
  font-size: 0.9rem;
  color: var(--color-muted);
  margin: 0;
}
.woocommerce-result-count strong { color: var(--color-ink); font-weight: 500; }

/* ---- Star rating ---- */
.star-rating {
  display: inline-flex;
  gap: 2px;
  color: var(--color-primary);
  font-size: 0.88rem;
  overflow: hidden;
  position: relative;
  height: 1em;
  line-height: 1;
}
.star-rating::before {
  content: "\f005\f005\f005\f005\f005";
  font-family: "Font Awesome 6 Free";
  font-weight: 400;
  color: var(--color-border);
  display: block;
  letter-spacing: 3px;
}
.star-rating span {
  position: absolute; top: 0; left: 0; overflow: hidden;
  padding-top: 1.5em; white-space: nowrap;
}
.star-rating span::before {
  content: "\f005\f005\f005\f005\f005";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: var(--color-primary);
  display: block;
  position: absolute; top: 0; left: 0;
  letter-spacing: 3px;
}

/* Product rating on product page */
.woocommerce-product-rating {
  display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-md);
}
.woocommerce-review-link { font-size: 0.88rem; color: var(--color-muted); }
.woocommerce-review-link:hover { color: var(--color-primary-dark); }

/* ---- Prix WooCommerce ---- */
.price ins { text-decoration: none; }
.price del { color: var(--color-muted); opacity: 0.7; }

/* Prix sur la carte produit */
.product-card .price {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 500;
}
.product-card .price del { font-size: 1rem; }

/* Prix sur la fiche produit */
.product__price .woocommerce-Price-amount { font-family: var(--font-serif); }
.product__price del .woocommerce-Price-amount { font-size: 1.6rem; color: var(--color-muted); }
.product__price ins .woocommerce-Price-amount { font-size: 2.6rem; }

/* ---- Bouton "Ajouter au panier" natif WooCommerce ---- */
.woocommerce .button,
.woocommerce button.button,
.woocommerce a.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-sans); font-weight: 500;
  font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 16px 30px; border-radius: var(--radius-sm);
  background: var(--color-primary); color: var(--color-white);
  transition: transform var(--t-fast), background var(--t-fast);
  cursor: pointer; border: none; white-space: nowrap;
}
.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover {
  background: var(--color-primary-dark); transform: translateY(-1px); color: var(--color-white);
}
.woocommerce .button.alt { background: var(--color-ink); }
.woocommerce .button.alt:hover { background: #000; }

.single_add_to_cart_button {
  flex: 1;
}

/* ---- WooCommerce notices ---- */
.woocommerce-notices-wrapper { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-lg); }

/* ---- Widget filtres prix (WC price filter widget) ---- */
.widget_price_filter .price_slider_wrapper { padding: 6px 0; }
.widget_price_filter .price_slider { margin: 18px 6px 14px; height: 3px; background: var(--color-border); border-radius: 3px; }
.widget_price_filter .price_slider .ui-slider-range { background: var(--color-primary); border-radius: 3px; }
.widget_price_filter .price_slider .ui-slider-handle {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--color-white); border: 3px solid var(--color-primary);
  box-shadow: var(--shadow-sm); top: -8px; cursor: pointer;
}
.widget_price_filter .price_slider_amount { display: flex; justify-content: space-between; align-items: center; }
.widget_price_filter .price_slider_amount .price_label { font-size: 0.85rem; color: var(--color-muted); }
.widget_price_filter .price_slider_amount button {
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-primary-dark); background: none; border: none; cursor: pointer;
  padding: 8px 0; transition: color var(--t-fast);
}
.widget_price_filter .price_slider_amount button:hover { color: var(--color-primary); }

/* ---- Layered nav widget ---- */
.widget_layered_nav .wc-layered-nav-term { padding: 9px 12px; margin: 0 -12px; border-radius: var(--radius-sm); cursor: pointer; transition: background var(--t-fast); font-size: 0.95rem; display: flex; justify-content: space-between; }
.widget_layered_nav .wc-layered-nav-term:hover { background: var(--color-surface); }
.widget_layered_nav .wc-layered-nav-term .count { color: var(--color-muted); font-size: 0.78rem; }

/* ---- Formulaire panier et checkout ---- */
.woocommerce-cart-form table { width: 100%; border-collapse: collapse; }
.woocommerce-cart-form table th { font-family: var(--font-sans); font-size: 0.72rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--color-border); }
.woocommerce-cart-form table td { padding: var(--space-md) 0; border-bottom: 1px solid var(--color-border); vertical-align: middle; }

/* ---- Page de compte ---- */
.woocommerce-account .woocommerce-MyAccount-navigation ul { display: flex; flex-direction: column; gap: 4px; }
.woocommerce-account .woocommerce-MyAccount-navigation a { display: block; padding: 10px 16px; border-radius: var(--radius-sm); font-size: 0.95rem; transition: background var(--t-fast), color var(--t-fast); }
.woocommerce-account .woocommerce-MyAccount-navigation a:hover { background: var(--color-primary-light); color: var(--color-primary-dark); }
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a { background: var(--color-primary-light); color: var(--color-primary-dark); font-weight: 500; }

/* ---- Loading state (AJAX) ---- */
.ajax_add_to_cart.loading { opacity: 0.6; pointer-events: none; }
.ajax_add_to_cart.added { background: var(--color-primary); color: var(--color-white); }

/* ---- Formulaire commentaires / avis ---- */
.comment-form-rating { margin-bottom: var(--space-md); }
.comment-form label { display: block; font-size: 0.82rem; font-weight: 500; letter-spacing: 0.06em; margin-bottom: 6px; color: var(--color-muted); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea {
  width: 100%; padding: 12px 16px;
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  font-family: inherit; font-size: 0.95rem; color: var(--color-ink);
  background: var(--color-white); transition: border-color var(--t-fast);
}
.comment-form input:focus,
.comment-form textarea:focus { border-color: var(--color-primary); outline: 2px solid var(--color-primary); outline-offset: 2px; }
.comment-form .submit { margin-top: var(--space-md); }
