/**
 * Styles frontend du plugin Sifas Configurator.
 *
 * Note : la charte graphique (typo, couleurs Sifas) reste pilotée par le
 * thème enfant `hello-elementor-child`. Ce fichier ne contient que des
 * styles fonctionnels indispensables au plugin (positionnement, états,
 * micro-animations).
 *
 * Les couleurs des badges sont surchargeables directement via les
 * contrôles Elementor du widget — ce qui suit n'est qu'un fallback visuel.
 */

/* ============================================================== *
 *  Compteur de sélection (Phase 3)
 * ============================================================== */
.sifas-counter {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: inherit;
	line-height: 1;
}

.sifas-counter__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.sifas-counter__icon i,
.sifas-counter__icon svg {
	display: block;
}

.sifas-counter__badge {
	position: absolute;
	top: -6px;
	right: -10px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: #c9a26b;
	color: #fff;
	font-size: 11px;
	line-height: 18px;
	text-align: center;
	font-weight: 600;
	pointer-events: none;
	transition: transform 0.18s ease, opacity 0.18s ease;
	transform: scale(1);
	opacity: 1;
}

/* Comportement par défaut : pastille masquée si sélection vide.
   Le widget ajoute `.sifas-counter--show-zero` si l'option Elementor
   "Afficher la pastille à zéro" est activée. */
.sifas-counter.is-empty:not(.sifas-counter--show-zero) .sifas-counter__badge {
	transform: scale(0);
	opacity: 0;
}

/* Petit "pop" visuel quand la sélection vient d'être mise à jour
   et que la pastille passe de zéro à non-zéro. */
.sifas-counter.is-active .sifas-counter__badge {
	animation: sifas-counter-pop 0.32s ease;
}

@keyframes sifas-counter-pop {
	0%   { transform: scale(0.6); }
	50%  { transform: scale(1.18); }
	100% { transform: scale(1); }
}

/* ============================================================== *
 *  Configurateur produit (Step 4a)
 * ============================================================== */

.sifas-config {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: start;
}

.sifas-config--placeholder {
	display: block;
	padding: 24px;
	background: #f5f5f5;
	border: 1px dashed #999;
	border-radius: 4px;
	color: #666;
}

@media (max-width: 1023px) {
	.sifas-config {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	/* Sur mobile, la galerie remonte au-dessus du moodboard */
	.sifas-config__gallery {
		order: -1;
	}
}

.sifas-config__moodboard,
.sifas-config__gallery {
	min-width: 0;
}

/* Titre + description héritent du Theme Style Elementor via leurs classes
   (.elementor-heading-title, post_content via the_content filter). On n'écrit
   ici que les marges nécessaires pour intégrer ces blocs au-dessus du form,
   sans rien forcer côté typo / couleur. */
.sifas-config__title {
	margin: 0 0 10px;     /* 10px entre le titre et la description */
	padding: 0;
}

.sifas-config__description {
	margin: 0 0 40px;     /* 40px entre la description et le moodboard */
}

.sifas-config__description p {
	margin: 0 0 12px;
}

.sifas-config__description p:last-child {
	margin-bottom: 0;
}

.sifas-config__form {
	display: flex;
	flex-direction: column;
	gap: 32px;          /* espacement majeur entre sections */
}

/* ----- Section (reset complet du <fieldset>) ----- */
.sifas-config__section {
	border: 0;
	margin: 0;
	padding: 0;
	min-width: 0;       /* évite le min-width: min-content natif des fieldset */
	display: block;
}

.sifas-config__section-title {
	/* <legend> reset : on le sort du comportement natif et on le rend en bloc */
	display: block;
	width: 100%;
	float: none;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	margin: 0 0 14px;
	padding: 0;
	text-transform: uppercase;
}

.sifas-config__required {
	color: #c0392b;
	margin-left: 4px;
}

/* Sous-section (Coussin classique / Coussin premium) */
.sifas-config__subsection {
	margin: 0;
}

.sifas-config__subsection + .sifas-config__subsection {
	margin-top: 20px;   /* espacement clair entre classique et premium */
}

.sifas-config__subsection-title {
	font-size: 0.85rem;
	font-weight: 500;
	color: #555;
	margin: 0 0 10px;
	padding: 0;
}

/* ----- Swatches grid ----- */
.sifas-config__swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: flex-start;   /* alignement haut, évite tout calage vertical bizarre */
	margin: 0;
	padding: 0;
	list-style: none;
}

