/* ==========================================================================
   woocommerce.css — Templates shop (archive-product.php + single-product.php).
   Le CSS par défaut de WooCommerce est désactivé via le filter woocommerce_enqueue_styles
   dans includes/woocommerce.php — tout le visuel shop est défini ici.
   ========================================================================== */

/* ==========================================================================
   Archive (boutique + catégories produits)
   ========================================================================== */

.shop-archive {
	display: flex;
	flex-direction: column;
	overflow-x: clip;
	max-width: 100%;
}

/* ----------------------------------------- Hero d'archive */

.shop-archive__hero {
	background: var(--color-bg);
	color: var(--color-text);
	padding-block: clamp(var(--space-2xl), 6vw, var(--space-3xl));
	border-bottom: 1px solid var(--color-border);
}

.shop-archive__hero-inner {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	max-width: var(--container-max);
}

.shop-archive__eyebrow {
	font-size: var(--fs-xs);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-widest);
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0;
}

.shop-archive__title {
	font-family: var(--font-display);
	font-size: var(--fs-4xl);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	margin: 0;
	color: inherit;
	text-wrap: balance;
}

.shop-archive__description {
	font-size: var(--fs-lg);
	line-height: var(--lh-relaxed);
	color: var(--color-text-muted);
	max-width: 64ch;
}

.shop-archive__description p {
	margin: 0 0 var(--space-sm);
}

.shop-archive__description p:last-child {
	margin-bottom: 0;
}

/* ----------------------------------------- Body (grille) */

.shop-archive__body {
	padding-block: clamp(var(--space-2xl), 6vw, var(--space-3xl));
}

.shop-archive__inner {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
	min-width: 0;
	max-width: 100%;
}

/* ===== Layout sidebar + main ===== */
.shop-archive__layout {
	display: grid;
	grid-template-columns: 240px minmax(0, 1fr);
	gap: var(--space-2xl);
	align-items: start;
	min-width: 0;
	position: relative;
}

/* État de chargement AJAX (fetch & swap) — léger overlay + spinner */
.shop-archive__layout.is-loading .shop-archive__grid,
.shop-archive__layout.is-loading .shop-archive__pagination,
.shop-archive__layout.is-loading .shop-archive__toolbar {
	opacity: 0.4;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.shop-archive__layout.is-loading::after {
	content: "";
	position: absolute;
	top: 30%;
	left: 50%;
	width: 38px;
	height: 38px;
	margin: -19px 0 0 -19px;
	border: 3px solid var(--color-border);
	border-top-color: var(--color-accent);
	border-radius: 50%;
	animation: shop-archive-spin 0.8s linear infinite;
	z-index: 10;
}

@keyframes shop-archive-spin {
	to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
	.shop-archive__layout.is-loading::after {
		animation: none;
		border-top-color: var(--color-accent);
	}
}

@media (max-width: 959px) {
	.shop-archive__layout {
		grid-template-columns: minmax(0, 1fr);
		gap: var(--space-lg);
	}
}

.shop-archive__sidebar {
	position: sticky;
	top: calc(var(--header-height, 80px) + var(--space-md));
}

@media (max-width: 959px) {
	.shop-archive__sidebar {
		position: static;
	}
}

.shop-archive__sidebar-title {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin: 0 0 var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
}

@media (max-width: 959px) {
	.shop-archive__sidebar-title {
		font-size: 0.68rem;
		margin-bottom: var(--space-sm);
		padding-bottom: var(--space-xs);
	}
}

.shop-archive__cat-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.shop-archive__cat-list > li {
	margin: 0;
}

.shop-archive__cat-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	padding: 10px 14px;
	text-decoration: none;
	color: var(--color-text-muted);
	font-size: 0.92rem;
	line-height: 1.3;
	border-left: 3px solid transparent;
	transition: color 0.2s, background 0.2s, border-color 0.2s;
}

