/* ============================================================
   WOOCOMMERCE — PhoneHS Apple Design
   ============================================================ */

/* ====== SHOP / ARCHIVE ====== */

/* Container — applied directly to .woo-main since nested woo-container
   may be stripped by astra-child hooks */
.woo-main,
.woo-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 20px var(--space-lg) 80px;
}

.woo-main .container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* Breadcrumb — works with both custom and default WC class */
.phs-breadcrumb,
.woocommerce-breadcrumb {
  font-size: var(--font-size-xs) !important;
  color: var(--color-gray-light) !important;
  margin-bottom: 8px !important;
  padding-top: 8px;
}
.phs-breadcrumb a,
.woocommerce-breadcrumb a { color: var(--color-gray); text-decoration: none; }
.phs-breadcrumb a:hover,
.woocommerce-breadcrumb a:hover { color: var(--color-blue); }
.phs-breadcrumb-sep { margin: 0 6px; color: var(--color-border); }

/* Shop header */
.woocommerce-products-header {
  text-align: center;
  padding: 24px 0 32px;
}

.woocommerce-products-header__title {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
}

/* Result count & ordering — flex bar */
.woocommerce-result-count,
.woocommerce-ordering {
  font-size: var(--font-size-sm);
  color: var(--color-gray);
}

/* Make result count + ordering on same line */
.woo-main > .woocommerce-result-count,
.woo-container .woocommerce-result-count { float: left; margin: 0; line-height: 38px; }
.woo-main > .woocommerce-ordering,
.woo-container .woocommerce-ordering { float: right; margin: 0 0 20px; }

.woocommerce-ordering select {
  padding: 8px 36px 8px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  background: white;
  cursor: pointer;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

.woocommerce-ordering select:focus {
  border-color: var(--color-blue);
}

/* ====== PRODUCT GRID ====== */
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.products li.product {
  background: var(--color-gray-bg);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--duration) var(--ease);
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  float: none !important;
  display: flex;
  flex-direction: column;
}

/* Push button to bottom of card */
ul.products li.product .button,
ul.products li.product .add_to_cart_button,
ul.products li.product a.added_to_cart {
  margin-top: auto;
}

ul.products li.product:hover {
  transform: translateY(-4px);
}

/* Product image */
ul.products li.product a img,
ul.products li.product .woocommerce-LoopProduct-link img {
  width: 100%;
  height: 220px;
  object-fit: contain;
  padding: 20px;
  background: white;
  border-radius: 0;
  margin: 0;
}

/* Product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
  font-size: var(--font-size-base) !important;
  font-weight: 600;
  padding: 14px 16px 4px !important;
  margin: 0;
  color: var(--color-black);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Product price */
ul.products li.product .price {
  padding: 0 16px 16px;
  font-size: var(--font-size-lg) !important;
  font-weight: 700;
  color: var(--color-black);
}

ul.products li.product .price del {
  font-size: var(--font-size-sm);
  color: var(--color-gray-light);
  font-weight: 400;
}

ul.products li.product .price ins {
  text-decoration: none;
  font-weight: 700;
}

/* Add to cart button in grid */
ul.products li.product .button,
ul.products li.product a.add_to_cart_button {
  display: block;
  text-align: center;
  padding: 12px 16px;
  background: var(--color-blue);
  color: white;
  font-size: var(--font-size-sm);
  font-weight: 600;
  border: none;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  transition: background var(--duration) var(--ease);
  width: 100%;
  margin: 0;
}

ul.products li.product .button:hover {
  background: var(--color-blue-hover);
}

/* ====================================================
   SYSTÈME BADGE UNIFIÉ
   Overrides tous les styles inline PHP + WC natif
   ==================================================== */

/* Base pill — appliqué à tous les badges */
.onsale,
.promo-badge,
.frontend-state-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: inherit !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  padding: 5px 10px !important;
  border-radius: 100px !important;
  border: none !important;
  white-space: nowrap !important;
  min-width: auto !important;
  min-height: auto !important;
  min-height: unset !important;
  width: auto !important;
  height: auto !important;
  vertical-align: middle !important;
}

/* ── Badge Promo (WC natif ".onsale" + custom ".promo-badge") ── */
.onsale {
  background: var(--color-red) !important;
  color: white !important;
}

/* Position sur la galerie produit — ne pas toucher à position ici (géré par le bloc Gallery) */
.woocommerce-product-gallery .onsale,
.woocommerce-product-gallery .promo-badge {
  position: absolute !important;
  top: 14px !important;
  left: 14px !important;
  z-index: 6 !important;
}

/* Position sur les cartes catalogue */
ul.products li.product .onsale {
  position: absolute !important;
  top: 10px !important;
  left: 10px !important;
  z-index: 5 !important;
}

/* ── Badges état (Neuf / Occasion / Reconditionné) ── */
.frontend-state-badge {
  transition: none !important;
}
.frontend-state-badge:hover {
  transform: none !important;
  box-shadow: none !important;
}

.frontend-state-badge.state-neuf {
  background: #34c759 !important;
  color: white !important;
}
.frontend-state-badge.state-occasion {
  background: #ff9f0a !important;
  color: white !important;
}
.frontend-state-badge.state-reconditionne {
  background: #007aff !important;
  color: white !important;
}

/* Catalogue : badge état centré */
.woocommerce ul.products li.product .frontend-state-badge {
  display: block !important;
  width: fit-content !important;
  margin: 2px auto 5px !important;
}

/* Page produit : badge état au-dessus du titre */
.woocommerce div.product .frontend-state-badge {
  display: inline-flex !important;
  margin: 0 0 10px !important;
}

/* Panier / checkout : version compacte */
.woocommerce-cart .frontend-state-badge,
.woocommerce-checkout .frontend-state-badge {
  font-size: 9px !important;
  padding: 3px 8px !important;
}

/* ====== SINGLE PRODUCT ====== */
.single-product .woo-main,
.single-product .woo-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 20px var(--space-lg) 60px;
}

/* Sur la page produit, overflow-x:hidden du body casse position:sticky — on le neutralise */
body.single-product {
  overflow-x: unset;
}

/* .product devient block : le grid est déplacé dans .phs-product-main-row
   pour que le sticky de la galerie soit contraint au wrapper gallery+summary
   et s'arrête naturellement avant .woocommerce-tabs */
.single-product .product {
  display: block !important;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0;
}

/* Wrapper créé par JS : encapsule gallery + summary */
.single-product .product .phs-product-main-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* Gallery */
/* !important pour surpasser WC core : .woocommerce div.product div.images.woocommerce-product-gallery { position: relative } */
.single-product .product .woocommerce-product-gallery {
  border-radius: 0;
  overflow: visible;
  background: none;
  width: 100% !important;
  float: none !important;
  position: sticky !important;
  top: calc(var(--nav-height) + 20px) !important;
  align-self: start;
}

/* Image principale */
.single-product .product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
  max-height: 480px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-gray-bg);
}

.single-product .product .woocommerce-product-gallery img {
  width: 100% !important;
  height: auto;
  max-height: 460px;
  object-fit: contain;
  padding: 20px;
  display: block;
}