.sifas-config__swatch {
	position: relative;
	display: inline-flex;
	width: 40px;
	height: 40px;
	margin: 0;
	cursor: pointer;
	border-radius: 50%;
	transition: transform 0.15s ease;
	vertical-align: top;
}

.sifas-config__swatch:hover {
	transform: scale(1.08);
}

.sifas-config__swatch[hidden] {
	display: none;
}

/* Radio caché de manière accessible (technique "visually-hidden" standard a11y).
   On évite width:0/height:0/opacity:0 qui peuvent être surchargés par certains
   thèmes ou builders qui forcent l'affichage des inputs. */
.sifas-config__radio {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
	white-space: nowrap;
	pointer-events: none;
}

.sifas-config__swatch-img {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: #eee;
	transition: box-shadow 0.18s ease, border-color 0.18s ease;
}

.sifas-config__swatch-img--placeholder {
	background: repeating-linear-gradient(45deg, #eee, #eee 3px, #ddd 3px, #ddd 6px);
}

/* État sélectionné — la couleur du contour est surchargée par Elementor */
.sifas-config__radio:checked + .sifas-config__swatch-img {
	box-shadow: 0 0 0 2px #000;
	border-color: #000;
}

/* Focus clavier (accessibilité) */
.sifas-config__radio:focus-visible + .sifas-config__swatch-img {
	outline: 2px solid #4d90fe;
	outline-offset: 2px;
}

/* ----- Voir plus -----
   Sans bordure, léger padding interne pour la cliquabilité, fond gris très
   discret au survol pour le contraste. !important pour battre les styles
   génériques de bouton (Hello Elementor / Essential Addons / etc.). */
.sifas-config__more {
	background: transparent !important;
	border: 0 !important;
	border-radius: 3px !important;
	box-shadow: none !important;
	padding: 6px 10px !important;
	margin: 0 0 0 4px !important;
	color: #888 !important;
	font-size: 0.85rem;
	font-family: inherit;
	font-weight: 400;
	letter-spacing: normal;
	text-transform: none;
	text-decoration: none !important;
	cursor: pointer;
	transition: color 0.15s ease, background 0.15s ease;
	line-height: 1.2;
}

.sifas-config__more:hover,
.sifas-config__more:focus {
	color: #000 !important;
	background: rgba(0, 0, 0, 0.05) !important;
}

.sifas-config__more:focus-visible {
	outline: 2px solid #4d90fe;
	outline-offset: 2px;
}

/* ----- Bouton ajouter -----
   !important pour empêcher la couleur primaire du Theme Style (rose chez
   Sifas) de surcharger notre noir au repos ou au hover. */
.sifas-config__add {
	margin-top: 12px;
	padding: 14px 24px !important;
	background: #000 !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	cursor: pointer;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: opacity 0.18s ease, transform 0.1s ease;
	font-family: inherit;
	align-self: flex-start;
}

.sifas-config__add:hover,
.sifas-config__add:focus {
	background: #000 !important;
	color: #fff !important;
	opacity: 0.82;
}

.sifas-config__add:active {
	transform: translateY(1px);
}

/* ----- Feedback ----- */
.sifas-config__error {
	margin: 0;
	padding: 8px 12px;
	background: #fdecea;
	border-left: 3px solid #c0392b;
	color: #7a1c12;
	font-size: 0.875rem;
}

.sifas-config__success {
	margin: 0;
	padding: 8px 12px;
	background: #e8f5e9;
	border-left: 3px solid #2e7d32;
	color: #1b5e20;
	font-size: 0.875rem;
	opacity: 0;
	transform: translateY(-4px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.sifas-config__success.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ============================================================== *
 *  Galerie produit (Step 4b — version simplifiée : 1 image vedette)
 * ============================================================== */

.sifas-config__gallery {
	min-width: 0;
}

.sifas-config__gallery-item {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: #f5f5f5;
}

.sifas-config__gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Bouton overlay "Voir le produit en 3D" sur l'image vedette
   Forcé avec !important pour empêcher le hover de prendre la couleur primaire
   du Theme Style (souvent rose chez Sifas). */
.sifas-config__view-3d {
	position: absolute;
	bottom: 16px;
	right: 16px;
	display: inline-flex !important;
	align-items: center;
	gap: 8px;
	padding: 10px 16px !important;
	background: rgba(0, 0, 0, 0.85) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 999px !important;
	font-size: 0.85rem;
	letter-spacing: 0.04em;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.18s ease, transform 0.12s ease;
	backdrop-filter: blur(6px);
	box-shadow: none !important;
}

.sifas-config__view-3d:hover,
.sifas-config__view-3d:focus {
	background: rgba(0, 0, 0, 0.65) !important;  /* éclairci ~25% au survol */
	color: #fff !important;
}

.sifas-config__view-3d:active {
	transform: translateY(1px);
}

.sifas-config__view-3d-icon {
	font-size: 1.1rem;
	line-height: 1;
}

@media (max-width: 1023px) {
	.sifas-config__gallery-grid {
		gap: 8px;
	}
	.sifas-config__view-3d {
		bottom: 10px;
		right: 10px;
		padding: 8px 12px;
		font-size: 0.78rem;
	}
}

/* ============================================================== *
 *  Popup 3D (Step 4b)
 * ============================================================== */

/* Verrouillage du scroll quand popup ouverte */
body.sifas-config-popup-open {
	overflow: hidden;
}

.sifas-config__popup {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sifas-config__popup[hidden] {
	display: none;
}

/* Backdrop (overlay sombre derrière la popup). C'est un <button> pour
   l'a11y au clavier, donc il faut forcer les styles avec !important pour
   battre les règles globales <button> du Theme Style. */
.sifas-config__popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6) !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
	cursor: pointer;
	color: transparent !important;
	font-size: 0;
}

.sifas-config__popup-backdrop:hover,
.sifas-config__popup-backdrop:focus {
	background: rgba(0, 0, 0, 0.6) !important;
}

.sifas-config__popup-content {
	position: relative;
	z-index: 1;
	width: min(92vw, 1100px);
	max-height: 92vh;
	overflow: auto;
	background: #fff;
	border-radius: 6px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
	padding: 32px;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 32px;
	align-items: start;
}

@media (max-width: 1023px) {
	.sifas-config__popup-content {
		grid-template-columns: 1fr;
		padding: 20px;
		gap: 20px;
		max-height: 96vh;
	}
}

/* Bouton fermeture popup. Même problème : <button> capté par le Theme Style.
   On force tout avec !important + on dessine le X via pseudo-elements
   (parfaitement centré, pas de glyphe Unicode décalé). */
.sifas-config__popup-close {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 36px;
	height: 36px;
	background: transparent !important;
	border: 0 !important;
	border-radius: 50% !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
	font-size: 0 !important;     /* cache le "×" du HTML */
	line-height: 0;
	color: transparent !important;
	cursor: pointer;
	z-index: 2;
	font-family: inherit;
	transition: background 0.15s ease;
}

.sifas-config__popup-close::before,
.sifas-config__popup-close::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 14px;
	height: 1.5px;
	background: #555;
	transition: background 0.15s ease;
}

.sifas-config__popup-close::before {
	transform: translate(-50%, -50%) rotate(45deg);
}

.sifas-config__popup-close::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}