.shop-archive__cat-link:hover,
.shop-archive__cat-link:focus-visible {
	color: var(--color-text);
	background: var(--color-surface);
	outline: none;
}

.shop-archive__cat-link.is-active {
	color: var(--color-accent);
	border-left-color: var(--color-accent);
	background: rgba(var(--color-accent-rgb), 0.10);
	font-weight: 600;
}

.shop-archive__cat-name {
	flex: 1 1 auto;
	min-width: 0;
}

.shop-archive__cat-count {
	flex: 0 0 auto;
	font-size: 0.72rem;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	padding: 2px 9px;
	border-radius: 100px;
	font-weight: 600;
	color: var(--color-text-muted);
	font-feature-settings: "tnum";
	min-width: 28px;
	text-align: center;
	line-height: 1.4;
}

.shop-archive__cat-link.is-active .shop-archive__cat-count {
	background: var(--color-accent);
	color: #0d0d0d;
	border-color: var(--color-accent);
}

/* ===== Mobile : chip pills (horizontal scroll) ===== */
@media (max-width: 959px) {
	.shop-archive__cat-list {
		display: flex;
		gap: var(--space-xs);
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 4px 0 var(--space-xs);
		margin-inline: calc(var(--container-padding) * -1);
		padding-inline: var(--container-padding);
	}

	.shop-archive__cat-list::-webkit-scrollbar {
		display: none;
	}

	.shop-archive__cat-link {
		flex: 0 0 auto;
		gap: 8px;
		padding: 8px 14px;
		border: 1px solid var(--color-border);
		border-radius: 100px;
		background: var(--color-bg);
		white-space: nowrap;
		font-size: 0.85rem;
	}

	.shop-archive__cat-link.is-active {
		background: var(--color-accent);
		color: #0d0d0d;
		border-color: var(--color-accent);
	}

	.shop-archive__cat-link.is-active .shop-archive__cat-count {
		background: rgba(13, 13, 13, 0.18);
		color: #0d0d0d;
		border-color: transparent;
	}
}

.shop-archive__main {
	min-width: 0;
	max-width: 100%;
}

.shop-archive__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: var(--space-lg);
	width: 100%;
	min-width: 0;
}

@media (min-width: 600px) {
	.shop-archive__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 960px) {
	.shop-archive__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.shop-archive__item {
	display: flex;
	min-width: 0;
	max-width: 100%;
	min-height: 0;
}

.shop-archive__empty {
	font-size: var(--fs-lg);
	color: var(--color-text-muted);
	text-align: center;
	padding: var(--space-2xl) 0;
}

/* ----------------------------------------- Carte produit */

.product-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	color: inherit;
	overflow: hidden;
	transition:
		transform var(--duration-base) var(--ease-out),
		border-color var(--duration-base) var(--ease-out),
		box-shadow var(--duration-base) var(--ease-out);
}

.product-card:hover,
.product-card:focus-visible {
	transform: translateY(-4px);
	border-color: var(--color-accent);
	box-shadow: var(--shadow-lg);
}

.product-card:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 4px;
}

.product-card__media {
	position: relative;
	aspect-ratio: 1/1;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	background: var(--color-surface-alt);
}

.product-card__image {
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: cover;
	display: block;
}

.product-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	padding: var(--space-lg);
	flex: 1;
}

.product-card__title {
	font-family: var(--font-display);
	font-size: var(--fs-lg);
	font-weight: var(--fw-bold);
	line-height: var(--lh-snug);
	margin: 0;
	color: var(--color-text);
	letter-spacing: var(--ls-tight);
}

.product-card__excerpt {
	display: none;
}

.product-card__cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
	color: var(--color-accent);
	font-size: var(--fs-sm);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	padding-top: var(--space-sm);
	border-top: 1px solid var(--color-border);
}

.product-card__cta-icon {
	display: inline-flex;
	transition: transform var(--duration-fast) var(--ease-out);
}

.product-card:hover .product-card__cta-icon,
.product-card:focus-visible .product-card__cta-icon {
	transform: translateX(4px);
}