/* Thumbnails */
.single-product .product .woocommerce-product-gallery .flex-control-thumbs {
  display: flex;
  gap: 8px;
  padding: 10px 0 0 !important;
  margin: 8px 0 0 !important;
  list-style: none;
  overflow-x: auto;
  scrollbar-width: none;
}
.single-product .product .woocommerce-product-gallery .flex-control-thumbs::-webkit-scrollbar {
  display: none;
}
.single-product .product .woocommerce-product-gallery .flex-control-thumbs li {
  flex: 0 0 68px;
}
.single-product .product .woocommerce-product-gallery .flex-control-thumbs li img {
  width: 68px !important;
  height: 68px !important;
  object-fit: contain;
  border-radius: 8px;
  border: 2px solid transparent;
  padding: 4px;
  background: var(--color-gray-bg);
  cursor: pointer;
  transition: border-color 0.18s;
  max-height: 68px !important;
  box-sizing: border-box;
}
.single-product .product .woocommerce-product-gallery .flex-control-thumbs li img.flex-active,
.single-product .product .woocommerce-product-gallery .flex-control-thumbs li img:hover {
  border-color: var(--color-blue);
  background: #e8f0fe;
}

/* Loupe */
.single-product .product .woocommerce-product-gallery .woocommerce-product-gallery__trigger {
  top: 12px !important;
  right: 12px !important;
  width: 36px;
  height: 36px;
  background: white !important;
  border-radius: 50% !important;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  z-index: 5;
}

/* Summary — côté droit */
.single-product .product .summary {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
}

.single-product .product .product_title {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 12px;
  line-height: 1.2;
}

/* Short description */
.single-product .product .woocommerce-product-details__short-description {
  font-size: var(--font-size-base);
  font-weight: 400;
  line-height: 1.7;
  color: var(--color-gray);
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--color-border);
}
.single-product .product .woocommerce-product-details__short-description h1,
.single-product .product .woocommerce-product-details__short-description h2,
.single-product .product .woocommerce-product-details__short-description h3 {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--color-dark);
  margin-bottom: 8px;
}

/* Prix */
.single-product .product .price {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--color-black);
  margin-bottom: 24px;
}
.single-product .product .price del {
  font-size: 1rem;
  color: var(--color-gray-light);
  font-weight: 400;
}
.single-product .product .price ins {
  text-decoration: none;
}

/* Variations (couleur, taille, etc) */
.single-product .product .variations {
  border-collapse: separate;
  border-spacing: 0 12px;
  width: 100%;
}
.single-product .product .variations td.label {
  font-size: 0.85rem;
  font-weight: 650;
  color: var(--color-dark);
  padding-right: 16px;
  vertical-align: top;
  padding-top: 12px;
}
.single-product .product .variations td.value select {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--color-border);
  border-radius: 12px;
  font-size: var(--font-size-base);
  outline: none;
  appearance: none;
  background: white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 14px center;
  transition: border-color 0.2s;
}
.single-product .product .variations td.value select:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.1);
}

/* Swatch / color buttons (si plugin variation swatches) */
.single-product .product .variable-items-wrapper .variable-item {
  border-radius: 12px !important;
  border: 2px solid var(--color-border) !important;
  transition: all 0.2s !important;
}
.single-product .product .variable-items-wrapper .variable-item.selected,
.single-product .product .variable-items-wrapper .variable-item:hover {
  border-color: var(--color-blue) !important;
  box-shadow: 0 0 0 3px rgba(0,113,227,0.12) !important;
}

/* Add to cart button */
.single-product .product .single_add_to_cart_button {
  background: var(--color-blue) !important;
  color: white !important;
  border: none;
  border-radius: 14px !important;
  padding: 16px 40px !important;
  font-size: 1rem !important;
  font-weight: 600;
  transition: all 0.2s ease;
  cursor: pointer;
  width: 100%;
  display: block;
  text-align: center;
}
.single-product .product .single_add_to_cart_button:hover {
  background: var(--color-blue-hover) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0,113,227,0.3);
}

/* Quantity + button row */
.single-product .product form.cart {
  display: block;
  margin-bottom: 24px;
}

/* Produits simples : qty + bouton en ligne directement dans form.cart */
.single-product .product form.cart:not(.variations_form) {
  display: flex;
  gap: 12px;
  align-items: stretch;
}

/* Produits variables : wrapper toujours visible */
.single-product .product .single_variation_wrap {
  display: block !important;
  overflow: visible !important;
  height: auto !important;
}

/* Wrapper qty+bouton : toujours en flex (disabled ou enabled) */
.single-product .product .woocommerce-variation-add-to-cart {
  display: flex !important;
  gap: 12px;
  align-items: stretch;
  margin-top: 8px;
  height: auto !important;
  overflow: visible !important;
}

.single-product .product form.cart .quantity,
.single-product .product .woocommerce-variation-add-to-cart .quantity {
  flex: 0 0 auto;
  float: none !important;
  margin: 0 !important;
}
.single-product .product .quantity input[type="number"] {
  border: 1.5px solid var(--color-border);
  border-radius: 12px;
  padding: 14px;
  width: 72px;
  text-align: center;
  font-size: var(--font-size-base);
  font-weight: 600;
  height: 100%;
  box-sizing: border-box;
}
.single-product .product form.cart .single_add_to_cart_button,
.single-product .product .woocommerce-variation-add-to-cart .single_add_to_cart_button {
  flex: 1;
  float: none !important;
}

/* Bouton désactivé (aucune variation sélectionnée) : visible mais indisponible */
.single-product .product .single_add_to_cart_button.disabled,
.single-product .product .single_add_to_cart_button.wc-variation-selection-needed {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  pointer-events: auto !important; /* garde le curseur visible */
  background: #b0b8c1 !important;
  border-color: #b0b8c1 !important;
  box-shadow: none !important;
}

/* Product meta (catégories, marque) */
.single-product .product .product_meta {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--color-border);
  font-size: 0.82rem;
  color: var(--color-gray);
  line-height: 2;
}
.single-product .product .product_meta > span {
  display: block;
}
.single-product .product .product_meta a {
  color: var(--color-blue);
  text-decoration: none;
  font-weight: 500;
}
.single-product .product .product_meta a:hover { text-decoration: underline; }

/* ====== TABS ====== */

/* Anti-FOUC : masquer tous les panels avant que WC JS les affiche */
.woocommerce-tabs .panel {
  display: none;
}

.woocommerce-tabs {
  margin-top: 48px;
}

/* ── Barre d'onglets ── */
.woocommerce-tabs ul.tabs {
  list-style: none;
  display: flex;
  gap: 0;
  padding: 0;
  margin: 0 0 0;
  background: none;
  border: none !important;
  border-bottom: 2px solid var(--color-border) !important;
}

.woocommerce-tabs ul.tabs li {
  margin: 0;
  padding: 0;
  background: none !important;
  border: none !important;
  position: relative;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after {
  content: none !important;
  display: none !important;
}
/* Indicateur actif en bas */
.woocommerce-tabs ul.tabs li.active::after {
  content: '' !important;
  display: block !important;
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-blue);
  border-radius: 2px 2px 0 0;
}

.woocommerce-tabs ul.tabs li a {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 14px 24px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-gray);
  border: none !important;
  transition: color 0.15s ease;
  text-decoration: none;
  white-space: nowrap;
}
.woocommerce-tabs ul.tabs li.active a {
  color: var(--color-dark);
}
.woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-dark);
}

/* ── Zone de contenu ── */
/* Spécificité identique à WC core pour overrider son padding:0 */
.woocommerce div.product .woocommerce-tabs .panel {
  padding: 36px 0 0;
  margin: 0;
  font-size: var(--font-size-base);
  line-height: 1.8;
  color: #444;
  max-width: 820px;
}