.sifas-config__popup-close:hover,
.sifas-config__popup-close:focus {
	background: rgba(0, 0, 0, 0.06) !important;
}

.sifas-config__popup-close:hover::before,
.sifas-config__popup-close:hover::after,
.sifas-config__popup-close:focus::before,
.sifas-config__popup-close:focus::after {
	background: #000;
}

.sifas-config__viewer {
	min-height: 400px;
	background: #fafafa;
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Le shortcode du plugin 3D Viewer génère son propre wrapper.
   On lui demande juste de remplir notre conteneur. */
.sifas-config__viewer > * {
	width: 100% !important;
	max-width: 100% !important;
}

.sifas-config__viewer model-viewer {
	width: 100%;
	height: 480px;
	background: transparent;
}

@media (max-width: 1023px) {
	.sifas-config__viewer model-viewer {
		height: 320px;
	}
}

/* Sur mobile pur (smartphone), le bloc 3D viewer occupe 50vh — adapté aux
 * écrans courts et permet un toucher confortable sans saturer la fold.
 * Le model-viewer interne suit en 100% du parent (override du 320px ci-dessus). */
@media (max-width: 600px) {
	.sifas-config__viewer {
		height: 50vh;
		min-height: 0;
	}
	.sifas-config__viewer model-viewer {
		height: 100%;
	}
}

.sifas-config__viewer-config {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.sifas-config__viewer-title {
	margin: 0;
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.sifas-config__viewer-section-title {
	margin: 0 0 10px;
	font-size: 0.82rem;
	color: #555;
	font-weight: 500;
}

.sifas-config__viewer-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: flex-start;
}

.sifas-config__viewer-swatch {
	position: relative;
	width: 44px;
	height: 44px;
	padding: 0 !important;
	border: 1px solid rgba(0, 0, 0, 0.12) !important;
	border-radius: 50% !important;
	overflow: hidden;
	background: #eee !important;
	box-shadow: none !important;
	cursor: pointer;
	transition: box-shadow 0.18s ease, transform 0.15s ease, border-color 0.18s ease;
}

.sifas-config__viewer-swatch img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sifas-config__viewer-swatch:hover {
	transform: scale(1.08);
}

.sifas-config__viewer-swatch.is-active {
	box-shadow: 0 0 0 2px #000 !important;
	border-color: #000 !important;
}

.sifas-config__viewer-swatch:focus-visible {
	outline: 2px solid #4d90fe;
	outline-offset: 2px;
}

/* ============================================================== *
 *  Page Ma sélection (Step 5a)
 * ============================================================== */

.sifas-selection {
	display: block;
}

.sifas-selection__title {
	margin: 0 0 32px;
	padding: 0;
}

.sifas-selection__layout {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 48px;
	align-items: start;
}

@media (max-width: 1023px) {
	.sifas-selection__layout {
		grid-template-columns: 1fr;
		gap: 32px;
	}
}

/* ----- Colonne récap ----- */
.sifas-selection__recap {
	min-width: 0;
}

.sifas-selection__items {
	display: flex;
	flex-direction: column;
}

.sifas-selection__empty {
	margin: 16px 0 0;
	padding: 24px;
	background: #fafafa;
	border: 1px dashed #ccc;
	border-radius: 4px;
	color: #555;
	text-align: center;
}

/* ----- Item individuel ----- */
.sifas-selection__item {
	display: grid;
	grid-template-columns: 120px 1fr auto auto;
	gap: 20px;
	align-items: center;
	padding: 20px 0;
	border-bottom: 1px solid #e0e0e0;
}

.sifas-selection__item:last-child {
	border-bottom: 0;
}

@media (max-width: 600px) {
	.sifas-selection__item {
		grid-template-columns: 80px 1fr auto;
		grid-template-areas:
			"image content delete"
			"image qty     qty";
		gap: 12px;
	}
	.sifas-selection__item-image { grid-area: image; }
	.sifas-selection__item-content { grid-area: content; }
	.sifas-selection__item-qty { grid-area: qty; justify-self: end; }
	.sifas-selection__delete { grid-area: delete; }
}

.sifas-selection__item-image {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: #f5f5f5;
	border-radius: 2px;
}

.sifas-selection__item-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sifas-selection__item-image-placeholder {
	display: block;
	width: 100%;
	height: 100%;
	background: repeating-linear-gradient(45deg, #eee, #eee 6px, #ddd 6px, #ddd 12px);
}

.sifas-selection__item-content {
	min-width: 0;
}

.sifas-selection__item-title {
	margin: 0 0 4px;
	font-size: 1.05rem;
	font-weight: 600;
}

.sifas-selection__item-title a {
	color: inherit;
	text-decoration: none;
}

.sifas-selection__item-title a:hover {
	text-decoration: underline;
}

.sifas-selection__item-ref {
	margin: 0 0 8px;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	color: #777;
	text-transform: uppercase;
}

.sifas-selection__components {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 0.875rem;
	color: #444;
}

.sifas-selection__component {
	display: flex;
	gap: 8px;
	padding: 2px 0;
}

.sifas-selection__component-section {
	min-width: 80px;
	font-weight: 500;
	color: #888;
}

.sifas-selection__component-value {
	flex: 1;
}

/* ----- Quantité ----- */
.sifas-selection__qty-label {
	display: flex;
	flex-direction: column;
	gap: 4px;
	align-items: flex-start;
}

.sifas-selection__qty-text {
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	color: #777;
	text-transform: uppercase;
}

.sifas-selection__item-qty input {
	width: 64px;
	padding: 6px 8px;
	border: 1px solid #ccc;
	border-radius: 2px;
	font-size: 0.95rem;
	text-align: center;
	font-family: inherit;
}

.sifas-selection__item-qty input:focus {
	outline: 2px solid #4d90fe;
	outline-offset: 1px;
}

/* ----- Bouton supprimer -----
   On masque le caractère "×" du HTML (font-size: 0) et on dessine un X
   parfait via deux pseudo-elements positionnés en absolu. C'est la seule
   façon d'avoir un X mathématiquement centré, le glyphe Unicode × étant
   décalé verticalement par sa baseline. */
.sifas-selection__delete {
	position: relative;
	width: 32px;
	height: 32px;
	padding: 0 !important;
	background: transparent !important;
	border: 1px solid #ccc !important;
	border-radius: 50% !important;
	font-size: 0 !important;          /* cache le "×" du HTML */
	line-height: 0;
	color: transparent !important;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease;
	font-family: inherit;
	box-shadow: none !important;
}

.sifas-selection__delete::before,
.sifas-selection__delete::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 12px;
	height: 1.5px;
	background: #888;
	transition: background 0.15s ease;
}

.sifas-selection__delete::before {
	transform: translate(-50%, -50%) rotate(45deg);
}

.sifas-selection__delete::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}

.sifas-selection__delete:hover,
.sifas-selection__delete:focus {
	border-color: #000 !important;
	background: transparent !important;
}

.sifas-selection__delete:hover::before,
.sifas-selection__delete:hover::after,
.sifas-selection__delete:focus::before,
.sifas-selection__delete:focus::after {
	background: #000;
}

.sifas-selection__delete:focus-visible {
	outline: 2px solid #4d90fe;
	outline-offset: 2px;
}

/* ----- Bouton PDF ----- */
.sifas-selection__pdf {
	margin: 24px 0 0;
	padding: 14px 28px !important;
	background: #000 !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	cursor: pointer;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-family: inherit;
	transition: opacity 0.18s ease;
}

.sifas-selection__pdf[hidden] {
	display: none;
}

.sifas-selection__pdf:hover,
.sifas-selection__pdf:focus {
	background: #000 !important;
	color: #fff !important;
	opacity: 0.82;
}

/* ----- Colonne formulaire ----- */
.sifas-selection__form-wrap[hidden] {
	display: none;
}

.sifas-selection__form-title {
	margin: 0 0 8px;
	font-size: 1.4rem;
	font-weight: 600;
}

.sifas-selection__form-intro {
	margin: 0 0 24px;
	color: #555;
}

.sifas-selection__form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.sifas-selection__form-row--two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

@media (max-width: 600px) {
	.sifas-selection__form-row--two {
		grid-template-columns: 1fr;
	}
}

.sifas-selection__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sifas-selection__field-label {
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #555;
}

.sifas-selection__field input,
.sifas-selection__field textarea {
	padding: 10px 12px !important;
	border: 1px solid #ccc !important;
	border-radius: 2px !important;
	font-size: 0.95rem;
	font-family: inherit;
	background: #fff !important;
	color: #333 !important;
	box-shadow: none !important;
}

.sifas-selection__field input:focus,
.sifas-selection__field textarea:focus {
	outline: 2px solid #4d90fe !important;
	outline-offset: 1px;
	border-color: #4d90fe !important;
}

.sifas-selection__field textarea {
	resize: vertical;
	min-height: 100px;
}

.sifas-selection__submit {
	margin-top: 8px;
	padding: 14px 24px !important;
	background: #000 !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	cursor: pointer;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-family: inherit;
	transition: opacity 0.18s ease;
	align-self: flex-start;
}

.sifas-selection__submit:hover:not(:disabled),
.sifas-selection__submit:focus:not(:disabled) {
	background: #000 !important;
	color: #fff !important;
	opacity: 0.82;
}

.sifas-selection__submit:disabled {
	cursor: not-allowed;
	opacity: 0.5;
	background: #000 !important;
	color: #fff !important;
}

/* ----- Feedback formulaire devis ----- */
.sifas-selection__form-error {
	margin: 0;
	padding: 10px 14px;
	background: #fdecea;
	border-left: 3px solid #c0392b;
	color: #7a1c12;
	font-size: 0.875rem;
}

.sifas-selection__form-success {
	margin: 0;
	padding: 12px 16px;
	background: #e8f5e9;
	border-left: 3px solid #2e7d32;
	color: #1b5e20;
	font-size: 0.95rem;
	font-weight: 500;
}

.sifas-selection__form-error[hidden],
.sifas-selection__form-success[hidden] {
	display: none;
}

/* On masque le honeypot via les styles inline, mais au cas où… */
.sifas-selection__honeypot {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

/* ============================================================== *
 *  Shortcode [sifas_products_grid] — grille de produits sur archive collection
 *  Reproduit fidèlement le rendu de l'ancien site (Divi-child).
 * ============================================================== */

.sifas-products__header {
	margin: 0 0 24px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

.sifas-products__count {
	font-size: 0.95rem;
	color: #555;
}

.sifas-products__count .count {
	font-weight: 700;
	color: #000;
}

.sifas-products__grid {
	display: grid;
	gap: 32px 24px;
	margin: 0 0 32px;
}

.sifas-products__grid--cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sifas-products__grid--cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.sifas-products__grid--cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 900px) {
	.sifas-products__grid--cols-3,
	.sifas-products__grid--cols-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.sifas-products__grid {
		grid-template-columns: 1fr !important;
	}
}

.sifas-product {
	display: flex;
	flex-direction: column;
	text-align: center;
}

.sifas-product__image-link {
	display: block;
	overflow: hidden;
	margin-bottom: 12px;
}

.sifas-product__image,
.sifas-product__image-link img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.4s ease;
}

.sifas-product__image-link:hover .sifas-product__image {
	transform: scale(1.03);
}

.sifas-product__image-placeholder {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	background: #f4f4f4;
}

.sifas-product__title {
	margin: 0 0 4px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.3;
}

.sifas-product__title a {
	color: inherit;
	text-decoration: none;
}

.sifas-product__title a:hover {
	text-decoration: underline;
}

.sifas-product__collection {
	margin: 0 0 8px;
	font-size: 0.8rem;
	color: #888;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.sifas-product__colors {
	display: flex;
	justify-content: center;
	margin-top: 6px;
}

.sifas-product__pastilles {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	justify-content: center;
}

.sifas-product__pastilles img {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid #ddd;
}

.sifas-products__pagination {
	margin-top: 24px;
	text-align: center;
}

.sifas-products__pagination ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: inline-flex;
	gap: 4px;
}