/* ----------------------------------------- Pagination */

.shop-archive__pagination {
	margin-top: var(--space-xl);
	display: flex;
	justify-content: center;
}

/* the_posts_pagination() emits a nested <nav class="navigation pagination">
   with <div class="nav-links">. The .page-numbers class is applied to each
   individual button (a / span), not to a wrapping list. */
.shop-archive__pagination .navigation.pagination {
	width: 100%;
}

.shop-archive__pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px;
}

.shop-archive__pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 12px;
	color: var(--color-text-muted);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 600;
	font-feature-settings: "tnum";
	transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.shop-archive__pagination a.page-numbers:hover,
.shop-archive__pagination a.page-numbers:focus-visible {
	color: var(--color-accent);
	border-color: var(--color-accent);
	outline: none;
}

.shop-archive__pagination .page-numbers.current {
	color: #0d0d0d;
	background: var(--color-accent);
	border-color: var(--color-accent);
}

.shop-archive__pagination .page-numbers.dots {
	background: transparent;
	border-color: transparent;
	pointer-events: none;
}

.shop-archive__pagination .page-numbers.prev,
.shop-archive__pagination .page-numbers.next {
	padding-inline: 16px;
	letter-spacing: 0.02em;
}

@media (max-width: 600px) {
	.shop-archive__pagination .page-numbers {
		min-width: 38px;
		height: 38px;
		padding: 0 10px;
		font-size: 0.85rem;
	}
	.shop-archive__pagination .page-numbers.prev,
	.shop-archive__pagination .page-numbers.next {
		padding-inline: 12px;
	}
}

/* ==========================================================================
   Single product
   ========================================================================== */

.product-detail {
	padding-block: clamp(var(--space-2xl), 6vw, var(--space-3xl));
}

.product-detail__inner {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

/* ----------------------------------------- Breadcrumbs */

.product-detail__breadcrumbs {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
}

.product-detail__breadcrumbs-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-2xs);
}

.product-detail__breadcrumbs-item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
}

.product-detail__breadcrumbs-item a {
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--duration-fast) var(--ease-out);
}

.product-detail__breadcrumbs-item a:hover,
.product-detail__breadcrumbs-item a:focus-visible {
	color: var(--color-accent);
}

.product-detail__breadcrumbs-sep {
	color: var(--color-border-strong);
}

/* ----------------------------------------- Layout (galerie + contenu) */

.product-detail__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(var(--space-xl), 4vw, var(--space-2xl));
	align-items: start;
}

@media (max-width: 960px) {
	.product-detail__layout {
		grid-template-columns: 1fr;
	}
}

/* ----------------------------------------- Galerie */

.product-detail__gallery {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.product-detail__gallery-main {
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
}

.product-detail__gallery-image {
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: cover;
	display: block;
	transition: opacity var(--duration-fast) var(--ease-out);
}

.product-detail__gallery-thumbs {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
	gap: var(--space-2xs);
}

.product-detail__gallery-thumb-wrap {
	display: flex;
	min-width: 0;
}

.product-detail__gallery-thumb {
	appearance: none;
	background: none;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: 0;
	cursor: pointer;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	width: 100%;
	transition:
		border-color var(--duration-fast) var(--ease-out),
		transform var(--duration-fast) var(--ease-out);
}

.product-detail__gallery-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.product-detail__gallery-thumb:hover {
	border-color: var(--color-text-muted);
}

.product-detail__gallery-thumb:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.product-detail__gallery-thumb.is-active {
	border-color: var(--color-accent);
}

/* ----------------------------------------- Content */

.product-detail__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	min-width: 0;
}

.product-detail__header {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.product-detail__category {
	font-size: var(--fs-xs);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-widest);
	text-transform: uppercase;
	margin: 0;
}

.product-detail__category a {
	color: var(--color-accent);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration-fast) var(--ease-out);
}