/* Description */
.woocommerce-tabs .panel h2:first-child {
  display: none; /* WC génère un H2 "Description" redondant */
}
.woocommerce-tabs .panel h2 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-dark);
  margin: 28px 0 10px;
  letter-spacing: -0.01em;
}
.woocommerce-tabs .panel h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-dark);
  margin: 20px 0 8px;
}
.woocommerce-tabs .panel p {
  margin-bottom: 14px;
  color: #555;
}
.woocommerce-tabs .panel ul,
.woocommerce-tabs .panel ol {
  padding-left: 0;
  margin: 0 0 16px;
  list-style: none;
}
.woocommerce-tabs .panel ul li,
.woocommerce-tabs .panel ol li {
  position: relative;
  padding: 5px 0 5px 22px;
  color: #555;
  font-size: 0.9rem;
  border-bottom: 1px solid #f2f2f2;
}
.woocommerce-tabs .panel ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-blue);
}
.woocommerce-tabs .panel ul li:last-child,
.woocommerce-tabs .panel ol li:last-child {
  border-bottom: none;
}

/* ── Section Avis ── */
#tab-reviews .woocommerce-Reviews-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 24px;
}
#tab-reviews #reviews #comments {
  margin-bottom: 32px;
}
#tab-reviews .commentlist {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
}
#tab-reviews .commentlist li.review {
  display: flex;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--color-border);
}
#tab-reviews .commentlist li.review:last-child {
  border-bottom: none;
}
#tab-reviews .comment_container {
  display: contents;
}
#tab-reviews .commentlist .avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
}
#tab-reviews .commentlist .comment-text {
  flex: 1;
}
#tab-reviews .commentlist .meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
#tab-reviews .commentlist .woocommerce-review__author {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-dark);
}
#tab-reviews .commentlist .woocommerce-review__published-date {
  font-size: 0.78rem;
  color: var(--color-gray-light);
}
#tab-reviews .star-rating {
  font-size: 0.75rem;
  color: #f5a623;
}
#tab-reviews .commentlist .description p {
  margin: 0;
  font-size: 0.9rem;
  color: #555;
  line-height: 1.6;
}

/* Formulaire avis */
#tab-reviews #review_form_wrapper {
  background: var(--color-gray-bg);
  border-radius: 16px;
  padding: 28px;
  margin-top: 8px;
}
#tab-reviews #review_form_wrapper h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 20px;
  color: var(--color-dark);
}
#tab-reviews .comment-form label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: 6px;
}
#tab-reviews .comment-form input[type="text"],
#tab-reviews .comment-form input[type="email"],
#tab-reviews .comment-form textarea {
  width: 100%;
  border: 1.5px solid var(--color-border);
  border-radius: 10px;
  padding: 12px 14px;
  font-size: var(--font-size-base);
  background: white;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
#tab-reviews .comment-form input:focus,
#tab-reviews .comment-form textarea:focus {
  border-color: var(--color-blue);
  outline: none;
  box-shadow: 0 0 0 3px rgba(0,113,227,0.08);
}
#tab-reviews .comment-form textarea { min-height: 120px; resize: vertical; }
#tab-reviews .comment-form .form-submit input {
  background: var(--color-blue);
  color: white;
  border: none;
  border-radius: 10px;
  padding: 12px 28px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
}
#tab-reviews .comment-form .form-submit input:hover {
  background: var(--color-blue-hover);
}
#tab-reviews .comment-form-rating {
  margin-bottom: 16px;
}
#tab-reviews .stars a {
  font-size: 1.2rem;
  color: #ddd;
  transition: color 0.1s;
}
#tab-reviews .stars a:hover,
#tab-reviews .stars a.active,
#tab-reviews .stars.selected a.active {
  color: #f5a623;
}
#tab-reviews p.no-comments {
  color: var(--color-gray);
  font-size: 0.9rem;
  font-style: italic;
}

/* ====== RELATED / UPSELLS ====== */
.single-product .related.products,
.single-product .upsells.products {
  margin-top: 48px;
  padding-top: 40px;
  border-top: 1px solid var(--color-border);
}
.single-product .related.products > h2,
.single-product .upsells.products > h2 {
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 20px;
}

/* Kill clearfix on related products grid too */
.single-product .related.products ul.products::before,
.single-product .related.products ul.products::after,
.single-product .upsells.products ul.products::before,
.single-product .upsells.products ul.products::after {
  content: none !important;
  display: none !important;
}
.single-product .related.products ul.products li.product,
.single-product .upsells.products ul.products li.product {
  clear: none !important;
  float: none !important;
}

/* ================================================================
   CART / CHECKOUT / ACCOUNT — Layout & titre dupliqué
   ================================================================ */

/* Masquer le titre Elementor (doublon avec page-hero) */
body.woocommerce-cart .elementor-widget-heading,
body.woocommerce-checkout .elementor-widget-heading,
body.woocommerce-account .elementor-widget-heading { display: none !important; }

/* Supprimer padding des sections Elementor sur ces pages → pas d'espace vide */
body.woocommerce-cart .elementor-section,
body.woocommerce-checkout .elementor-section { padding: 0 !important; }

/* Supprimer padding des colonnes Elementor (column-gap default = 10px each side) */
body.woocommerce-cart .elementor-column,
body.woocommerce-checkout .elementor-column { padding-top: 0 !important; padding-bottom: 0 !important; }

/* Container Elementor full-width (max-width gérée par .woocommerce) */
body.woocommerce-cart .elementor-container,
body.woocommerce-checkout .elementor-container { max-width: none !important; }

/* Supprimer padding-top du container page.php */
body.woocommerce-cart .site-main > .container,
body.woocommerce-checkout .site-main > .container { padding-top: 0 !important; }

/* Masquer les zones vides qui créent un grand blanc avant le contenu du checkout */
body.woocommerce-checkout .woocommerce-notices-wrapper:empty { display: none !important; margin: 0 !important; }

