/**
 * Quiz "Trouvez votre destination idéale" — registre voyage luxe.
 *
 * Customisable via CSS variables :
 *   --clv-quiz-accent       : couleur de marque (boutons, accents)
 *   --clv-quiz-text         : couleur principale du texte
 *   --clv-quiz-muted        : couleur secondaire/atténuée
 *   --clv-quiz-bg-card      : fond des cartes de réponse
 *   --clv-quiz-bg-card-hover: fond hover/sélectionné
 *   --clv-quiz-font-size    : taille de base (par défaut 16px)
 *   --clv-quiz-radius       : arrondi des éléments
 */

/**
 * Hiérarchie de cascade (du plus prioritaire au moins prioritaire) :
 *   1. Override user : --clv-quiz-accent, etc. (défini dans le CSS additionnel WP)
 *   2. Elementor Global Colors / Typography : --e-global-color-primary, etc.
 *   3. Défauts neutres hardcodés
 */
.clv-quiz {
	--_accent:        var(--clv-quiz-accent,        var(--e-global-color-primary,   #1a3a5c));
	--_gold:          var(--clv-quiz-gold,          #C5B458);
	--_text:          var(--clv-quiz-text,          var(--e-global-color-text,      #1f2937));
	--_muted:         var(--clv-quiz-muted,         var(--e-global-color-secondary, #6b7280));
	--_bg-card:       var(--clv-quiz-bg-card,       #ffffff);
	--_bg-card-hover: var(--clv-quiz-bg-card-hover, #f4f5f7);
	--_border:        var(--clv-quiz-border,        #e5e7eb);
	--_font-size:     var(--clv-quiz-font-size,     16px);
	--_radius:        var(--clv-quiz-radius,        6px);

	/* Polices : Elementor Global Typography si défini, sinon hérite du thème */
	--_font-body:  var(--clv-quiz-font,       var(--e-global-typography-text-font-family,    inherit));
	--_font-title: var(--clv-quiz-font-title, var(--e-global-typography-primary-font-family, inherit));

	font-size: var(--_font-size) !important;
	font-family: var(--_font-body);
	line-height: 1.55;
	color: var(--_text);
	box-sizing: border-box;
	width: 100%;
	max-width: 760px;
	margin: 0 auto;
}

/* Titres : police "Primary" (titres) du site, distincte du texte courant */
.clv-quiz .clv-quiz-title,
.clv-quiz .clv-quiz-question,
.clv-quiz .clv-quiz-result-name {
	font-family: var(--_font-title);
}

.clv-quiz * { box-sizing: border-box; max-width: 100%; }

.clv-quiz-data { display: none !important; }

/* ----- Intro / start screen ----- */
.clv-quiz-intro {
	text-align: center;
	padding: 2.5rem 1.5rem;
}
.clv-quiz-intro .clv-quiz-title {
	font-family: 'Roca', var(--_font-title);
	font-size: 30px;
	font-weight: 200;
	line-height: 1;
	color: #1C2847;
	margin: 0 0 0.75rem;
}
.clv-quiz-intro .clv-quiz-subtitle {
	color: var(--_muted);
	margin-bottom: 2rem;
	font-size: 1em;
}

/* ----- Progression ----- */
.clv-quiz-progress {
	font-size: 16px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--_muted);
	margin-bottom: 0.6rem;
}
.clv-quiz-progress-bar {
	height: 2px;
	background: var(--_border);
	margin-bottom: 2rem;
	border-radius: 1px;
	overflow: hidden;
}
.clv-quiz-progress-bar-fill {
	height: 100%;
	background: var(--_accent);
	transition: width 0.4s ease;
}

/* ----- Question + réponses ----- */
.clv-quiz-question {
	font-family: 'Roca', var(--_font-title) !important;
	font-size: 1.5em;
	font-weight: 500;
	margin: 0 0 1.5rem;
	color: #1C2847;
	max-width: 100%;
	min-width: 0;
	white-space: normal;
	overflow-wrap: break-word;
	word-break: normal;
	hyphens: auto;
}
.clv-quiz-answers {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: grid;
	gap: 0.6rem;
	min-width: 0;
}
.clv-quiz-answer {
	list-style: none !important;
	padding: 0;
	margin: 0;
	min-width: 0;
}
.clv-quiz-answer button {
	box-sizing: border-box !important;
	display: block;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	text-align: left;
	padding: 1rem 1.2rem;
	background: var(--_bg-card);
	border: 1px solid var(--_border);
	border-radius: var(--_radius);
	font-family: inherit;
	font-size: 1em;
	color: #1C2847 !important;
	cursor: pointer;
	white-space: normal;
	word-break: normal;
	overflow-wrap: break-word;
	transition: border-color 0.2s ease, background 0.2s ease, transform 0.1s ease;
	touch-action: manipulation;
	user-select: none;
	-webkit-user-select: none;
	-webkit-tap-highlight-color: rgba(0,0,0,0.05);
}
.clv-quiz-answer .clv-quiz-answer-label {
	display: block;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	white-space: normal !important;
	word-break: normal !important;
	overflow-wrap: break-word !important;
	hyphens: auto;
}
@media (hover: hover) {
	.clv-quiz-answer button:hover {
		border-color: var(--_accent);
		background: #EDF0FE;
		color: #1C2847 !important;
	}
}
.clv-quiz-answer button.is-selected {
	border-color: var(--_accent);
	background: #EDF0FE;
	color: #1C2847 !important;
}

/* Neutralise le rouge/rose pâle hérité du thème global sur :active mobile
   et :focus clavier — on force le même bleu pastel que la sélection. */
.clv-quiz-answer button:active,
.clv-quiz-answer button:focus,
.clv-quiz-answer button:focus-visible {
	background: #EDF0FE !important;
	border-color: var(--_accent) !important;
	color: #1C2847 !important;
	outline: none;
}
.clv-quiz-answer button.is-disabled {
	opacity: 0.4;
	cursor: not-allowed;
}
.clv-quiz-answer button.is-disabled:hover {
	border-color: var(--_border);
	background: var(--_bg-card);
}

/* Hint sous une question multi (ex: "Choisissez 1 ou 2 réponses…") */
.clv-quiz-hint {
	font-size: 16px;
	color: var(--_muted);
	margin: -0.75rem 0 1.25rem;
	font-style: italic;
}

/* Badge "1" / "2" sur les cases d'une question multi avec weighted_order */
.clv-quiz-answers.is-multi .clv-quiz-answer button {
	position: relative;
	padding-left: 3rem;
}
.clv-quiz-badge {
	position: absolute;
	left: 1rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1.5rem;
	height: 1.5rem;
	border-radius: 50%;
	background: var(--_accent);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1em;
	font-weight: 700;
	flex-shrink: 0;
}

/* ----- Précédent (sans bouton Suivant) ----- */
.clv-quiz-nav-back {
	margin-top: 1.5rem;
	text-align: left;
}

/* Animation feedback de sélection */
.clv-quiz-answer-btn.is-selected {
	transform: scale(0.98);
}

/* ----- Boutons nav (legacy, encore utilisé pour intro/result) ----- */
.clv-quiz-nav {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2rem;
}
.clv-quiz-btn {
	font-family: inherit;
	font-size: 1em;
	font-weight: 600;
	letter-spacing: 0.04em;
	padding: 0.85em 1.6em;
	border-radius: 999px;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, transform 0.1s ease;
	border: 1px solid var(--_accent);
}
.clv-quiz-btn-primary {
	background: var(--_accent);
	color: #fff;
}
@media (hover: hover) {
	.clv-quiz-btn-primary:hover:not(:disabled) {
		background: var(--_gold) !important;
		border-color: var(--_gold) !important;
		color: #fff !important;
	}
}
.clv-quiz-btn-primary:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}
.clv-quiz-btn-secondary {
	background: transparent;
	color: var(--_accent);
}
.clv-quiz-btn-secondary:hover {
	background: var(--_bg-card-hover);
}

/* ----- Résultat ----- */
.clv-quiz-result {
	padding: 0 0 2rem;
}
.clv-quiz-result-match {
	display: inline-block;
	font-size: 1em;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--_accent);
	border: 1px solid var(--_accent);
	border-radius: 999px;
	padding: 0.35em 0.9em;
	margin-bottom: 1.2rem;
	font-weight: 600;
}

/* Image héro winner (featured image du CPT destination) */
.clv-quiz-result-image {
	margin: 1.5rem 0 2rem;
	border-radius: var(--_radius);
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: var(--_bg-card-hover);
}
.clv-quiz-result-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Conteneur du CTA primaire (placé en bas de page après case à cocher) */
.clv-quiz-result-ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1rem;
	align-items: center;
	justify-content: center;
	margin-top: 1rem;
}

/* Ligne header du winner : H2 nom à gauche, lien "Découvrir →" à droite */
.clv-quiz-result-headline-row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	margin: 0 0 0.4rem;
}
.clv-quiz-result-headline-row .clv-quiz-result-name {
	margin: 0;
}

/* Lien "Découvrir {île} →" placé à droite du H2 du winner */
.clv-quiz-result-discover-inline {
	margin: 0;
}
.clv-quiz-result-discover-inline a {
	font-size: 16px;
	color: var(--_accent);
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
	letter-spacing: 0.02em;
	transition: opacity 0.2s ease;
}
.clv-quiz-result-discover-inline a:hover { opacity: 0.65; }

/* Cartes "pépites" — format horizontal : image gauche + nom/tagline droite (centrés vertical) */
.clv-quiz-suggestion-card {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	text-decoration: none !important;
	color: inherit;
	padding: 0;
	overflow: hidden;
	background: var(--_bg-card);
	border: 1px solid var(--_border);
	border-radius: var(--_radius);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
@media (hover: hover) {
	.clv-quiz-suggestion-card:hover {
		transform: translateY(-2px);
		box-shadow: 0 8px 24px -10px color-mix(in srgb, var(--_text) 25%, transparent);
	}
}
.clv-quiz-suggestion-card.is-static { cursor: default; }
.clv-quiz-suggestion-card.is-static:hover {
	transform: none;
	box-shadow: none;
}
.clv-quiz-suggestion-image {
	flex: 0 0 50%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--_bg-card-hover);
}
.clv-quiz-suggestion-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}
.clv-quiz-suggestion-card:hover .clv-quiz-suggestion-image img {
	transform: scale(1.04);
}
.clv-quiz-suggestion-card.is-static:hover .clv-quiz-suggestion-image img {
	transform: none;
}
.clv-quiz-suggestion-body {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 0.85rem 1.1rem;
	min-width: 0;
}
.clv-quiz-result-eyebrow {
	font-size: 16px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #1C2847;
	margin-bottom: 0.5rem;
}
.clv-quiz-result-name {
	font-family: 'Roca', var(--_font-title) !important;
	font-size: 2.2em;
	font-weight: 600;
	color: #1C2847;
	margin: 0 0 0.4rem;
	line-height: 1.2;
}
.clv-quiz-result-tagline {
	font-size: 1.15em;
	color: #C5B458;
	margin-bottom: 1.5rem;
	font-style: italic;
}
.clv-quiz-result-description {
	font-size: 1em;
	line-height: 1.7;
	color: #1C2847;
	margin-bottom: 2rem;
}
.clv-quiz-result-highlights {
	background: #EDF0FE;
	border-left: 3px solid var(--_accent);
	padding: 1.5rem 1.5rem 1.5rem 1.75rem;
	border-radius: 0 var(--_radius) var(--_radius) 0;
	margin-bottom: 2rem;
}
.clv-quiz-result-highlights-title {
	font-size: 1em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--_accent);
	margin-bottom: 0.75rem;
}
.clv-quiz-result-highlights ul {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
.clv-quiz-result-highlights li {
	list-style: none !important;
	padding-left: 1.2rem;
	margin: 0.4rem 0;
	position: relative;
	font-size: 1em;
	color: #1C2847 !important;
}
.clv-quiz-result-highlights li::before {
	content: "—";
	position: absolute;
	left: 0;
	color: var(--_accent);
	opacity: 0.6;
}

/* ----- CTA principal ----- */
.clv-quiz-cta {
	display: inline-block;
	background: var(--_accent);
	color: #fff !important;
	font-weight: 600;
	letter-spacing: 0;
	padding: 1em 2em;
	border-radius: 999px;
	text-decoration: none !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
@media (hover: hover) {
	.clv-quiz-cta:hover {
		background: var(--_gold) !important;
		color: #fff !important;
		box-shadow: 0 8px 24px -8px color-mix(in srgb, var(--_gold) 40%, transparent);
	}
}

/* ----- Suggestions secondaires ----- */
.clv-quiz-suggestions {
	margin-top: 3rem;
}
.clv-quiz-suggestions-title {
	font-size: 1em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--_muted);
	margin-bottom: 1rem;
}
.clv-quiz-suggestions-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}
@media (max-width: 540px) {
	.clv-quiz-suggestions-grid {
		grid-template-columns: 1fr;
	}
}
.clv-quiz-suggestion-name {
	font-family: 'Roca', var(--_font-title) !important;
	font-size: 1.2em;
	font-weight: 500;
	color: #1C2847;
	margin-bottom: 0.2rem;
}
.clv-quiz-suggestion-tagline {
	font-size: 1em;
	color: #C5B458;
}

/* ----- Case "Ajouter #2 et #3 à ma demande" (placée juste AU-DESSUS du CTA primaire) ----- */
.clv-quiz-compare-toggle {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 0.6rem;
	margin: 1.75rem auto 0;
	max-width: 560px;
	font-size: 1em;
	line-height: 1.45;
	color: var(--_muted);
	cursor: pointer;
}
.clv-quiz-compare-toggle input[type="checkbox"] {
	flex-shrink: 0;
	width: 1rem;
	height: 1rem;
	margin: 0.2em 0 0;
	accent-color: var(--_accent);
	cursor: pointer;
}
.clv-quiz-compare-toggle:hover { color: var(--_text); }

/* Cartes alternatives compactes : pas de hover dramatique (pas de rivalité avec le CTA #1) */
.clv-quiz-suggestion-card.is-compact { cursor: default; }
.clv-quiz-suggestion-card.is-compact:hover {
	transform: none;
	box-shadow: none;
}

/* ----- Restart : lien simple souligné, centré sous le CTA ----- */
.clv-quiz-restart {
	margin-top: 1.5rem;
	text-align: center;
}
.clv-quiz-restart .clv-quiz-btn {
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	border-radius: 0 !important;
	color: #1C2847 !important;
	text-decoration: underline !important;
	text-underline-offset: 0.25em;
	font-weight: 400;
	font-size: 1em;
	letter-spacing: normal;
}
.clv-quiz-restart .clv-quiz-btn:hover {
	background: transparent !important;
	color: #1C2847 !important;
	opacity: 0.7;
}

/* Responsive */
@media (max-width: 640px) {
	.clv-quiz { font-size: 16px; }
	.clv-quiz-intro { padding: 1.5rem 1rem; }
	.clv-quiz-result-name { font-size: 1.7em; }
	.clv-quiz-nav { flex-direction: column-reverse; }
	.clv-quiz-btn { width: 100%; text-align: center; }
}

/* Bouton "Commencer le quiz" — en majuscules pour insister sur le CTA d'entrée. */
.clv-quiz-btn[data-action="start"] {
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