.product-detail__category a:hover,
.product-detail__category a:focus-visible {
	border-bottom-color: var(--color-accent);
}

.product-detail__title {
	font-family: var(--font-display);
	font-size: var(--fs-3xl);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	margin: 0;
	color: inherit;
	text-wrap: balance;
}

.product-detail__short-description {
	font-size: var(--fs-lg);
	line-height: var(--lh-relaxed);
	color: var(--color-text-muted);
}

.product-detail__short-description p {
	margin: 0 0 var(--space-sm);
}

.product-detail__short-description p:last-child {
	margin-bottom: 0;
}

/* ----------------------------------------- CTA Demander un devis */

.product-detail__cta {
	appearance: none;
	-webkit-appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-md) var(--space-xl);
	background: var(--color-accent);
	color: var(--color-text);
	border: 0;
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: var(--fs-base);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	cursor: pointer;
	box-shadow: var(--shadow-sm);
	transition:
		background var(--duration-fast) var(--ease-out),
		transform var(--duration-fast) var(--ease-out),
		box-shadow var(--duration-fast) var(--ease-out);
	align-self: flex-start;
}

.product-detail__cta:hover,
.product-detail__cta:focus-visible {
	background: var(--color-accent-dark);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.product-detail__cta:focus-visible {
	outline: 2px solid var(--color-text);
	outline-offset: 3px;
}

.product-detail__cta-icon {
	display: inline-flex;
	transition: transform var(--duration-fast) var(--ease-out);
}

.product-detail__cta:hover .product-detail__cta-icon,
.product-detail__cta:focus-visible .product-detail__cta-icon {
	transform: translateX(4px);
}

/* ----------------------------------------- Description longue (the_content) */

.product-detail__description {
	font-size: var(--fs-base);
	line-height: var(--lh-relaxed);
	color: var(--color-text);
	max-width: 72ch;
}

.product-detail__description p {
	margin: 0 0 var(--space-sm);
}

.product-detail__description p:last-child {
	margin-bottom: 0;
}

.product-detail__description h2,
.product-detail__description h3,
.product-detail__description h4 {
	font-family: var(--font-display);
	margin: var(--space-lg) 0 var(--space-sm);
	color: var(--color-text);
}

.product-detail__description h2 { font-size: var(--fs-xl); }
.product-detail__description h3 { font-size: var(--fs-lg); }
.product-detail__description h4 { font-size: var(--fs-base); }

.product-detail__description ul,
.product-detail__description ol {
	margin: 0 0 var(--space-md);
	padding-left: var(--space-md);
}

.product-detail__description li {
	margin-bottom: var(--space-2xs);
}

.product-detail__description a {
	color: var(--color-accent);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* ----------------------------------------- Attributs */

.product-detail__attributes {
	margin: 0;
	padding: var(--space-md) 0;
	border-top: 1px solid var(--color-border);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-sm);
}

@media (min-width: 600px) {
	.product-detail__attributes {
		grid-template-columns: repeat(2, 1fr);
	}
}

.product-detail__attribute {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.product-detail__attribute-label {
	font-size: var(--fs-xs);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-widest);
	text-transform: uppercase;
	color: var(--color-text-muted);
}

.product-detail__attribute-value {
	margin: 0;
	font-size: var(--fs-base);
	color: var(--color-text);
}

/* ----------------------------------------- Reduced motion */

@media (prefers-reduced-motion: reduce) {
	.product-card,
	.product-card__image,
	.product-card__cta-icon,
	.product-detail__cta,
	.product-detail__cta-icon,
	.product-detail__gallery-thumb,
	.product-detail__gallery-image {
		transition: none;
	}

	.product-card:hover,
	.product-card:focus-visible {
		transform: none;
	}

	.product-card:hover .product-card__image,
	.product-card:focus-visible .product-card__image {
		transform: none;
	}

	.product-detail__cta:hover,
	.product-detail__cta:focus-visible {
		transform: none;
	}
}

/* ============================================================
   A. Trust bandeau (sous CTA single + sous hero archive)
   Voir .ombre-trust plus bas — classe générique partagée.
   Sur single product, on lui ajoute juste un margin top/bottom.
   ============================================================ */
.product-detail__content .ombre-trust {
	margin: var(--space-lg) 0 var(--space-xl);
}

/* ============================================================
   B. Tabs (Description / Caractéristiques / Personnalisation)
   Pleine largeur sous le layout gallery+content.
   ============================================================ */
.product-detail__tabs {
	margin-top: clamp(var(--space-2xl), 5vw, var(--space-3xl));
	padding-top: var(--space-xl);
	border-top: 1px solid var(--color-border);
}

.product-detail__tabs-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 4px;
	border-bottom: 1px solid var(--color-border);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.product-detail__tabs-list::-webkit-scrollbar {
	display: none;
}

.product-detail__tabs-tab {
	all: unset;
	cursor: pointer;
	padding: 12px 18px;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-text-muted);
	letter-spacing: 0.02em;
	white-space: nowrap;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color 0.2s, border-color 0.2s;
}