/* Libérer le max-width 800px de .entry-content (page.php) — critique pour le layout */
body.woocommerce-cart .entry-content,
body.woocommerce-checkout .entry-content,
body.woocommerce-account .entry-content,
body.phs-connexion-page .entry-content {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Supprimer padding Elementor widget-wrap (10px résiduel) */
body.woocommerce-cart .elementor-widget-wrap,
body.woocommerce-checkout .elementor-widget-wrap { padding: 0 !important; }

/* Page-hero sur account : fond clair + titre foncé (lisible) */
body.woocommerce-account .page-hero {
  background: #f5f5f7 !important;
  padding: 36px 0 !important;
  border-bottom: 1px solid var(--color-border);
}
body.woocommerce-account .page-hero-title {
  color: var(--color-dark) !important;
}
body.woocommerce-account .site-main > .container { padding-top: 0 !important; }
body.woocommerce-account .elementor-widget-wrap { padding: 0 !important; }
body.woocommerce-account .elementor-section { padding: 0 !important; }
body.woocommerce-account .entry-content { max-width: none !important; margin: 0 !important; }

/* ====== CART ====== */
body.woocommerce-cart .woocommerce,
.woocommerce-cart .woocommerce {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 48px var(--space-lg) 80px;
}

/* Cart layout : tableau pleine largeur + totaux à droite */
body.woocommerce-cart .woocommerce-cart-form { width: 100%; margin-bottom: 32px; }

body.woocommerce-cart .cart-collaterals {
  float: none !important;
  width: 100% !important;
  display: flex;
  justify-content: flex-end;
}

body.woocommerce-cart .cart_totals {
  width: 360px;
  float: none !important;
}

/* Table cart */
.woocommerce table.shop_table {
  border: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border-collapse: collapse;
  width: 100%;
  background: white;
  box-shadow: 0 0 0 1px var(--color-border);
}

/* Colonnes cart : table-layout fixed pour contrôle total */
.woocommerce-cart-form table.shop_table {
  table-layout: fixed !important;
}
.woocommerce-cart-form table.shop_table th.product-remove,
.woocommerce-cart-form table.shop_table td.product-remove { width: 52px !important; padding: 16px 8px !important; }
.woocommerce-cart-form table.shop_table th.product-thumbnail,
.woocommerce-cart-form table.shop_table td.product-thumbnail { width: 90px !important; }
.woocommerce-cart-form table.shop_table td.product-name { overflow: hidden; }
.woocommerce-cart-form table.shop_table th.product-price,
.woocommerce-cart-form table.shop_table td.product-price { width: 110px !important; text-align: right !important; }
.woocommerce-cart-form table.shop_table th.product-quantity,
.woocommerce-cart-form table.shop_table td.product-quantity { width: 110px !important; text-align: center !important; }
.woocommerce-cart-form table.shop_table th.product-subtotal,
.woocommerce-cart-form table.shop_table td.product-subtotal { width: 120px !important; text-align: right !important; font-weight: 700; }

/* Actions tfoot — garder display:table-cell pour que colspan fonctionne */
.woocommerce-cart-form table.shop_table tfoot td.actions {
  display: table-cell !important;
}

.woocommerce table.shop_table th {
  background: var(--color-gray-bg);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-gray-light);
  padding: 12px 16px;
  border: none;
}

.woocommerce table.shop_table td {
  padding: 16px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

.woocommerce table.shop_table tbody tr:last-child td { border-bottom: none; }

/* Image produit dans le panier */
.woocommerce table.shop_table img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  border-radius: 8px;
  background: var(--color-gray-bg);
  padding: 4px;
}

/* Bouton supprimer produit */
.woocommerce-cart-form td.product-remove a.remove {
  background: #f2f2f7;
  color: var(--color-gray) !important;
  border-radius: 50%;
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.woocommerce-cart-form td.product-remove a.remove:hover {
  background: #ffebe8;
  color: #ff3b30 !important;
}

/* Nom produit */
.woocommerce-cart-form td.product-name a {
  font-weight: 600;
  color: var(--color-black);
  text-decoration: none;
  font-size: var(--font-size-sm);
}
.woocommerce-cart-form td.product-name a:hover { color: var(--color-blue); }

/* Prix */
.woocommerce-cart-form td.product-price,
.woocommerce-cart-form td.product-subtotal { font-weight: 600; color: var(--color-black); }

/* Quantité */
.woocommerce-cart-form .quantity input.qty {
  width: 60px; height: 38px;
  text-align: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

/* Actions bar — NE PAS mettre display:flex sur le TD (casse colspan) */
.woocommerce-cart-form .actions {
  padding: 16px 20px !important;
  background: var(--color-gray-bg);
  border-top: 1px solid var(--color-border);
  overflow: hidden; /* clearfix pour float */
}

/* Bouton "Mettre à jour" → flottant à droite */
.woocommerce-cart-form button[name="update_cart"] {
  float: right;
  padding: 10px 20px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  background: white;
  color: var(--color-dark);
  transition: all 0.2s;
  white-space: nowrap;
}
.woocommerce-cart-form button[name="update_cart"]:hover {
  background: var(--color-blue);
  color: white;
  border-color: var(--color-blue);
}

/* Coupon → inline-flex à gauche */
.woocommerce-cart-form .coupon {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.woocommerce-cart-form .coupon input#coupon_code {
  padding: 10px 16px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  outline: none;
  width: 180px;
  transition: border-color 0.2s;
}
.woocommerce-cart-form .coupon input#coupon_code:focus { border-color: var(--color-blue); }

.woocommerce-cart-form .coupon button[name="apply_coupon"] {
  padding: 10px 20px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  background: white;
  color: var(--color-dark);
  transition: all 0.2s;
  white-space: nowrap;
}
.woocommerce-cart-form .coupon button[name="apply_coupon"]:hover {
  background: var(--color-blue);
  color: white;
  border-color: var(--color-blue);
}

/* Cart Totals */
.cart_totals {
  background: var(--color-gray-bg);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
}

.cart_totals h2 {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 20px;
  color: var(--color-black);
}

.cart_totals .shop_table {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  width: 100%;
  margin-bottom: 0;
}

.cart_totals .shop_table th,
.cart_totals .shop_table td {
  padding: 10px 0;
  border: none !important;
  border-bottom: 1px solid var(--color-border) !important;
  font-size: var(--font-size-sm);
  background: transparent;
  box-shadow: none;
}

.cart_totals .shop_table tr.order-total th,
.cart_totals .shop_table tr.order-total td {
  border-bottom: none !important;
  font-size: 1rem;
  font-weight: 700;
  padding-top: 16px;
}

/* Options de livraison */
.cart_totals .shipping ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.cart_totals .shipping ul li label {
  font-size: var(--font-size-sm);
  cursor: pointer; color: var(--color-dark);
}

/* Bouton valider commande */
.wc-proceed-to-checkout { margin-top: 20px; }

.wc-proceed-to-checkout .checkout-button {
  display: block;
  text-align: center;
  padding: 16px !important;
  background: var(--color-blue) !important;
  color: white !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 700;
  border: none;
  width: 100%;
  transition: background var(--duration) var(--ease);
  cursor: pointer;
}
.wc-proceed-to-checkout .checkout-button:hover { background: var(--color-blue-hover) !important; }

/* ====== CHECKOUT ====== */
body.woocommerce-checkout .woocommerce,
.woocommerce-checkout .woocommerce {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 48px var(--space-lg) 80px;
}

/* Layout 2 colonnes : 1 seul row, billing à gauche, récap à droite alignés en haut.
   On cache le h3#order_review_heading (qui force un 2e row) et on le recrée via ::before */
body.woocommerce-checkout form.woocommerce-checkout {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 0 56px;
  align-items: start;
}

body.woocommerce-checkout #customer_details { grid-column: 1; }

/* Cacher le h3 standalone (il forcerait un 2e row) */
body.woocommerce-checkout #order_review_heading { display: none !important; }

/* Récap à droite, row 1 — heading reconstitué via ::before */
body.woocommerce-checkout #order_review {
  grid-column: 2;
}
body.woocommerce-checkout #order_review::before {
  content: "Votre commande";
  display: block;
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-black);
}

/* Empiler billing et shipping verticalement (non flottés côte à côte) */
body.woocommerce-checkout #customer_details .col-1,
body.woocommerce-checkout #customer_details .col-2 {
  float: none !important;
  width: 100% !important;
  padding: 0 !important;
}
body.woocommerce-checkout #customer_details .col-2 { margin-top: 8px; }

/* Titres de sections (Facturation, Livraison…) */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
  margin-top: 16px;
}
.woocommerce-checkout h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0 0 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-black);
}

/* Champs de formulaire */
.woocommerce form .form-row { margin-bottom: 16px; }

