/* =========================================================
   Tableau comparatif pour Elementor — rendu front.
   Desktop : grille « cartée ». Mobile : cartes empilées.
   Couleurs, arrondis, typos pilotés par variables CSS (--ecmp-*).
   ========================================================= */

.ecmp {
	--ecmp-cols: 3;
	--ecmp-radius: 16px;
	--ecmp-panel: #f6f7f9;
	--ecmp-card: #ffffff;
	--ecmp-border: rgba(17, 24, 39, 0.08);
	--ecmp-accent: #1b5fe0;
	--ecmp-accent-ink: #ffffff;
	--ecmp-yes: #16a34a;
	--ecmp-no: #ef4444;
	--ecmp-partial: #f59e0b;
	--ecmp-state-size: 24px;
	--ecmp-rowicon: var(--ecmp-accent);
	--ecmp-label: #1f2937;
	--ecmp-head-ink: #0f172a;
	--ecmp-head-gap: 18px;
	--ecmp-price: var(--ecmp-accent);
	--ecmp-caption: #6b7280;
	--ecmp-pulse-dur: 2.5s;
	display: block;
	width: 100%;
	min-height: 1px;
	overflow: visible;
}
.elementor-widget-ecmp-comparatif {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	overflow: visible !important;
}
.elementor-widget-ecmp-comparatif > .elementor-widget-container {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	overflow: visible !important;
	width: 100%;
}
.ecmp *,
.ecmp *::before,
.ecmp *::after { box-sizing: border-box; }

.ecmp .screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	white-space: nowrap;
	border: 0; padding: 0; margin: -1px;
}

/* ---- Bascule desktop / mobile (mobile-first) ------------ */
.ecmp__desktop { display: none; }
.ecmp__mobile { display: flex; flex-direction: column; gap: 16px; }

@media (min-width: 820px) {
	.ecmp__desktop { display: grid; }
	.ecmp__mobile { display: none; }
}

/* ========================= DESKTOP ======================= */
.ecmp__desktop {
	width: 100%;
	grid-template-columns: minmax(220px, 1.5fr) repeat(var(--ecmp-cols), minmax(120px, 1fr));
	column-gap: 16px;
	row-gap: 0;
	align-items: stretch;
}

/* Fonds (panneau gauche + colonne mise en avant) */
.ecmp__bg {
	z-index: 0;
	border-radius: var(--ecmp-radius);
	pointer-events: none;
}
.ecmp__bg--panel { background: var(--ecmp-panel); }
.ecmp__bg--hl {
	background: var(--ecmp-card);
	border: 2px solid var(--ecmp-accent);
	overflow: hidden;
	box-shadow: 0 18px 40px -20px rgba(27, 95, 224, 0.5);
}
@supports (color: color-mix(in srgb, red, blue)) {
	.ecmp__bg--hl { box-shadow: 0 18px 40px -20px color-mix(in srgb, var(--ecmp-accent) 55%, transparent); }
}
.ecmp-lift-yes .ecmp__bg--hl { margin-top: -14px; }

/* Animation « pulse » (légère, activable depuis Elementor) */
@keyframes ecmp-pulse {
	0%, 100% {
		box-shadow: 0 18px 40px -16px rgba(27, 95, 224, 0.45),
		            0 0 0 0 rgba(27, 95, 224, 0);
	}
	50% {
		box-shadow: 0 20px 44px -16px rgba(27, 95, 224, 0.55),
		            0 0 0 7px rgba(27, 95, 224, 0.15);
	}
}
@supports (color: color-mix(in srgb, red, blue)) {
	@keyframes ecmp-pulse {
		0%, 100% {
			box-shadow: 0 18px 40px -16px color-mix(in srgb, var(--ecmp-accent) 45%, transparent),
			            0 0 0 0 color-mix(in srgb, var(--ecmp-accent) 0%, transparent);
		}
		50% {
			box-shadow: 0 20px 44px -16px color-mix(in srgb, var(--ecmp-accent) 55%, transparent),
			            0 0 0 7px color-mix(in srgb, var(--ecmp-accent) 15%, transparent);
		}
	}
}
.ecmp-pulse-yes .ecmp__bg--hl,
.ecmp-pulse-yes .ecmp-card--hl {
	animation: ecmp-pulse var(--ecmp-pulse-dur, 2.5s) ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
	.ecmp-pulse-yes .ecmp__bg--hl,
	.ecmp-pulse-yes .ecmp-card--hl { animation: none; }
}

/* En-tête de colonne */
.ecmp__corner { z-index: 1; }
.ecmp__head-gap { height: var(--ecmp-head-gap); }
.ecmp__head {
	z-index: 1;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: 12px;
	min-height: 76px;
	padding: 22px 16px 18px;
	background: var(--ecmp-card);
	border: 1px solid var(--ecmp-border);
	border-radius: var(--ecmp-radius);
}
.ecmp__head--hl {
	z-index: 2;
	margin: 2px 2px 0;
	padding: 22px 18px;
	background: var(--ecmp-accent);
	border: 0;
	border-radius: calc(var(--ecmp-radius) - 4px) calc(var(--ecmp-radius) - 4px) 0 0;
	box-shadow: none;
}
.ecmp-lift-yes .ecmp__head--hl { margin-top: -12px; padding-top: 36px; min-height: 90px; }