.sifas-products__pagination ul li a,
.sifas-products__pagination ul li span {
	display: inline-block;
	padding: 6px 12px;
	border: 1px solid #ddd;
	color: #333;
	text-decoration: none;
	font-size: 0.9rem;
}

.sifas-products__pagination ul li span.current {
	background: #000;
	color: #fff;
	border-color: #000;
}

.sifas-products__empty {
	padding: 32px;
	text-align: center;
	color: #888;
}

/* ============================================================== *
 *  Aperçu visuel des couleurs sélectionnées (moodboard preview)
 *  Reproduit la superposition en escalier de l'ancien site Divi-child.
 * ============================================================== */

.sifas-config__form-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 140px;
	gap: 24px;
	align-items: start;
	margin-bottom: 20px;
}

@media (max-width: 700px) {
	.sifas-config__form-layout {
		grid-template-columns: minmax(0, 1fr) 100px;
		gap: 16px;
	}
}

.sifas-config__preview {
	position: sticky;
	top: 20px;
	padding: 4px;
}

/* Chaque tile = un carré qui prend toute la largeur du conteneur preview.
 * Les tiles suivantes se chevauchent avec un décalage en escalier
 * (overlap haut + décalage horizontal), identique à l'ancien site. */
.sifas-config__preview-tile {
	width: 100%;
	aspect-ratio: 1 / 1;
	background: #f4f4f4;
	border: 1px solid #e0e0e0;
	overflow: hidden;
	position: relative;
	transition: border-color 0.2s ease;
}