.woocommerce form .form-row label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  display: block;
  margin-bottom: 6px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 13px 16px !important;
  font-size: var(--font-size-sm) !important;
  outline: none;
  width: 100%;
  transition: border-color var(--duration) var(--ease);
  background: white;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--color-blue) !important;
  box-shadow: 0 0 0 3px rgba(0,113,227,0.10) !important;
}

/* Récapitulatif commande */
#order_review .shop_table {
  background: var(--color-gray-bg) !important;
  border-radius: var(--radius-lg);
  box-shadow: none !important;
}
#order_review .shop_table th,
#order_review .shop_table td {
  padding: 12px 16px;
  font-size: var(--font-size-sm);
  border-bottom: 1px solid var(--color-border) !important;
  background: transparent;
}
#order_review .shop_table tr.order-total th,
#order_review .shop_table tr.order-total td {
  font-weight: 700;
  font-size: var(--font-size-base);
  border-bottom: none !important;
}

/* Bloc paiement */
#payment {
  background: white;
  border-radius: var(--radius-lg);
  border: 1.5px solid var(--color-border);
  overflow: hidden;
  margin-top: 20px;
}
#payment ul.payment_methods {
  list-style: none; padding: 20px; margin: 0;
  border-bottom: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: 12px;
}
#payment ul.payment_methods li label {
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  color: var(--color-dark);
}
#payment .payment_box {
  background: var(--color-gray-bg);
  padding: 16px 20px;
  font-size: var(--font-size-sm);
  color: var(--color-gray);
  border-top: 1px solid var(--color-border);
}
#payment .place-order { padding: 20px; }

#place_order {
  background: var(--color-blue) !important;
  color: white !important;
  border-radius: var(--radius-full) !important;
  padding: 18px !important;
  font-size: var(--font-size-base) !important;
  font-weight: 700;
  border: none;
  width: 100%;
  cursor: pointer;
  transition: background var(--duration) var(--ease);
}
#place_order:hover { background: var(--color-blue-hover) !important; }

/* Notices (déjà client ? / code promo ?) */
body.woocommerce-checkout .woocommerce-notices-wrapper { grid-column: 1 / -1; }
body.woocommerce-checkout .woocommerce-info,
body.woocommerce-checkout .woocommerce-error { margin-bottom: 24px; }

/* ====== MY ACCOUNT ====== */

/* Libérer le container pour que le contenu WC prenne toute la largeur */
body.woocommerce-account .site-main > .container { padding-top: 0 !important; }
body.woocommerce-account .entry-content { max-width: none !important; margin: 0 !important; }
body.woocommerce-account .elementor-widget-container { padding: 0 !important; }
body.woocommerce-account .elementor-section,
body.woocommerce-account .elementor-widget-wrap { padding: 0 !important; }

body.woocommerce-account .woocommerce,
.woocommerce-account .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 24px 80px;
  display: grid !important;
  grid-template-columns: 220px 1fr;
  gap: 40px;
  align-items: start;
}

/* Forcer le placement explicite — WC applique float+width qui cassent le grid */
body.woocommerce-account .woocommerce-MyAccount-navigation {
  grid-column: 1 !important;
  grid-row: 1 !important;
  float: none !important;
  width: 100% !important;
  background: var(--color-gray-bg);
  border-radius: var(--radius-lg);
  padding: 16px;
  position: sticky;
  top: calc(var(--nav-height) + 20px);
  box-sizing: border-box;
}

body.woocommerce-account .woocommerce-MyAccount-content {
  grid-column: 2 !important;
  grid-row: 1 !important;
  float: none !important;
  width: 100% !important;
  min-width: 0;
  box-sizing: border-box;
}

.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; margin: 0; }

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 11px 16px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-dark);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: all var(--duration) var(--ease);
}
.woocommerce-MyAccount-navigation ul li a:hover {
  background: white;
  color: var(--color-blue);
}
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: white;
  color: var(--color-blue);
  font-weight: 600;
  box-shadow: var(--shadow-sm);
}

/* Forcer couleur foncée sur TOUS les titres de l'espace client */
/* (sinon ils héritent de styles qui les rendent invisibles) */
body.woocommerce-account .woocommerce-MyAccount-content h1,
body.woocommerce-account .woocommerce-MyAccount-content h2,
body.woocommerce-account .woocommerce-MyAccount-content h3,
body.woocommerce-account .woocommerce-MyAccount-content h4,
body.woocommerce-account .woocommerce-MyAccount-content legend,
body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-MyAccount-content-title,
body.woocommerce-account .woocommerce-MyAccount-content p,
body.woocommerce-account .woocommerce-MyAccount-content label,
body.woocommerce-account .woocommerce-MyAccount-content strong,
body.woocommerce-account .woocommerce-MyAccount-content address,
body.woocommerce-account .woocommerce-MyAccount-content td,
body.woocommerce-account .woocommerce-MyAccount-content th {
  color: var(--color-dark) !important;
}
body.woocommerce-account .woocommerce-MyAccount-content a {
  color: var(--color-blue) !important;
}
body.woocommerce-account .woocommerce-MyAccount-content h1,
body.woocommerce-account .woocommerce-MyAccount-content h2 {
  margin-bottom: 20px;
  font-weight: 700;
}

/* ====== CONNEXION (page /connexion/) ====== */
body.phs-connexion-page .page-hero { display: none; }

/* Libérer le container pour que le bandeau soit plein écran */
body.phs-connexion-page .site-main > .container {
  max-width: none !important;
  padding: 0 !important;
  width: 100% !important;
}
body.phs-connexion-page .elementor {
  width: 100% !important;
  max-width: none !important;
}

/* Supprimer tous paddings Elementor (cette page utilise e-con- flex containers) */
body.phs-connexion-page [class*="e-con"],
body.phs-connexion-page .e-con-inner,
body.phs-connexion-page .elementor-section { padding: 0 !important; margin: 0 !important; }