.ecmp__hicon {
	flex: none;
	width: 40px; height: 40px;
	border-radius: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #eef2fb;
	color: var(--ecmp-accent);
}
@supports (background: color-mix(in srgb, red, blue)) {
	.ecmp__hicon { background: color-mix(in srgb, var(--ecmp-accent) 12%, #fff); }
}
.ecmp__hicon .dashicons { font-size: 22px; width: 22px; height: 22px; }
.ecmp__hname {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--ecmp-head-ink);
}
.ecmp__head--hl .ecmp__hname { color: var(--ecmp-accent-ink); }
.ecmp__head--hl .ecmp__hicon {
	background: rgba(255, 255, 255, 0.18);
	color: var(--ecmp-accent-ink);
}
.ecmp__logo { max-height: 34px; width: auto; max-width: 100%; object-fit: contain; }

/* Libellés (colonne de gauche) */
.ecmp__label {
	z-index: 1;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 15px 18px;
	border-top: 1px solid var(--ecmp-border);
	color: var(--ecmp-label);
}
.ecmp__label--first { border-top: 0; }
.ecmp__rowicon { display: inline-flex; color: var(--ecmp-rowicon); flex: none; }
.ecmp__rowicon .dashicons { font-size: 20px; width: 20px; height: 20px; }
.ecmp__rowtext { font-size: 15px; font-weight: 500; color: var(--ecmp-label); }
.ecmp__label--price .ecmp__rowtext { font-weight: 700; }

/* Cellules de valeur */
.ecmp__cell {
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 14px 12px;
	border-top: 1px solid var(--ecmp-border);
}
.ecmp__cell--first { border-top: 0; }
.ecmp__cell--hl {
	margin-inline: 2px;
	background: var(--ecmp-card);
}
.ecmp__cell--hl.ecmp__cell--first {
	border-top-color: transparent;
}

/* Ligne de prix */
.ecmp__price {
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 18px 12px 22px;
	border-top: 1px solid var(--ecmp-border);
	text-align: center;
}
.ecmp__price--hl {
	margin: 0 2px 2px;
	background: var(--ecmp-card);
	border-radius: 0 0 calc(var(--ecmp-radius) - 4px) calc(var(--ecmp-radius) - 4px);
}
.ecmp__pricev {
	font-size: 24px;
	font-weight: 800;
	letter-spacing: 1px;
	color: var(--ecmp-price);
}
.ecmp__pricec { font-size: 12px; line-height: 1.3; color: var(--ecmp-caption); }

/* Pictos d'état */
.ecmp-v { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.ecmp-v svg { width: var(--ecmp-state-size); height: var(--ecmp-state-size); display: block; }
.ecmp-v--yes { color: var(--ecmp-yes); }
.ecmp-v--no { color: var(--ecmp-no); }
.ecmp-v--partial { color: var(--ecmp-partial); }
.ecmp__txt { font-size: 14px; font-weight: 600; color: var(--ecmp-label); text-align: center; }

/* ========================= MOBILE ======================== */
.ecmp-card {
	background: var(--ecmp-card);
	border: 1px solid var(--ecmp-border);
	border-radius: var(--ecmp-radius);
	overflow: hidden;
}
.ecmp-card--hl {
	border: 2px solid var(--ecmp-accent);
	box-shadow: 0 16px 36px -18px rgba(27, 95, 224, 0.45);
}
@supports (color: color-mix(in srgb, red, blue)) {
	.ecmp-card--hl { box-shadow: 0 16px 36px -18px color-mix(in srgb, var(--ecmp-accent) 50%, transparent); }
}
.ecmp-card__head {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 16px 18px;
	border-bottom: 1px solid var(--ecmp-border);
}
.ecmp-card--hl .ecmp-card__head {
	background: var(--ecmp-accent);
	border-bottom-color: transparent;
}
.ecmp-card--hl .ecmp-card__head .ecmp__hname { color: var(--ecmp-accent-ink); }
.ecmp-card--hl .ecmp-card__head .ecmp__hicon {
	background: rgba(255, 255, 255, 0.18);
	color: var(--ecmp-accent-ink);
}
.ecmp-card__list { list-style: none; margin: 0; padding: 4px 18px; }
.ecmp-card__list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 11px 0;
	border-top: 1px solid var(--ecmp-border);
}
.ecmp-card__list li:first-child { border-top: 0; }
.ecmp-card__lbl {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--ecmp-label);
}
.ecmp-card__val { flex: none; }
.ecmp-card__price {
	display: flex;
	align-items: baseline;
	gap: 8px;
	padding: 14px 18px 18px;
	border-top: 1px solid var(--ecmp-border);
}
.ecmp-card__price .ecmp__pricev { font-size: 20px; }
.ecmp-card__price .ecmp__pricec { font-size: 12px; }

/* ---- État vide (éditeur Elementor) ---------------------- */
.ecmp-empty {
	padding: 20px;
	border: 1px dashed #c3c4c7;
	border-radius: 8px;
	color: #646970;
	text-align: center;
	font-size: 14px;
}