.product-detail__tabs-tab:hover,
.product-detail__tabs-tab:focus-visible {
	color: var(--color-text);
}

.product-detail__tabs-tab:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
	border-radius: 2px;
}

.product-detail__tabs-tab.is-active {
	color: var(--color-accent);
	border-bottom-color: var(--color-accent);
}

.product-detail__tabs-panel {
	padding-top: var(--space-lg);
}

.product-detail__tabs-panel:not(.is-active) {
	display: none;
}

.product-detail__tabs-panel .product-detail__description {
	color: var(--color-text-muted);
	line-height: 1.7;
}

.product-detail__tabs-panel .product-detail__description p {
	margin-bottom: var(--space-md);
}

.product-detail__tabs-panel .product-detail__description p:last-child {
	margin-bottom: 0;
}

/* Description en 2 colonnes sur écrans larges — meilleure lecture, comble le vide */
@media (min-width: 1024px) {
	.product-detail__tabs-panel .product-detail__description {
		max-width: none; /* override le 72ch utilisé en single column */
		column-count: 2;
		column-gap: clamp(var(--space-xl), 4vw, var(--space-2xl));
		column-rule: 1px solid var(--color-border);
	}

	.product-detail__tabs-panel .product-detail__description > * {
		break-inside: avoid-column;
	}

	.product-detail__tabs-panel .product-detail__description p:first-child,
	.product-detail__tabs-panel .product-detail__description h2:first-child,
	.product-detail__tabs-panel .product-detail__description h3:first-child {
		margin-top: 0;
	}
}

/* Caractéristiques : grille 2 colonnes sur écrans larges */
@media (min-width: 1024px) {
	.product-detail__tabs-panel .product-detail__attributes {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 0 var(--space-2xl);
	}
}

/* Personnalisation tab specifics */
.product-detail__personnalisation-intro {
	color: var(--color-text-muted);
	line-height: 1.65;
	margin: 0 0 var(--space-md);
	font-size: 0.95rem;
}

.product-detail__techniques {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 10px;
}

.product-detail__technique {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-size: 0.92rem;
	color: var(--color-text);
	font-weight: 500;
}

.product-detail__technique-icon {
	flex: 0 0 auto;
	color: var(--color-accent);
	display: inline-flex;
}

/* ============================================================
   C. Related products
   ============================================================ */
.product-related {
	padding-block: clamp(var(--space-2xl), 5vw, var(--space-3xl));
	background: var(--color-bg-alt, var(--color-bg));
	border-top: 1px solid var(--color-border);
	margin-top: clamp(var(--space-2xl), 5vw, var(--space-3xl));
}

.product-related__header {
	margin-bottom: var(--space-xl);
	text-align: left;
}

.product-related__eyebrow {
	font-size: 0.74rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 6px;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 12px;
}