/* Section 1 (e-con-full) = hero noir avec titre */
body.phs-connexion-page .e-con-full {
  background: var(--color-black, #0d0d0d) !important;
  padding: 44px 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body.phs-connexion-page .elementor-widget-heading .elementor-heading-title {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 800;
  text-align: center;
  color: white !important;
  margin: 0;
  padding: 0;
}

/* Section 2 (e-con-boxed) = fond gris clair, formulaire centré */
body.phs-connexion-page .e-con-boxed {
  background: var(--color-gray-bg, #f7f7f8) !important;
  padding: 60px 24px !important;
}

/* e-con-inner : annuler la max-width Elementor (1140px) et centrer le contenu */
body.phs-connexion-page .e-con-boxed > .e-con-inner {
  max-width: 100% !important;
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  padding: 0 !important;
}

/* Widget à l'intérieur : limité à 520px centré */
body.phs-connexion-page .e-con-boxed .elementor-widget {
  width: 100% !important;
  max-width: 520px !important;
}
body.phs-connexion-page .e-con-boxed .elementor-widget-container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

/* Carte formulaire (pro-forms-container) */
body.phs-connexion-page .pro-forms-container {
  background: white;
  border-radius: var(--radius-xl);
  padding: 44px 44px;
  box-shadow: 0 2px 24px rgba(0,0,0,0.08);
  width: 100%;
  box-sizing: border-box;
}

/* Labels */
body.phs-connexion-page .pro-forms-container label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  display: block;
  margin-bottom: 6px;
}

/* Rows */
body.phs-connexion-page .pro-forms-container .form-row { margin-bottom: 16px; }

/* Inputs */
body.phs-connexion-page .pro-forms-container input[type="text"],
body.phs-connexion-page .pro-forms-container input[type="email"],
body.phs-connexion-page .pro-forms-container input[type="password"] {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
body.phs-connexion-page .pro-forms-container input:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.10);
}

/* Checkbox "se souvenir de moi" */
body.phs-connexion-page .pro-forms-container input[type="checkbox"] {
  width: auto;
  margin-right: 6px;
  vertical-align: middle;
}
body.phs-connexion-page .pro-forms-container label:has(input[type="checkbox"]) {
  display: flex; align-items: center;
  font-weight: 400; color: var(--color-gray);
  font-size: var(--font-size-sm);
}

/* Bouton SE CONNECTER */
body.phs-connexion-page .pro-forms-container button.btn,
body.phs-connexion-page .pro-forms-container button[type="submit"] {
  width: 100% !important;
  padding: 14px !important;
  background: var(--color-blue) !important;
  background-image: none !important;
  color: white !important;
  border: none !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  margin-top: 8px !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  text-align: center !important;
  display: block !important;
}
body.phs-connexion-page .pro-forms-container button.btn:hover,
body.phs-connexion-page .pro-forms-container button[type="submit"]:hover {
  background: var(--color-blue-hover) !important;
  background-image: none !important;
}

/* Lien "Pas encore de compte" et autres liens */
body.phs-connexion-page .pro-forms-container a { color: var(--color-blue); font-size: var(--font-size-sm); }
body.phs-connexion-page .pro-forms-container p:last-child { text-align: center; margin-top: 16px; font-size: var(--font-size-sm); }

/* ====== INSCRIPTION (page /inscription/) ====== */
/* Même design que /connexion/ : hero noir plein écran + carte centrée */

/* Transformer le page-hero gris en bandeau noir */
body.phs-inscription-page .page-hero {
  background: var(--color-black, #0d0d0d) !important;
  padding: 44px 24px !important;
}
body.phs-inscription-page .page-hero-title {
  color: white !important;
}

/* Libérer le container et l'elementor */
body.phs-inscription-page .site-main > .container {
  max-width: none !important;
  padding: 0 !important;
}
body.phs-inscription-page .entry-content {
  max-width: none !important;
  margin: 0 !important;
}
body.phs-inscription-page .elementor {
  width: 100% !important;
  max-width: none !important;
}

/* Supprimer paddings Elementor */
body.phs-inscription-page [class*="e-con"],
body.phs-inscription-page .e-con-inner,
body.phs-inscription-page .elementor-section { padding: 0 !important; margin: 0 !important; }

/* Masquer la section heading Elementor (titre géré par page.php page-hero) */
body.phs-inscription-page .e-con-full { display: none !important; }

/* Section form (e-con-box/e-con-boxed) = fond gris */
body.phs-inscription-page [class*="e-con-box"] {
  background: var(--color-gray-bg, #f7f7f8) !important;
  padding: 60px 24px !important;
}

/* e-con-inner : annuler la contrainte Elementor et centrer */
body.phs-inscription-page .e-con-inner {
  max-width: 100% !important;
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  padding: 0 !important;
}

/* Widget limité à 520px centré */
body.phs-inscription-page [class*="e-con"] .elementor-widget {
  width: 100% !important;
  max-width: 520px !important;
}
body.phs-inscription-page [class*="e-con"] .elementor-widget-container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

/* Carte formulaire */
body.phs-inscription-page .pro-forms-container {
  background: white;
  border-radius: var(--radius-xl);
  padding: 44px 44px;
  box-shadow: 0 2px 24px rgba(0,0,0,0.08);
  width: 100%;
  box-sizing: border-box;
}

/* Labels */
body.phs-inscription-page .pro-forms-container label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  display: block;
  margin-bottom: 6px;
}
body.phs-inscription-page .pro-forms-container .form-row { margin-bottom: 16px; }

/* Inputs */
body.phs-inscription-page .pro-forms-container input[type="text"],
body.phs-inscription-page .pro-forms-container input[type="email"],
body.phs-inscription-page .pro-forms-container input[type="password"],
body.phs-inscription-page .pro-forms-container input[type="tel"],
body.phs-inscription-page .pro-forms-container select {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
body.phs-inscription-page .pro-forms-container input:focus,
body.phs-inscription-page .pro-forms-container select:focus {
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.10);
  outline: none;
}

/* Bouton S'INSCRIRE */
body.phs-inscription-page .pro-forms-container button.btn,
body.phs-inscription-page .pro-forms-container button[type="submit"] {
  width: 100% !important;
  padding: 14px !important;
  background: var(--color-blue) !important;
  background-image: none !important;
  color: white !important;
  border: none !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  margin-top: 8px !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  text-align: center !important;
  display: block !important;
}
body.phs-inscription-page .pro-forms-container button.btn:hover,
body.phs-inscription-page .pro-forms-container button[type="submit"]:hover {
  background: var(--color-blue-hover) !important;
  background-image: none !important;
}

body.phs-inscription-page .pro-forms-container a { color: var(--color-blue); font-size: var(--font-size-sm); }
body.phs-inscription-page .pro-forms-container p:last-child { text-align: center; margin-top: 16px; font-size: var(--font-size-sm); }

/* ====== MESSAGES ====== */
.woocommerce-message,
.woocommerce-info {
  border: none !important;
  background: var(--color-blue-bg) !important;
  color: var(--color-blue) !important;
  border-radius: var(--radius-md) !important;
  /* padding-gauche élargi pour laisser la place à l'icône (sinon elle
     chevauchait la 1re lettre du texte) */
  padding: 14px 20px 14px 52px !important;
  font-size: var(--font-size-sm);
  position: relative !important;
}

/* Icône calée à gauche et centrée verticalement → ne passe plus sur le texte */
.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--color-blue) !important;
  left: 20px !important;
  top: 50% !important;
  margin: 0 !important;
  transform: translateY(-50%) !important;
}

.woocommerce-error {
  border: none !important;
  background: var(--color-red-bg) !important;
  color: var(--color-red) !important;
  border-radius: var(--radius-md) !important;
  padding: 14px 20px 14px 52px !important;
  position: relative !important;
}

.woocommerce-error::before {
  color: var(--color-red) !important;
  left: 20px !important;
  top: 50% !important;
  margin: 0 !important;
  transform: translateY(-50%) !important;
}

/* ====== BREADCRUMBS ====== */
.woocommerce-breadcrumb {
  font-size: var(--font-size-sm);
  color: var(--color-gray-light);
  padding: 16px 0;
  margin-bottom: 0;
}

.woocommerce-breadcrumb a {
  color: var(--color-gray);
  transition: color var(--duration) var(--ease);
}

.woocommerce-breadcrumb a:hover { color: var(--color-blue); }