.sifas-config__preview-tile:not(:first-child) {
	margin: -20% 0 0 15%;
}

.sifas-config__preview-tile.is-filled {
	border-color: #aaa;
	background: #fff;
}

/* Placeholder discret quand la tile est vide (avant choix) */
.sifas-config__preview-tile:not(.is-filled)::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		repeating-linear-gradient(
			45deg,
			transparent 0,
			transparent 7px,
			rgba(0,0,0,0.04) 7px,
			rgba(0,0,0,0.04) 8px
		);
}

.sifas-config__preview-tile img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ============================================================== *
 *  Carte revendeurs (page "Trouver un distributeur")
 *  Layout 50/50 desktop, stack mobile.
 * ============================================================== */

.sifas-revendeurs {
	font-family: inherit;
	color: #333;
}

/* --- Filtres --- */

.sifas-revendeurs__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 24px;
	padding: 0;
}

.sifas-revendeurs__filter {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 18px;
	background: #f4f4f4;
	border: 1px solid #e0e0e0;
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 500;
	color: #444;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
	font-family: inherit;
}

.sifas-revendeurs__filter:hover {
	background: #ebebeb;
	border-color: #ccc;
}

.sifas-revendeurs__filter.is-active {
	background: #2c2c2c;
	border-color: #2c2c2c;
	color: #fff;
}

