/**
 * Quiz Cadeaux Ado — styles front.
 * Tout est encapsulé sous .idf-quiz / .idf-result pour ne rien casser sur le thème.
 * Couleurs pilotées par des variables CSS (surchargées par les réglages / Elementor).
 */

/* Variables partagées par les deux contextes (quiz + page profil). */
.idf-quiz,
.idf-profil-products {
	--idf-primary: #ff4d8d;
	--idf-secondary: #7c5cff;
	--idf-bg: #ffffff;
	--idf-card: #f7f7fb;
	--idf-text: #1a1a2e;
	--idf-radius: 18px;
	--idf-shadow: 0 10px 30px rgba(20, 20, 50, 0.08);
	color: var(--idf-text);
	font-family: inherit;
	-webkit-font-smoothing: antialiased;
}

/* Chrome « carte » uniquement pour le quiz interactif. */
.idf-quiz {
	box-sizing: border-box;
	max-width: 640px;
	margin: 0 auto;
	padding: clamp(16px, 4vw, 28px);
	background: var(--idf-bg);
	border-radius: var(--idf-radius);
}

/* Sur la page profil : grille de produits centrée, sans carte. */
.idf-profil-products {
	max-width: 960px;
	margin: 36px auto;
}

.idf-quiz *,
.idf-quiz *::before,
.idf-quiz *::after,
.idf-profil-products *,
.idf-profil-products *::before,
.idf-profil-products *::after {
	box-sizing: border-box;
}

/* Respecte l'attribut [hidden] même si le thème impose un display sur button/div.
   (Sinon le loader « On calcule… » et le bouton Retour restent visibles.) */
.idf-quiz [hidden],
.idf-profil-products [hidden] {
	display: none !important;
}

/* ---------- Progression ---------- */
.idf-quiz__progress {
	margin-bottom: 22px;
}

.idf-quiz__progress-track {
	height: 8px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--idf-text) 10%, transparent);
	overflow: hidden;
}

.idf-quiz__progress-bar {
	height: 100%;
	width: 0;
	border-radius: 999px;
	background: var(--idf-secondary);
	transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.idf-quiz__progress-label {
	margin-top: 8px;
	font-size: 13px;
	font-weight: 600;
	opacity: 0.6;
	letter-spacing: 0.02em;
}

/* ---------- Questions ---------- */
.idf-quiz__form {
	border: 0;
	margin: 0;
	padding: 0;
}

.idf-quiz__question {
	border: 0;
	margin: 0;
	padding: 0;
	min-inline-size: auto; /* reset fieldset */
}

.idf-quiz__legend {
	display: block;
	width: 100%;
	float: none;
	font-size: clamp(20px, 5vw, 26px);
	font-weight: 800;
	line-height: 1.25;
	margin-bottom: 20px;
	padding: 0;
}

.idf-quiz__answers {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.idf-quiz__answer {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	text-align: left;
	padding: 16px 18px;
	font-size: 16px;
	font-weight: 600;
	/* !important : neutralise les styles de bouton du thème (fond au focus/active). */
	color: var(--idf-text) !important;
	background: var(--idf-card) !important;
	border: 2px solid transparent;
	border-radius: 14px;
	cursor: pointer;
	transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
	-webkit-tap-highlight-color: transparent;
	box-shadow: none;
}

/* Le focus/active ne doit PAS ressembler à une sélection : on garde le fond carte. */
.idf-quiz__answer:focus,
.idf-quiz__answer:active {
	background: var(--idf-card) !important;
	color: var(--idf-text) !important;
}

.idf-quiz__answer::before {
	content: "";
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	border: 2px solid color-mix(in srgb, var(--idf-text) 25%, transparent);
	transition: border-color 0.15s ease, background 0.15s ease;
}

@media (hover: hover) {
	.idf-quiz__answer:hover {
		transform: translateY(-2px);
		border-color: var(--idf-primary);
		box-shadow: var(--idf-shadow);
	}
}

.idf-quiz__answer:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--idf-primary) 50%, transparent);
	outline-offset: 2px;
}

.idf-quiz__answer.is-selected,
.idf-quiz__answer.is-selected:focus,
.idf-quiz__answer.is-selected:active {
	border-color: var(--idf-primary) !important;
	background: color-mix(in srgb, var(--idf-primary) 14%, var(--idf-card)) !important;
	color: var(--idf-text) !important;
}

.idf-quiz__answer.is-selected::before {
	border-color: var(--idf-primary);
	background: radial-gradient(circle, var(--idf-primary) 0 45%, transparent 50%);
}

/* ---------- Navigation / retour ---------- */
.idf-quiz__nav {
	margin-top: 18px;
}