/* ====== RESPONSIVE ====== */
@media (max-width: 1024px) {
  ul.products { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  ul.products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  ul.products li.product a img { height: 160px; padding: 16px; }

  /* ====== PANIER mobile : bloc 'code promo' qui ne déborde plus ====== */
  /* Le champ passait en largeur fixe (180px) + bouton nowrap → le bouton
     'Appliquer le code promo' était coupé à droite. On rend le champ flexible
     (il rétrécit) pour que le bouton reste toujours entièrement visible. */
  body.woocommerce-cart .woocommerce-cart-form .actions { text-align: left; }
  /* Champ + bouton EMPILÉS (2 lignes) en pleine largeur → le bouton n'est
     plus tronqué et le texte 'Appliquer le code promo' tient à l'aise. */
  .woocommerce-cart-form .coupon {
    display: flex !important;
    flex-direction: column !important;
    float: none !important;
    width: 100%;
    box-sizing: border-box;
    gap: 10px;
    margin-bottom: 12px;
  }
  .woocommerce-cart-form .coupon input#coupon_code {
    width: 100% !important;
    box-sizing: border-box;
    text-align: center;
  }
  .woocommerce-cart-form .coupon button[name="apply_coupon"] {
    width: 100% !important;
    white-space: normal !important;
    box-sizing: border-box;
  }

  /* ====== PANIER mobile : tableau pleine largeur (fin des 'traits courts') ======
     Les largeurs fixes définies pour desktop (52/90/110/120px + table-layout:fixed)
     restaient actives en vue empilée mobile → cellules étroites, lignes courtes.
     On remet tout en largeur auto pour que chaque ligne occupe toute la largeur. */
  body.woocommerce-cart .woocommerce-cart-form table.shop_table { table-layout: auto !important; }
  body.woocommerce-cart .woocommerce-cart-form table.shop_table th,
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td { width: auto !important; }
  body.woocommerce-cart .woocommerce-cart-form table.shop_table td.product-name { overflow: visible !important; }

  /* ====== CHECKOUT mobile : 1 colonne (formulaire puis récap) ====== */
  body.woocommerce-checkout form.woocommerce-checkout {
    grid-template-columns: 1fr !important;
    gap: 28px 0 !important;
  }
  body.woocommerce-checkout #customer_details,
  body.woocommerce-checkout #order_review {
    grid-column: 1 !important;
    min-width: 0 !important;
    max-width: 100% !important;
    position: static !important;
  }
  /* Anti-débordement horizontal sur la page commande */
  body.woocommerce-checkout { overflow-x: hidden; }
  body.woocommerce-checkout .col2-set,
  body.woocommerce-checkout #customer_details .col-1,
  body.woocommerce-checkout #customer_details .col-2 {
    width: 100% !important;
    float: none !important;
  }
  body.woocommerce-checkout #order_review .shop_table { font-size: 0.9rem; }

  /* Single product — galerie en haut, résumé en bas, pas de sticky */
  .single-product .woo-main,
  .single-product .woo-container {
    padding-top: 5px !important;
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
  .single-product .product {
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .single-product .site-main > .container,
  .single-product .elementor-section,
  .single-product .elementor-widget-wrap,
  .single-product .elementor-widget-container {
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .single-product .product .phs-product-main-row {
    grid-template-columns: 1fr !important;
    gap: 24px;
  }
  .single-product .product .woocommerce-product-gallery {
    position: static !important;
    top: auto !important;
    order: 1;
  }
  .single-product .product .summary {
    padding-left: 0;
    margin-top: 0;
    order: 2;
  }
  .single-product .product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
    max-height: none;
  }
  .single-product .product .woocommerce-product-gallery img {
    max-height: 360px;
  }

  /* ====== CONNEXION + INSCRIPTION mobile ====== */
  /* Garde-fou anti-overflow horizontal */
  body.phs-connexion-page,
  body.phs-inscription-page {
    overflow-x: hidden !important;
    max-width: 100vw;
  }
  body.phs-connexion-page *,
  body.phs-inscription-page * {
    max-width: 100%;
  }
  body.phs-connexion-page .site-main,
  body.phs-inscription-page .site-main,
  body.phs-connexion-page .site-main > .container,
  body.phs-inscription-page .site-main > .container,
  body.phs-connexion-page .elementor,
  body.phs-inscription-page .elementor,
  body.phs-connexion-page [class*="e-con"],
  body.phs-inscription-page [class*="e-con"],
  body.phs-connexion-page .e-con-inner,
  body.phs-inscription-page .e-con-inner {
    width: 100% !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box;
  }

  /* Hero connexion (e-con-full noir) */
  body.phs-connexion-page .e-con-full {
    padding: 32px 16px !important;
    width: 100% !important;
    box-sizing: border-box;
  }
  body.phs-connexion-page .elementor-widget-heading {
    width: 100% !important;
    max-width: 100% !important;
  }
  body.phs-connexion-page .elementor-widget-heading .elementor-heading-title {
    font-size: 1.5rem !important;
    line-height: 1.2;
  }

  /* Hero inscription (page-hero) */
  body.phs-inscription-page .page-hero {
    padding: 32px 16px !important;
    width: 100% !important;
    box-sizing: border-box;
  }
  body.phs-inscription-page .page-hero .container {
    padding: 0 !important;
    max-width: 100% !important;
  }
  body.phs-inscription-page .page-hero-title {
    font-size: 1.5rem !important;
    line-height: 1.2;
  }

  /* Container gris (e-con-boxed / e-con-box) — padding 0 (marge gérée sur la carte) */
  body.phs-connexion-page .e-con-boxed,
  body.phs-inscription-page [class*="e-con-box"] {
    padding: 0 12px !important;
    width: 100% !important;
    box-sizing: border-box;
    min-height: 0 !important;
  }
  /* Elementor injecte parfois du padding/margin sur .entry-content ou .site-main */
  body.phs-connexion-page .site-main,
  body.phs-inscription-page .site-main,
  body.phs-connexion-page .entry-content,
  body.phs-inscription-page .entry-content,
  body.phs-connexion-page .phs-elementor-content,
  body.phs-inscription-page .phs-elementor-content {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  body.phs-connexion-page .e-con-boxed > .e-con-inner,
  body.phs-inscription-page .e-con-inner {
    padding: 0 !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }

  /* Widget = pleine largeur mobile */
  body.phs-connexion-page .e-con-boxed .elementor-widget,
  body.phs-inscription-page [class*="e-con"] .elementor-widget {
    width: 100% !important;
    max-width: 100% !important;
  }
  body.phs-connexion-page .e-con-boxed .elementor-widget-container,
  body.phs-inscription-page [class*="e-con"] .elementor-widget-container {
    width: 100% !important;
    padding: 0 !important;
  }

  /* Carte formulaire — marge 15px haut/bas */
  body.phs-connexion-page .pro-forms-container,
  body.phs-inscription-page .pro-forms-container {
    padding: 22px 16px !important;
    border-radius: 14px;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    margin: 15px auto !important;
  }

  /* Inputs/selects = zéro débordement + pas de zoom iOS */
  body.phs-connexion-page .pro-forms-container input,
  body.phs-connexion-page .pro-forms-container select,
  body.phs-inscription-page .pro-forms-container input,
  body.phs-inscription-page .pro-forms-container select,
  body.phs-inscription-page .pro-forms-container textarea {
    font-size: 16px !important;
    padding: 12px 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
  }
  body.phs-connexion-page .pro-forms-container .form-row,
  body.phs-inscription-page .pro-forms-container .form-row,
  body.phs-connexion-page .pro-forms-container .form-row-first,
  body.phs-connexion-page .pro-forms-container .form-row-last,
  body.phs-inscription-page .pro-forms-container .form-row-first,
  body.phs-inscription-page .pro-forms-container .form-row-last {
    width: 100% !important;
    float: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    box-sizing: border-box;
  }
  body.phs-connexion-page .pro-forms-container button,
  body.phs-inscription-page .pro-forms-container button {
    width: 100% !important;
    box-sizing: border-box;
  }

  /* ====== MY ACCOUNT mobile — refonte complète ====== */

  /* Anti-overflow horizontal */
  body.woocommerce-account {
    overflow-x: hidden !important;
    max-width: 100vw;
  }
  body.woocommerce-account .site-main,
  body.woocommerce-account .site-main > .container,
  body.woocommerce-account .elementor,
  body.woocommerce-account .elementor-section,
  body.woocommerce-account .elementor-widget-wrap,
  body.woocommerce-account .elementor-widget-container,
  body.woocommerce-account .entry-content {
    width: 100% !important;
    max-width: 100vw !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box;
  }

  /* Hero */
  body.woocommerce-account .page-hero {
    padding: 22px 16px !important;
    width: 100% !important;
    box-sizing: border-box;
  }
  body.woocommerce-account .page-hero .container {
    padding: 0 !important;
    max-width: 100% !important;
  }
  body.woocommerce-account .page-hero-title {
    font-size: 1.4rem !important;
    line-height: 1.2;
  }

  /* Wrapper principal WC */
  body.woocommerce-account .woocommerce,
  .woocommerce-account .woocommerce {
    display: block !important;
    grid-template-columns: none !important;
    max-width: 100% !important;
    width: 100% !important;
    padding: 14px 12px 40px !important;
    gap: 0 !important;
    margin: 0 !important;
    box-sizing: border-box;
  }

  /* Navigation = barre horizontale scrollable en haut */
  body.woocommerce-account .woocommerce-MyAccount-navigation {
    grid-column: auto !important;
    grid-row: auto !important;
    position: static !important;
    top: auto !important;
    width: 100% !important;
    padding: 0 !important;
    margin-bottom: 14px !important;
    background: transparent;
    border-radius: 0;
    box-sizing: border-box;
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 6px;
    padding: 4px 2px;
    margin: 0;
    list-style: none;
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar { display: none; }
  body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    flex: 0 0 auto;
    margin: 0 !important;
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 8px 14px !important;
    font-size: 0.78rem !important;
    font-weight: 500;
    background: var(--color-gray-bg);
    border-radius: 999px;
    white-space: nowrap;
    color: var(--color-dark);
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background: var(--color-blue) !important;
    color: white !important;
    box-shadow: none;
  }

  /* Contenu */
  body.woocommerce-account .woocommerce-MyAccount-content {
    grid-column: auto !important;
    grid-row: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
  }
  body.woocommerce-account .woocommerce-MyAccount-content > * {
    max-width: 100%;
    box-sizing: border-box;
  }

  /* Titres + texte */
  body.woocommerce-account .woocommerce-MyAccount-content h1,
  body.woocommerce-account .woocommerce-MyAccount-content h2,
  body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-MyAccount-content-title {
    font-size: 1.2rem !important;
    margin: 8px 0 14px !important;
    word-wrap: break-word;
  }
  body.woocommerce-account .woocommerce-MyAccount-content h3 {
    font-size: 1.05rem !important;
  }
  body.woocommerce-account .woocommerce-MyAccount-content p {
    font-size: 0.9rem;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  body.woocommerce-account .woocommerce-MyAccount-content a {
    word-break: break-word;
  }

  /* Infos compte pro */
  body.woocommerce-account .woocommerce-pro-account-info {
    padding: 14px !important;
    margin-bottom: 20px !important;
    box-sizing: border-box;
  }
  body.woocommerce-account .woocommerce-pro-account-info h3 {
    font-size: 1rem !important;
  }

  /* Tables (shop_table) — lisible sur mobile */
  body.woocommerce-account .shop_table,
  body.woocommerce-account .shop_table_responsive {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.85rem;
    border-collapse: collapse;
    box-sizing: border-box;
    table-layout: fixed;
  }
  body.woocommerce-account .shop_table tr,
  body.woocommerce-account .shop_table_responsive tr {
    border-bottom: 1px solid var(--color-border);
  }
  body.woocommerce-account .shop_table th,
  body.woocommerce-account .shop_table td,
  body.woocommerce-account .shop_table_responsive th,
  body.woocommerce-account .shop_table_responsive td {
    padding: 10px 8px !important;
    word-break: break-word;
    overflow-wrap: break-word;
    vertical-align: top;
    text-align: left !important;
  }
  body.woocommerce-account .shop_table th {
    font-weight: 600;
    color: var(--color-gray);
    font-size: 0.78rem;
    width: 45%;
  }

  /* Formulaires (Adresses, Détails du compte) */
  body.woocommerce-account .woocommerce-MyAccount-content form .form-row,
  body.woocommerce-account .woocommerce-MyAccount-content form .form-row-first,
  body.woocommerce-account .woocommerce-MyAccount-content form .form-row-last,
  body.woocommerce-account .woocommerce-MyAccount-content form .form-row-wide {
    width: 100% !important;
    float: none !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
    box-sizing: border-box;
  }
  body.woocommerce-account .woocommerce-MyAccount-content label {
    display: block;
    margin-bottom: 6px;
    font-size: 0.85rem;
    font-weight: 600;
  }
  body.woocommerce-account .woocommerce-MyAccount-content input[type="text"],
  body.woocommerce-account .woocommerce-MyAccount-content input[type="email"],
  body.woocommerce-account .woocommerce-MyAccount-content input[type="tel"],
  body.woocommerce-account .woocommerce-MyAccount-content input[type="password"],
  body.woocommerce-account .woocommerce-MyAccount-content select,
  body.woocommerce-account .woocommerce-MyAccount-content textarea {
    font-size: 16px !important;
    padding: 11px 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    border: 1.5px solid var(--color-border);
    border-radius: 10px;
  }
  body.woocommerce-account .woocommerce-MyAccount-content .button,
  body.woocommerce-account .woocommerce-MyAccount-content button[type="submit"],
  body.woocommerce-account .woocommerce-MyAccount-content input[type="submit"] {
    width: 100% !important;
    box-sizing: border-box;
    padding: 12px !important;
    font-size: 0.95rem !important;
  }

  /* Fieldset / legend */
  body.woocommerce-account .woocommerce-MyAccount-content fieldset {
    padding: 14px !important;
    margin: 14px 0 !important;
    border: 1px solid var(--color-border);
    border-radius: 10px;
  }
  body.woocommerce-account .woocommerce-MyAccount-content legend {
    font-size: 0.95rem;
    padding: 0 6px;
  }

  /* Notices / messages */
  body.woocommerce-account .woocommerce-message,
  body.woocommerce-account .woocommerce-info,
  body.woocommerce-account .woocommerce-error {
    font-size: 0.85rem !important;
    padding: 12px 14px !important;
    margin-bottom: 14px !important;
    word-break: break-word;
  }

  /* Page détails de commande (order-details) */
  body.woocommerce-account .order_details,
  body.woocommerce-account .customer_details,
  body.woocommerce-account .addresses {
    display: block !important;
    width: 100% !important;
  }
  body.woocommerce-account .addresses .col-1,
  body.woocommerce-account .addresses .col-2,
  body.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
    width: 100% !important;
    float: none !important;
    margin-bottom: 16px !important;
    box-sizing: border-box;
  }
}

@media (max-width: 480px) {
  ul.products { grid-template-columns: 1fr; }
}