.sifas-revendeurs__filter.is-empty {
	opacity: 0.45;
	cursor: not-allowed;
	pointer-events: none;
}

.sifas-revendeurs__filter-dot {
	display: inline-block;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	flex-shrink: 0;
}

.sifas-revendeurs__filter-count {
	font-size: 0.8em;
	opacity: 0.7;
}

/* --- Layout 2 colonnes --- */

.sifas-revendeurs__layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	align-items: start;
}

@media (max-width: 900px) {
	.sifas-revendeurs__layout {
		grid-template-columns: 1fr;
	}

	/* Sur mobile : carte d'abord, liste ensuite (ordre DOM inversé
	   uniquement visuellement, sans toucher au markup PHP). */
	.sifas-revendeurs__layout > .sifas-revendeurs__map-col {
		order: 1;
	}
	.sifas-revendeurs__layout > .sifas-revendeurs__list-scroll {
		order: 2;
	}
}

/* --- Colonne gauche : liste --- */

.sifas-revendeurs__list-scroll {
	overflow-y: auto;
	padding-right: 8px;
}

.sifas-revendeurs__list-scroll::-webkit-scrollbar { width: 8px; }
.sifas-revendeurs__list-scroll::-webkit-scrollbar-thumb { background: #ccc; border-radius: 4px; }
.sifas-revendeurs__list-scroll::-webkit-scrollbar-thumb:hover { background: #999; }

.sifas-revendeurs__list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

@media (max-width: 600px) {
	.sifas-revendeurs__list {
		grid-template-columns: 1fr;
	}
}

/* --- Card revendeur --- */

.sifas-revendeurs__card {
	position: relative;
	padding: 16px;
	background: #fff;
	/* !important nécessaire : Hello Elementor met border-color via currentColor
	   sur <article>, ce qui donne du noir/charbon hérité du body Sifas. */
	border: 1px solid #eaeaea !important;
	border-radius: 4px;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.sifas-revendeurs__card:hover {
	border-color: #cfcfcf !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.sifas-revendeurs__card.is-active {
	border-color: #c9a96e !important;
	box-shadow: 0 4px 12px rgba(201, 169, 110, 0.20);
}

.sifas-revendeurs__badge {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: var(--badge-color, #888);
	border-bottom: 2px solid var(--badge-color, #888);
	padding: 0 0 2px;
	margin: 0 0 10px;
}

.sifas-revendeurs__name {
	margin: 0 0 10px;
	font-size: 1.05rem;
	line-height: 1.3;
	color: #000;
	font-weight: 600;
}

/* Bloc localisation (adresse + cp/pays) : éléments collés sans gap */
.sifas-revendeurs__location {
	margin: 0 0 8px;
}

.sifas-revendeurs__addr,
.sifas-revendeurs__loc {
	margin: 0; /* pas de marge — collés au sein du .sifas-revendeurs__location */
	font-size: 0.9rem;
	line-height: 1.4;
	color: #555;
}

.sifas-revendeurs__loc {
	color: #888;
	font-size: 0.85rem;
}

/* Bloc contact : téléphone + email empilés, juste sous la localisation */
.sifas-revendeurs__contact {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.5;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.sifas-revendeurs__contact a {
	color: #333;
	text-decoration: none;
	transition: color 0.15s ease;
	word-break: break-word;
}

.sifas-revendeurs__contact a:hover {
	color: #c9a96e;
	text-decoration: underline;
}

/* --- Colonne droite : map --- */

.sifas-revendeurs__map-col {
	position: sticky;
	top: 20px;
}

.sifas-revendeurs__map {
	width: 100%;
	height: 700px;
	border-radius: 4px;
	overflow: hidden;
	border: 1px solid #e8e8e8;
}

@media (max-width: 900px) {
	.sifas-revendeurs__map-col {
		position: static;
	}
	.sifas-revendeurs__map {
		height: 450px;
	}
}

/* --- Markers Leaflet personnalisés (divIcon) --- */

.sifas-rev-marker {
	pointer-events: auto;
}

.sifas-rev-marker__pin {
	display: block;
	width: 18px;
	height: 18px;
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	border: 2px solid #fff;
	box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	transition: transform 0.15s ease;
}

.sifas-rev-marker:hover .sifas-rev-marker__pin {
	transform: rotate(-45deg) scale(1.15);
}

/* --- Popup Leaflet --- */

.leaflet-popup-content .sifas-rev-popup {
	font-family: inherit;
	min-width: 200px;
}

.sifas-rev-popup__name {
	display: block;
	font-size: 1rem;
	color: #000;
	margin-bottom: 4px;
}

.sifas-rev-popup__type {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 600;
	margin-bottom: 8px;
}

.sifas-rev-popup__addr {
	margin: 0 0 6px;
	font-size: 0.85rem;
	color: #555;
	line-height: 1.4;
}

.sifas-rev-popup__web {
	margin: 0;
	font-size: 0.85rem;
}

.sifas-rev-popup__web a {
	color: #c9a96e;
	text-decoration: none;
}

.sifas-rev-popup__web a:hover {
	text-decoration: underline;
}