.idf-quiz__back {
	border: 0;
	background: none;
	color: var(--idf-text);
	opacity: 0.6;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	padding: 6px 4px;
}

.idf-quiz__back:hover {
	opacity: 1;
}

/* ---------- Animations entre questions ---------- */
.idf-quiz[data-animation="fade"] .idf-quiz__question.is-active {
	animation: idf-fade 0.35s ease both;
}

.idf-quiz[data-animation="slide"] .idf-quiz__question.is-active {
	animation: idf-slide 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes idf-fade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes idf-slide {
	from { opacity: 0; transform: translateX(28px); }
	to   { opacity: 1; transform: translateX(0); }
}

/* ---------- Chargement ---------- */
.idf-quiz__loading {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 40px 0;
	font-weight: 600;
	opacity: 0.75;
}

.idf-quiz__spinner {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	border: 3px solid color-mix(in srgb, var(--idf-text) 15%, transparent);
	border-top-color: var(--idf-primary);
	animation: idf-spin 0.8s linear infinite;
}

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

/* ---------- Résultat ---------- */
.idf-result {
	--idf-accent: var(--idf-primary);
	animation: idf-fade 0.4s ease both;
}

.idf-result__head {
	display: flex;
	flex-direction: column;
	gap: 18px;
	align-items: center;
	text-align: center;
	margin-bottom: 28px;
}

.idf-result__media {
	width: 120px;
	height: 120px;
	flex: 0 0 auto;
}

.idf-result__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50%;
	box-shadow: var(--idf-shadow);
}

.idf-result__eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 12px;
	font-weight: 700;
	color: var(--idf-accent);
	margin: 0 0 4px;
}

.idf-result__title {
	font-size: clamp(26px, 6vw, 36px);
	font-weight: 800;
	margin: 0 0 10px;
	color: var(--idf-accent);
}

.idf-result__desc {
	font-size: 16px;
	line-height: 1.55;
	opacity: 0.85;
	margin: 0;
}

.idf-result__subtitle {
	font-size: 18px;
	font-weight: 800;
	margin: 0 0 16px;
}

/* ---------- Grille produits ---------- */
.idf-products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

.idf-product {
	display: flex;
	flex-direction: column;
	background: var(--idf-card);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: var(--idf-shadow);
	transition: transform 0.18s ease;
}

@media (hover: hover) {
	.idf-product:hover {
		transform: translateY(-3px);
	}
}

.idf-product__media {
	position: relative;
	aspect-ratio: 1 / 1;
	background: color-mix(in srgb, var(--idf-text) 5%, var(--idf-card));
}

.idf-product__media-link {
	display: block;
	width: 100%;
	height: 100%;
}

.idf-product__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.idf-product__noimg {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, color-mix(in srgb, var(--idf-primary) 18%, transparent), color-mix(in srgb, var(--idf-secondary) 18%, transparent));
}

.idf-product__badge {
	position: absolute;
	top: 10px;
	left: 10px;
	padding: 5px 10px;
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #fff;
	background: var(--idf-secondary);
	border-radius: 999px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.idf-product__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 14px 16px 16px;
	flex: 1;
}

.idf-product__title {
	font-size: 15px;
	font-weight: 700;
	margin: 0;
	line-height: 1.3;
}

.idf-product__desc {
	font-size: 13px;
	line-height: 1.45;
	opacity: 0.7;
	margin: 0;
}

.idf-product__cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 11px 14px;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	color: #fff;
	background: var(--idf-secondary);
	border-radius: 10px;
	transition: filter 0.15s ease, transform 0.15s ease;
}

.idf-product__cta:hover {
	filter: brightness(1.35);
	transform: translateY(-1px);
	color: #fff;
}

/* ---------- Erreurs / messages ---------- */
.idf-quiz-error {
	padding: 14px 16px;
	border-radius: 10px;
	background: #fff3f4;
	color: #b32d2e;
	border: 1px solid #f3c7c9;
	font-size: 14px;
}

.idf-quiz__retry {
	display: inline-block;
	margin-top: 16px;
	padding: 10px 18px;
	border: 2px solid var(--idf-primary);
	background: none;
	color: var(--idf-primary);
	font-weight: 700;
	border-radius: 999px;
	cursor: pointer;
}

/* ---------- Responsive ---------- */
@media (min-width: 520px) {
	.idf-products {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 760px) {
	.idf-result__head {
		flex-direction: row;
		text-align: left;
		align-items: center;
	}
	.idf-products {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ---------- Accessibilité : mouvement réduit ---------- */
@media (prefers-reduced-motion: reduce) {
	.idf-quiz *,
	.idf-result * {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}
}