.product-related__eyebrow::before {
	content: '';
	width: 28px;
	height: 2px;
	background: var(--color-accent);
}

.product-related__title {
	font-size: clamp(1.4rem, 2.5vw, 1.85rem);
	margin: 0;
	color: var(--color-text);
}

.product-related__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-lg);
}

@media (min-width: 600px) {
	.product-related__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 960px) {
	.product-related__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.product-related__item {
	display: flex;
	min-width: 0;
}

.product-related__item .product-card {
	width: 100%;
}

/* ============================================================
   Trust bandeau réutilisable (.ombre-trust)
   Utilisé dans archive-product.php et single-product.php
   ============================================================ */
.ombre-trust {
	list-style: none;
	margin: 0;
	padding: var(--space-md);
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-sm);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
}

@media (min-width: 720px) {
	.ombre-trust {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.ombre-trust__item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 4px;
	min-width: 0;
}

.ombre-trust__icon {
	flex: 0 0 auto;
	width: 38px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(var(--color-accent-rgb), 0.18);
	color: var(--color-accent);
}

/* Cas spécial : drapeau français — fond neutre pour préserver bleu/blanc/rouge */
.ombre-trust__item:has(.ombre-icon--flag-fr) .ombre-trust__icon {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
}

.ombre-trust__text {
	display: flex;
	flex-direction: column;
	min-width: 0;
	line-height: 1.25;
}

.ombre-trust__label {
	font-size: 0.86rem;
	font-weight: 700;
	color: var(--color-text);
}

.ombre-trust__sub {
	font-size: 0.74rem;
	color: var(--color-text-muted);
	margin-top: 2px;
}

/* Wrapper sur shop archive — espace entre hero et grid */
.shop-archive__trust-wrap {
	padding-top: var(--space-lg);
}

/* ============================================================
   Toolbar shop archive (result count + sort dropdown)
   ============================================================ */
.shop-archive__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border);
	min-width: 0;
}

.shop-archive__count {
	margin: 0;
	font-size: 0.92rem;
	color: var(--color-text-muted);
	font-feature-settings: "tnum";
	min-width: 0;
	flex: 1 1 auto;
}

.shop-archive__count-cat {
	color: var(--color-text);
	font-weight: 600;
}

.shop-archive__sort {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	margin: 0;
}

.shop-archive__sort-label {
	font-size: 0.85rem;
	color: var(--color-text-muted);
	white-space: nowrap;
}

.shop-archive__sort-select-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
}

.shop-archive__sort-select {
	appearance: none;
	-webkit-appearance: none;
	background: var(--color-surface);
	color: var(--color-text);
	border: 1px solid var(--color-border-strong, var(--color-border));
	border-radius: var(--radius-sm);
	padding: 9px 38px 9px 14px;
	font-family: inherit;
	font-size: 0.88rem;
	font-weight: 500;
	line-height: 1.3;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s;
}

.shop-archive__sort-select:hover {
	border-color: var(--color-text-muted);
}

.shop-archive__sort-select:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
	border-color: var(--color-accent);
}

.shop-archive__sort-chevron {
	position: absolute;
	right: 12px;
	pointer-events: none;
	color: var(--color-text-muted);
	display: inline-flex;
}

.shop-archive__sort-submit {
	background: var(--color-accent);
	color: #0d0d0d;
	border: none;
	border-radius: var(--radius-sm);
	padding: 9px 14px;
	cursor: pointer;
	font-weight: 600;
	font-size: 0.85rem;
}

@media (max-width: 600px) {
	.shop-archive__toolbar {
		flex-direction: column;
		align-items: stretch;
		gap: var(--space-sm);
	}
	.shop-archive__count {
		font-size: 0.85rem;
		line-height: 1.45;
	}
	.shop-archive__sort {
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.shop-archive__sort-select-wrap {
		flex: 1 1 auto;
	}
	.shop-archive__sort-select {
		width: 100%;
	}
}
