/* ========================================================================
   Salam Muslim — Voyage (Phase 2)
   Styles dédiés aux pages /voyage/*. Classes préfixées smc-v… / smc-voyage…
   pour isolation. Réutilise les tokens globaux de main.css.
   Enqueue conditionnel : uniquement sur les LP /voyage/*.
   ======================================================================== */

.smc-voyage { background: var(--cream); color: var(--encre); font-family: var(--font-body); }
.smc-voyage__wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.smc-voyage a { text-decoration: none; }

/* ========================================================================
   IMAGE PLACEHOLDER (en attendant images réelles)
   ======================================================================== */
.smc-img-placeholder {
	background: linear-gradient(135deg, var(--cream-soft) 0%, var(--peau) 100%);
	border: 2px dashed rgba(184, 147, 92, 0.4);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	color: var(--olive-deep);
}
.smc-img-placeholder--hero { height: 520px; border-radius: 20px; width: 100%; }
.smc-img-placeholder--card { aspect-ratio: 16 / 9; min-height: 200px; }
.smc-img-placeholder--gallery { aspect-ratio: 1 / 1; min-height: 160px; }
.smc-img-placeholder--inline {
	aspect-ratio: 16 / 9; max-width: 720px; margin: 36px auto;
	width: 100%; min-height: 260px;
}
.smc-img-placeholder__inner {
	text-align: center;
	padding: 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	max-width: 80%;
}
.smc-img-placeholder__icon { font-size: 42px; opacity: 0.32; line-height: 1; }
.smc-img-placeholder__label {
	font-family: var(--font-display);
	font-size: 16px;
	font-style: italic;
	color: var(--olive-deep);
	opacity: 0.7;
}
.smc-img-placeholder__hint {
	font-size: 12px;
	color: var(--soft);
	opacity: 0.65;
	letter-spacing: 0.03em;
	line-height: 1.4;
}

/* ========================================================================
   AFFILIATE SLOT (kayak, booking, ivisa, getyourguide…)
   ======================================================================== */
.smc-affiliate {
	display: grid;
	grid-template-columns: 56px 1fr;
	gap: 20px;
	align-items: start;
	padding: 22px 24px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(184,147,92,0.08) 0%, rgba(184,147,92,0.02) 100%);
	border: 1.5px solid rgba(184, 147, 92, 0.3);
	margin: 32px 0;
	box-shadow: 0 3px 10px rgba(28,46,74,0.05);
	position: relative;
}
.smc-affiliate__icon {
	width: 56px; height: 56px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	background: linear-gradient(135deg, var(--or) 0%, var(--or-light) 100%);
	color: var(--cream);
	box-shadow: 0 4px 12px rgba(184, 147, 92, 0.28);
}
.smc-affiliate__body { min-width: 0; }
.smc-affiliate__kicker {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 6px;
}
.smc-affiliate__provider {
	font-size: 10.5px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--olive-deep);
}
.smc-affiliate__partner {
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--soft);
	padding: 2px 8px;
	background: rgba(184,147,92,0.15);
	border-radius: 10px;
}
.smc-affiliate__title {
	font-family: var(--font-display);
	font-size: 19px;
	font-weight: 500;
	color: var(--bleu);
	margin: 0 0 6px;
	line-height: 1.25;
}
.smc-affiliate__desc {
	font-size: 14.5px;
	line-height: 1.55;
	color: var(--soft);
	margin: 0 0 14px;
}
.smc-affiliate__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	background: var(--olive);
	color: var(--cream) !important;
	font-size: 13.5px;
	font-weight: 600;
	border-radius: 8px;
	letter-spacing: 0.02em;
	transition: all 0.3s ease;
}
.smc-affiliate__cta:hover { background: var(--bleu); gap: 12px; }

.smc-affiliate--featured {
	grid-template-columns: 72px 1fr;
	padding: 28px 32px;
	border-radius: 18px;
	background: linear-gradient(135deg, rgba(184,147,92,0.12) 0%, rgba(184,147,92,0.04) 100%);
	border: 1.5px solid rgba(184, 147, 92, 0.45);
}
.smc-affiliate--featured .smc-affiliate__icon { width: 72px; height: 72px; font-size: 36px; }
.smc-affiliate--featured .smc-affiliate__title { font-size: 22px; }

@media (max-width: 640px) {
	.smc-affiliate { grid-template-columns: 1fr; }
	.smc-affiliate__icon { margin: 0 auto; }
	.smc-affiliate__kicker, .smc-affiliate__body { text-align: center; }
	.smc-affiliate__kicker { justify-content: center; }
}

/* ========================================================================
   VOYAGE HERO — pleine largeur avec image + gradient + contenu gauche
   ======================================================================== */
.smc-vhero {
	position: relative;
	min-height: 560px;
	display: flex;
	align-items: center;
	padding: 80px 0;
	overflow: hidden;
	background: var(--bleu-deep);
}
.smc-vhero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.smc-vhero__bg .smc-img-placeholder {
	width: 100%; height: 100%;
	border-radius: 0;
	border: 0;
	opacity: 0.45;
}
.smc-vhero__img {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}
.smc-vhero__gradient {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		100deg,
		rgba(20, 34, 58, 0.96) 0%,
		rgba(20, 34, 58, 0.85) 40%,
		rgba(20, 34, 58, 0.5) 75%,
		rgba(20, 34, 58, 0.2) 100%);
}
.smc-vhero__wrap {
	position: relative;
	z-index: 1;
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 32px;
	width: 100%;
}
.smc-vhero__crumbs {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	font-size: 13px;
	color: rgba(247, 241, 227, 0.72);
	margin-bottom: 22px;
}
.smc-vhero__crumbs a { color: var(--or-light) !important; text-decoration: none !important; }
.smc-vhero__crumbs a:hover { color: var(--cream) !important; }
.smc-vhero__crumbs-sep { color: rgba(184, 147, 92, 0.6); }
.smc-vhero__crumbs-current { color: var(--cream); font-weight: 500; }

.smc-vhero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-size: 12px;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--or-light);
	margin-bottom: 22px;
}
.smc-vhero__eyebrow::before {
	content: '';
	width: 36px; height: 1px;
	background: var(--or);
}
/* NUCLEAR RESET hero voyage — vaincre cascade Elementor qui applique
   --e-global-color-primary (#212121) sur les H1 via héritage. Sans !important
   ici, le titre "Préparer son Omra :" reste en gris foncé quasi invisible
   sur le fond bleu nuit. Leçon tirée de la cascade sur cross-sell (cf MEMORY). */
.smc-voyage .smc-vhero *,
.smc-voyage .smc-vhero *::before,
.smc-voyage .smc-vhero *::after { color: inherit !important; }
.smc-voyage .smc-vhero { color: var(--cream) !important; }

.smc-voyage .smc-vhero__title,
.smc-lp .smc-vhero__title {
	font-family: var(--font-display) !important;
	font-size: clamp(38px, 5vw, 60px);
	line-height: 1.08;
	letter-spacing: -0.025em;
	font-weight: 500;
	color: var(--cream) !important;
	margin: 0 0 20px !important;
	max-width: 820px;
	text-shadow: 0 2px 16px rgba(0,0,0,0.35);
}
.smc-voyage .smc-vhero__title em,
.smc-lp .smc-vhero__title em {
	display: inline;
	font-style: italic;
	font-weight: 400;
	color: var(--or-light) !important;
}
.smc-voyage .smc-vhero__subtitle,
.smc-lp .smc-vhero__subtitle {
	font-family: var(--font-display) !important;
	font-style: italic;
	font-size: 19px;
	color: rgba(247, 241, 227, 0.95) !important;
	margin: 0 0 22px;
	max-width: 680px;
	text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}
.smc-voyage .smc-vhero__lede,
.smc-lp .smc-vhero__lede {
	font-size: 16.5px;
	line-height: 1.7;
	color: rgba(247, 241, 227, 0.85) !important;
	max-width: 660px;
	text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.smc-voyage .smc-vhero__lede p,
.smc-lp .smc-vhero__lede p { color: rgba(247, 241, 227, 0.85) !important; }
.smc-voyage .smc-vhero__lede strong,
.smc-lp .smc-vhero__lede strong { color: var(--cream) !important; font-weight: 600; }
.smc-voyage .smc-vhero__lede a,
.smc-lp .smc-vhero__lede a { color: var(--or-light) !important; }
.smc-vhero__lede p { margin: 0 0 14px; }
.smc-vhero__lede p:last-child { margin-bottom: 0; }
.smc-vhero__lede strong { color: var(--cream); font-weight: 600; }
.smc-vhero__lede a { color: var(--or-light) !important; text-decoration: underline !important; text-decoration-color: rgba(184,147,92,0.4) !important; text-underline-offset: 3px; }
.smc-vhero__lede a:hover { text-decoration-color: var(--or-light) !important; }

@media (max-width: 768px) {
	.smc-vhero { min-height: 460px; padding: 56px 0; }
	.smc-vhero__gradient { background: linear-gradient(to bottom, rgba(20,34,58,0.92) 0%, rgba(20,34,58,0.82) 100%); }
}

/* ========================================================================
   VOYAGE NAVIGATION CARDS (CTA primary des hubs)
   ======================================================================== */
.smc-vnav {
	background: var(--cream-soft);
	padding: 72px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.smc-vnav__wrap { max-width: 1100px; margin: 0 auto; padding: 0 32px; }
.smc-vnav__head { text-align: center !important; margin-bottom: 44px; display: flex; flex-direction: column; align-items: center; }
.smc-vnav__head > * { text-align: center !important; }
.smc-vnav__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-size: 11.5px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--olive-deep);
	margin-bottom: 16px;
}
.smc-vnav__eyebrow::before,
.smc-vnav__eyebrow::after {
	content: '';
	width: 34px; height: 1px;
	background: var(--olive);
}
.smc-vnav__title {
	font-family: var(--font-display);
	font-size: clamp(28px, 3.4vw, 38px);
	line-height: 1.18;
	font-weight: 500;
	color: var(--bleu);
	margin: 0 0 12px;
	letter-spacing: -0.018em;
}
.smc-vnav__title em { font-style: italic; color: var(--olive-deep); font-weight: 400; }
.smc-vnav__subtitle {
	font-size: 16px;
	color: var(--soft);
	max-width: 620px;
	margin: 0 auto;
	line-height: 1.6;
}
.smc-vnav__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}
.smc-voyage a.smc-vnav__card,
.smc-voyage a.smc-vnav__card:link,
.smc-voyage a.smc-vnav__card:visited,
.smc-voyage a.smc-vnav__card:hover {
	display: grid;
	grid-template-columns: 52px 1fr;
	gap: 20px;
	align-items: center;
	padding: 28px 28px;
	background: var(--cream) !important;
	border: 1.5px solid rgba(184, 147, 92, 0.4) !important;
	border-radius: 16px;
	color: var(--encre) !important;
	text-decoration: none !important;
	transition: all 0.35s cubic-bezier(.2,.7,.2,1);
	box-shadow: 0 2px 6px rgba(28,46,74,0.05);
	position: relative;
	overflow: hidden;
}
.smc-voyage a.smc-vnav__card::before {
	content: '';
	position: absolute; top: 0; left: 0;
	width: 100%; height: 3px;
	background: linear-gradient(90deg, var(--olive) 0%, var(--or) 100%);
	transform: scaleX(0); transform-origin: left;
	transition: transform 0.4s ease;
}
.smc-voyage a.smc-vnav__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 32px rgba(28,46,74,0.12) !important;
	border-color: var(--or) !important;
	background: #FDFBF4 !important;
}
.smc-voyage a.smc-vnav__card:hover::before { transform: scaleX(1); }

.smc-vnav__card-icon {
	width: 52px; height: 52px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--peau) 0%, var(--cream-soft) 100%);
	border: 1px solid var(--line);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	transition: all 0.35s ease;
	color: var(--olive-deep);
}
.smc-voyage a.smc-vnav__card:hover .smc-vnav__card-icon {
	background: linear-gradient(135deg, var(--olive) 0%, var(--olive-deep) 100%);
	border-color: var(--olive);
	color: var(--cream);
	transform: rotate(-3deg) scale(1.05);
}
.smc-vnav__card-body { min-width: 0; }
.smc-vnav__card-title {
	font-family: var(--font-display) !important;
	font-size: 19px !important;
	font-weight: 500 !important;
	color: var(--bleu) !important;
	margin: 0 0 4px !important;
	line-height: 1.25;
	letter-spacing: -0.01em;
}
.smc-vnav__card-desc {
	font-size: 13.5px !important;
	line-height: 1.5;
	color: var(--soft) !important;
	margin: 0 !important;
}
.smc-vnav__card-cta {
	grid-column: 1 / -1;
	font-size: 11.5px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--olive-deep) !important;
	margin-top: 6px;
	transition: color 0.3s ease;
}
.smc-voyage a.smc-vnav__card:hover .smc-vnav__card-cta { color: var(--bleu) !important; }

@media (max-width: 720px) {
	.smc-vnav__grid { grid-template-columns: 1fr; }
	.smc-vnav { padding: 56px 0; }
}

/* ========================================================================
   STRUCTURE LP VOYAGE — sections génériques
   ======================================================================== */
.smc-voyage-section {
	padding: 88px 0;
}
.smc-voyage-section--alt {
	background: var(--cream-soft);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.smc-voyage-section--peau {
	background: var(--peau);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.smc-voyage-section__inner {
	max-width: 820px;
	margin: 0 auto;
	padding: 0 32px;
}
.smc-voyage-section__inner--wide {
	max-width: 1100px;
}

.smc-voyage-section h2 {
	font-family: var(--font-display);
	font-size: clamp(28px, 3.2vw, 36px);
	line-height: 1.2;
	font-weight: 500;
	color: var(--bleu);
	letter-spacing: -0.02em;
	position: relative;
	padding-bottom: 14px;
	margin: 0 0 20px;
}
.smc-voyage-section h2::after {
	content: '';
	display: block;
	position: absolute;
	bottom: 0; left: 0;
	width: 56px; height: 3px;
	background: linear-gradient(90deg, var(--or) 0%, var(--or-light) 100%);
	border-radius: 2px;
}
.smc-voyage-section h2 em { font-style: italic; color: var(--olive-deep); font-weight: 400; }

.smc-voyage-section h3 {
	font-family: var(--font-display);
	font-size: 22px;
	font-weight: 500;
	color: var(--bleu);
	margin: 2rem 0 .75rem;
	letter-spacing: -0.01em;
}
.smc-voyage-section p {
	font-size: 16.5px;
	line-height: 1.75;
	color: var(--encre);
	margin: 0 0 18px;
}
.smc-voyage-section p strong { color: var(--bleu); font-weight: 600; }
.smc-voyage-section p a {
	color: var(--olive-deep) !important;
	text-decoration: underline !important;
	text-decoration-color: rgba(107, 127, 63, 0.35) !important;
	text-underline-offset: 3px;
	transition: text-decoration-color 0.2s;
}
.smc-voyage-section p a:hover { text-decoration-color: var(--olive) !important; }
.smc-voyage-section ul,
.smc-voyage-section ol {
	padding-left: 1.5rem;
	margin: 0 0 1.5rem;
}
.smc-voyage-section ul li,
.smc-voyage-section ol li {
	margin-bottom: 0.65rem;
	line-height: 1.65;
	font-size: 16px;
}
.smc-voyage-section ul li strong,
.smc-voyage-section ol li strong { color: var(--bleu); }
.smc-voyage-section ul li::marker { color: var(--olive); }
.smc-voyage-section ol li::marker { color: var(--or); font-weight: 700; }

/* Tableaux stylisés */
.smc-voyage-section table,
.smc-voyage-table {
	width: 100%;
	border-collapse: collapse;
	margin: 28px 0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 14px rgba(28,46,74,0.06);
	font-size: 15px;
}
.smc-voyage-section table thead,
.smc-voyage-table thead {
	background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-soft) 100%);
}
.smc-voyage-section table th,
.smc-voyage-table th {
	color: var(--cream);
	font-family: var(--font-display);
	font-weight: 500;
	padding: 14px 18px;
	text-align: left;
	letter-spacing: 0.01em;
}
.smc-voyage-section table td,
.smc-voyage-table td {
	padding: 14px 18px;
	border-bottom: 1px solid var(--line);
	background: var(--cream-soft);
	vertical-align: top;
}
.smc-voyage-section table tr:nth-child(even) td,
.smc-voyage-table tr:nth-child(even) td { background: var(--cream); }
.smc-voyage-section table td strong,
.smc-voyage-table td strong { color: var(--olive-deep); }

/* ========================================================================
   ORNEMENT ٭ ٭ ٭ entre sections voyage
   ======================================================================== */
.smc-voyage-ornament {
	text-align: center;
	color: var(--or);
	font-size: 20px;
	letter-spacing: .5em;
	opacity: 0.6;
	margin: 32px 0;
}

/* ========================================================================
   VOYAGE "POURQUOI" CARDS — 4 cards argumentaires, layout vertical.
   Icône au-dessus du titre, bien détachée, cohérent avec l'inspiration
   des maquettes éditoriales premium (pas en ligne horizontale).
   ======================================================================== */
.smc-voyage-why {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	margin: 40px 0 8px;
}
.smc-voyage-why__card {
	background: var(--cream-soft);
	border: 1.5px solid rgba(184, 147, 92, 0.35);
	border-radius: 16px;
	padding: 28px 26px 24px;
	box-shadow: 0 1px 2px rgba(28,46,74,0.04), 0 4px 14px rgba(28,46,74,0.06);
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.smc-voyage-why__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 2px 4px rgba(28,46,74,0.06), 0 10px 22px rgba(28,46,74,0.09);
}
.smc-voyage-why__icon {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--peau) 0%, var(--cream) 100%);
	border: 1px solid var(--line);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	line-height: 1;
	color: var(--olive-deep);
	margin-bottom: 24px;             /* respiration entre icône et titre */
	box-shadow: 0 2px 6px rgba(77, 94, 43, 0.08);
}
.smc-voyage-why__title {
	font-family: var(--font-display) !important;
	font-size: 20px !important;
	font-weight: 500 !important;
	color: var(--bleu) !important;
	line-height: 1.25;
	letter-spacing: -0.01em;
	margin: 0 0 10px !important;
}
.smc-voyage-why__desc {
	font-family: var(--font-body);
	font-size: 15px !important;
	line-height: 1.6;
	color: var(--encre) !important;
	margin: 0 !important;
}
.smc-voyage-why__desc strong { color: var(--bleu) !important; font-weight: 600; }
.smc-voyage-why__desc a {
	color: var(--olive-deep) !important;
	text-decoration: underline !important;
	text-decoration-color: rgba(107,127,63,0.35) !important;
	text-underline-offset: 3px;
}
.smc-voyage-why__desc a:hover { text-decoration-color: var(--olive) !important; }

@media (max-width: 720px) {
	.smc-voyage-why { grid-template-columns: 1fr; gap: 16px; }
}


/* ========================================================================
   COMPARATIF CARD (Omra vs Hajj style)
   ======================================================================== */
.smc-voyage-compare {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	margin: 40px 0;
}
.smc-voyage-compare__item {
	padding: 28px 30px;
	border-radius: 16px;
	background: var(--cream-soft);
	border: 1.5px solid rgba(184, 147, 92, 0.35);
}
.smc-voyage-compare__item--dark {
	background: linear-gradient(135deg, var(--bleu-deep) 0%, var(--bleu) 100%);
	border-color: rgba(184, 147, 92, 0.4);
	color: var(--cream);
}
.smc-voyage-compare__item h3 {
	font-family: var(--font-display);
	font-size: 24px;
	margin: 0 0 18px;
	color: inherit;
}
.smc-voyage-compare__item ul { list-style: none; padding: 0; margin: 0; }
.smc-voyage-compare__item li {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid rgba(217, 207, 184, 0.4);
	font-size: 14.5px;
}
.smc-voyage-compare__item--dark li { border-bottom-color: rgba(184, 147, 92, 0.2); }
.smc-voyage-compare__item li strong { color: inherit; font-weight: 600; }

@media (max-width: 720px) { .smc-voyage-compare { grid-template-columns: 1fr; } }

/* ========================================================================
   GALERIE BAS DE PAGE (placeholders carrés)
   ======================================================================== */
.smc-voyage-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
	margin: 32px 0;
}

/* ========================================================================
   RESPONSIVE GLOBAL
   ======================================================================== */
@media (max-width: 768px) {
	.smc-voyage-section { padding: 56px 0; }
	.smc-voyage-section__inner { padding: 0 24px; }
	.smc-voyage__wrap { padding: 0 24px; }
	.smc-img-placeholder--hero { height: 320px; }
	.smc-img-placeholder--inline { margin: 24px auto; min-height: 180px; }
}

/* ============================================================
   CTA Booking Placeholder (renforcement 2026-04-19)
   Composant réutilisable pour futurs liens affiliés Booking/Travelpayouts
   ============================================================ */
.smc-voyage .smc-cta-booking {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-deep) 100%);
	color: var(--cream) !important;
	border: 1px solid var(--or);
	border-radius: var(--radius-lg, 16px);
	padding: 24px 28px;
	margin: 32px 0;
	box-shadow: var(--shadow-md, 0 4px 16px rgba(28, 46, 74, 0.08));
	position: relative;
	overflow: hidden;
	max-width: 100%;
	box-sizing: border-box;
	flex-wrap: wrap;
}
.smc-voyage .smc-cta-booking::before {
	content: "";
	position: absolute; inset: 0;
	background: radial-gradient(circle at 10% 20%, rgba(184, 147, 92, 0.15) 0%, transparent 50%);
	pointer-events: none;
}
.smc-voyage .smc-cta-booking__icon {
	flex-shrink: 0;
	width: 64px; height: 64px;
	display: flex; align-items: center; justify-content: center;
	font-size: 34px;
	background: rgba(184, 147, 92, 0.18);
	border-radius: 50%;
	border: 2px solid var(--or);
}
.smc-voyage .smc-cta-booking__content {
	flex: 1 1 auto;
	min-width: 0;
	position: relative;
	z-index: 1;
	max-width: 100%;
}
.smc-voyage .smc-cta-booking__title {
	font-family: var(--font-display);
	font-size: 1.35rem;
	color: var(--cream) !important;
	margin: 0 0 8px;
	font-weight: 600;
	word-break: break-word;
	overflow-wrap: break-word;
}
.smc-voyage .smc-cta-booking__desc {
	color: rgba(247, 241, 227, 0.85) !important;
	margin: 0 0 16px;
	font-size: 0.95rem;
	line-height: 1.5;
	word-break: break-word;
	overflow-wrap: break-word;
}
.smc-voyage .smc-cta-booking__button {
	display: inline-flex;
	align-items: center; gap: 8px;
	background: var(--or);
	color: var(--bleu-deep) !important;
	font-family: var(--font-body);
	font-weight: 600;
	padding: 11px 22px;
	border-radius: 999px;
	text-decoration: none !important;
	transition: all 0.2s ease;
	border: 2px solid var(--or);
	cursor: pointer;
	font-size: 0.95rem;
	max-width: 100%;
	box-sizing: border-box;
	text-align: center;
	flex-wrap: wrap;
	justify-content: center;
}
.smc-voyage .smc-cta-booking__button > span {
	word-break: break-word;
	overflow-wrap: break-word;
}
.smc-voyage .smc-cta-booking__button:hover {
	background: var(--or-light);
	border-color: var(--or-light);
	transform: translateX(4px);
	color: var(--bleu-deep) !important;
}
.smc-voyage .smc-cta-booking__button svg { flex-shrink: 0; }
.smc-voyage .smc-cta-booking__micro {
	display: block;
	font-size: 0.75rem;
	color: rgba(247, 241, 227, 0.55);
	margin-top: 10px;
	font-style: italic;
}

/* Variantes */
.smc-voyage .smc-cta-booking--hero {
	margin-top: 20px;
	margin-bottom: 32px;
	padding: 28px 32px;
	align-items: center;
	/* Constrain hero CTA à la même largeur que .smc-voyage-section__inner (820px)
	   même quand le template oublie le wrapper section — centrage propre (2026-04-22) */
	max-width: 820px;
	margin-left: auto;
	margin-right: auto;
}
.smc-voyage .smc-cta-booking--hero .smc-cta-booking__title { font-size: 1.5rem; }

/* Hero CTA — layout banner desktop : icône | titre+desc | bouton droite (2026-04-22)
   Utilise CSS Grid sur __content pour placer titre/desc à gauche et bouton à droite,
   sans toucher au HTML (rétrocompat avec les 17 templates). */
.smc-voyage .smc-cta-booking--hero .smc-cta-booking__content {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	column-gap: 24px;
	row-gap: 4px;
	align-items: center;
	width: 100%;
}
.smc-voyage .smc-cta-booking--hero .smc-cta-booking__title {
	grid-column: 1;
	grid-row: 1;
	margin: 0;
}
.smc-voyage .smc-cta-booking--hero .smc-cta-booking__desc {
	grid-column: 1;
	grid-row: 2;
	margin: 0;
}
.smc-voyage .smc-cta-booking--hero .smc-cta-booking__button {
	grid-column: 2;
	grid-row: 1 / span 2;
	align-self: center;
	white-space: nowrap;
	flex-wrap: nowrap;
	width: auto;
	justify-content: center;
	text-align: center;
}

/* Mobile : stack vertical (titre+desc au-dessus, bouton pleine largeur dessous) */
@media (max-width: 640px) {
	.smc-voyage .smc-cta-booking--hero .smc-cta-booking__content {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto auto;
		row-gap: 12px;
	}
	.smc-voyage .smc-cta-booking--hero .smc-cta-booking__button {
		grid-column: 1;
		grid-row: 3;
		width: 100%;
	}
}

.smc-voyage .smc-cta-booking--featured {
	background: linear-gradient(135deg, var(--bleu-deep) 0%, #0e1626 100%);
	border-width: 2px;
	transform: scale(1.02);
	box-shadow: var(--shadow-lg, 0 16px 40px rgba(28, 46, 74, 0.12));
}

.smc-voyage .smc-cta-booking--card {
	margin: 16px 0;
	padding: 16px 20px;
	gap: 14px;
}
.smc-voyage .smc-cta-booking--card .smc-cta-booking__icon { width: 48px; height: 48px; font-size: 24px; }
.smc-voyage .smc-cta-booking--card .smc-cta-booking__title { font-size: 1.1rem; }

.smc-voyage .smc-cta-booking--final {
	margin-top: 48px;
	padding: 36px 40px;
	text-align: center;
	flex-direction: column;
	align-items: center;
}
.smc-voyage .smc-cta-booking--final .smc-cta-booking__icon {
	width: 80px; height: 80px;
	font-size: 42px;
	margin-bottom: 8px;
}

/* Responsive */
@media (max-width: 640px) {
	.smc-voyage .smc-cta-booking {
		flex-direction: column;
		padding: 20px;
		gap: 14px;
	}
	.smc-voyage .smc-cta-booking__icon { width: 56px; height: 56px; font-size: 28px; }
	.smc-voyage .smc-cta-booking__title { font-size: 1.15rem; }
}

/* Sommaire cliquable ancre */
.smc-voyage .smc-page-toc {
	background: var(--cream);
	border-left: 4px solid var(--or);
	border-radius: var(--radius-md, 12px);
	padding: 20px 24px;
	margin: 32px 0;
}
.smc-voyage .smc-page-toc h3 {
	font-family: var(--font-display);
	color: var(--bleu);
	margin: 0 0 12px;
	font-size: 1.1rem;
}
.smc-voyage .smc-page-toc ol { margin: 0; padding-left: 24px; }
.smc-voyage .smc-page-toc li { margin-bottom: 6px; line-height: 1.5; }
.smc-voyage .smc-page-toc a {
	color: var(--bleu) !important;
	text-decoration: none !important;
	border-bottom: 1px solid transparent;
	transition: border-color 0.2s;
}
.smc-voyage .smc-page-toc a:hover { border-bottom-color: var(--or); }

/* Tableau comparatif hôtels */
.smc-voyage .smc-hotels-compare-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.92rem;
	margin: 24px 0;
	background: var(--cream-soft);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
}
.smc-voyage .smc-hotels-compare-table th,
.smc-voyage .smc-hotels-compare-table td {
	padding: 12px 14px;
	text-align: left;
	border-bottom: 1px solid var(--line);
}
.smc-voyage .smc-hotels-compare-table th {
	background: var(--bleu);
	color: var(--cream);
	font-family: var(--font-display);
	font-weight: 500;
}
.smc-voyage .smc-hotels-compare-table tbody tr:nth-child(even) { background: var(--peau); }
.smc-voyage .smc-hotels-compare-table tbody tr:hover { background: var(--cream); }

/* Section profils voyageurs */
.smc-voyage .smc-profiles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
	margin: 28px 0;
}
.smc-voyage .smc-profile-card {
	background: var(--cream-soft);
	border-radius: var(--radius-md);
	padding: 24px;
	border-top: 3px solid var(--or);
}
.smc-voyage .smc-profile-card__icon {
	font-size: 28px;
	margin-bottom: 10px;
}
.smc-voyage .smc-profile-card h3 {
	font-family: var(--font-display);
	color: var(--bleu);
	margin: 0 0 10px;
	font-size: 1.15rem;
}
.smc-voyage .smc-profile-card p {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.6;
}
.smc-voyage .smc-profile-card ul {
	margin: 8px 0;
	padding-left: 20px;
	font-size: 0.9rem;
}
.smc-voyage .smc-profile-card ul li { margin-bottom: 4px; }

/* Section infos ville */
.smc-voyage .smc-city-facts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
	margin: 24px 0;
}
.smc-voyage .smc-city-fact {
	background: var(--cream-soft);
	border-radius: var(--radius-md);
	padding: 14px 18px;
	border-left: 3px solid var(--or);
}
.smc-voyage .smc-city-fact__label {
	display: block;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--soft);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 4px;
}
.smc-voyage .smc-city-fact__value {
	font-family: var(--font-display);
	font-size: 1.1rem;
	color: var(--bleu);
	font-weight: 600;
}

/* Hôtels par tranche de prix */
.smc-voyage .smc-hotel-tier {
	margin: 32px 0;
	padding: 24px;
	background: var(--cream-soft);
	border-radius: var(--radius-lg);
	border-left: 5px solid var(--or);
}
.smc-voyage .smc-hotel-tier--luxe { border-left-color: #B8935C; background: #FBF5E6; }
.smc-voyage .smc-hotel-tier--haut { border-left-color: var(--olive); }
.smc-voyage .smc-hotel-tier--moyen { border-left-color: var(--bleu-soft); }
.smc-voyage .smc-hotel-tier--eco { border-left-color: var(--soft); }

.smc-voyage .smc-hotel-tier h3 {
	font-family: var(--font-display);
	color: var(--bleu);
	margin: 0 0 18px;
	font-size: 1.4rem;
	display: flex; align-items: center; gap: 10px;
	border-bottom: 2px solid var(--line);
	padding-bottom: 10px;
}
.smc-voyage .smc-hotel-card {
	background: var(--cream);
	border-radius: var(--radius-md);
	padding: 18px 20px;
	margin: 16px 0;
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--line);
}
.smc-voyage .smc-hotel-card h4 {
	font-family: var(--font-display);
	color: var(--bleu);
	margin: 0 0 6px;
	font-size: 1.1rem;
}
.smc-voyage .smc-hotel-card .smc-hotel-meta {
	display: inline-flex; gap: 12px; flex-wrap: wrap;
	font-size: 0.85rem;
	color: var(--soft);
	margin-bottom: 10px;
}
.smc-voyage .smc-hotel-card .smc-hotel-meta strong { color: var(--or); font-weight: 700; }
.smc-voyage .smc-hotel-card ul { margin: 8px 0; padding-left: 18px; font-size: 0.92rem; }
.smc-voyage .smc-hotel-card ul li { margin-bottom: 3px; }
.smc-voyage .smc-hotel-card .smc-hotel-for {
	display: inline-block;
	background: var(--peau);
	color: var(--bleu);
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 0.8rem;
	margin: 8px 0;
}

/* ============================================================
   CTA Booking — Variante MINI (bandeau fin hôtel individuel)
   ============================================================ */
.smc-voyage .smc-cta-booking-mini {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-deep) 100%);
	color: var(--cream) !important;
	border-radius: var(--radius-sm, 8px);
	padding: 10px 16px;
	margin: 12px 0 4px;
	border: 1px solid rgba(184, 147, 92, 0.4);
	transition: border-color 0.2s, transform 0.2s;
}
.smc-voyage .smc-cta-booking-mini:hover {
	border-color: var(--or);
	transform: translateY(-1px);
}
.smc-voyage .smc-cta-booking-mini__label {
	font-family: var(--font-body);
	font-size: 0.9rem;
	color: rgba(247, 241, 227, 0.92) !important;
	font-weight: 500;
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.smc-voyage .smc-cta-booking-mini__btn {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--or);
	color: var(--bleu-deep) !important;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 0.82rem;
	padding: 6px 14px;
	border-radius: 999px;
	text-decoration: none !important;
	border: none;
	transition: background 0.2s, transform 0.2s;
	cursor: pointer;
	letter-spacing: 0.02em;
}
.smc-voyage .smc-cta-booking-mini__btn:hover {
	background: var(--or-light);
	color: var(--bleu-deep) !important;
	transform: translateX(2px);
}
.smc-voyage .smc-cta-booking-mini__btn svg { flex-shrink: 0; }

/* Responsive mini */
@media (max-width: 480px) {
	.smc-voyage .smc-cta-booking-mini {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		padding: 10px 14px;
	}
	.smc-voyage .smc-cta-booking-mini__label { white-space: normal; }
	.smc-voyage .smc-cta-booking-mini__btn { justify-content: center; }
}

/* Suppression de la mention "Partenaire Booking" — retirée du template */
.smc-voyage .smc-cta-booking__micro { display: none !important; }

/* ============================================================
   HELPERS MAILLAGE — Brief Audit CTA 2026-04-21
   ============================================================ */

/* Liens noms d'hôtels : discret doré, souligné dotted au hover */
.smc-voyage .smc-hotel-link,
.smc-voyage a.smc-hotel-link {
	color: inherit !important;
	text-decoration: none !important;
	border-bottom: 1px dotted rgba(184, 147, 92, 0.35);
	transition: border-bottom-color 0.2s ease, color 0.2s ease;
	padding-bottom: 1px;
}
.smc-voyage .smc-hotel-link:hover,
.smc-voyage a.smc-hotel-link:hover {
	border-bottom-color: var(--or);
	color: var(--or-light) !important;
	cursor: pointer;
}

/* Liens internes villes / destinations : souligné subtil bleu charte */
.smc-voyage .smc-internal-link,
.smc-voyage a.smc-internal-link {
	color: var(--bleu) !important;
	text-decoration: underline;
	text-underline-offset: 2px;
	text-decoration-thickness: 1px;
	text-decoration-color: rgba(36, 66, 92, 0.28);
	transition: text-decoration-color 0.2s ease;
}
.smc-voyage .smc-internal-link:hover,
.smc-voyage a.smc-internal-link:hover {
	text-decoration-color: var(--bleu);
}

/* Dans les tableaux comparatifs : liens hôtels bien visibles */
.smc-voyage table a.smc-hotel-link {
	color: var(--or) !important;
	border-bottom-color: rgba(184, 147, 92, 0.5);
	font-weight: 500;
}
.smc-voyage table a.smc-hotel-link:hover {
	color: var(--or-light) !important;
}

/* ============================================================
   TÉLÉPHONIE / eSIM — pages /voyage/.../telephone-internet-esim/
   Pilote Turquie 2026-04-22
   ============================================================ */

.smc-voyage--telephonie { --tel-accent-primary: var(--or); --tel-accent-secondary: var(--olive); --tel-accent-bg: var(--cream-soft); }

/* --- TL;DR box (hero secondaire, lecture 10 secondes) --- */
.smc-voyage-section--tldr-wrap { padding-top: 24px; padding-bottom: 24px; }
.smc-tel-tldr {
	background: linear-gradient(135deg, var(--cream-soft) 0%, #fcfaf0 100%);
	border-left: 5px solid var(--or);
	border-radius: 12px;
	padding: 28px 32px;
	box-shadow: 0 4px 20px rgba(28, 46, 74, 0.06);
}
.smc-tel-tldr__head { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.smc-tel-tldr__icon { font-size: 32px; line-height: 1; }
.smc-tel-tldr__title { font-family: 'Fraunces', serif; color: var(--bleu-deep); margin: 0; font-size: 22px; font-weight: 600; }
.smc-tel-tldr__list { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 10px; }
.smc-tel-tldr__item { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; font-size: 16px; line-height: 1.55; color: var(--bleu); }
.smc-tel-tldr__mark { flex-shrink: 0; font-size: 18px; line-height: 1.3; }
.smc-tel-tldr__item--fail { color: #7a2e1e; opacity: 0.85; }
.smc-tel-tldr__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; padding-top: 12px; border-top: 1px dashed rgba(184, 147, 92, 0.3); }
.smc-tel-tldr__cta-note { font-size: 13px; color: var(--bleu-soft); font-style: italic; }

/* --- Buttons système --- */
/* --- Bouton système premium (Airalo primary + Yesim secondary) --- */
.smc-tel-btn {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 28px;
	border-radius: 12px;
	font-family: 'Figtree', sans-serif;
	font-weight: 600;
	font-size: 15px;
	letter-spacing: 0.01em;
	text-decoration: none;
	border: none;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.smc-tel-btn__arrow { display: inline-block; transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1); }
.smc-tel-btn:hover .smc-tel-btn__arrow { transform: translateX(4px); }

/* --- Primary Airalo : gradient or 3-colors + shine + lift --- */
.smc-tel-btn--primary {
	background: linear-gradient(135deg, #C9A068 0%, #B8935C 50%, #A47D4A 100%);
	color: #FFFFFF !important;
	border: 1px solid rgba(255, 255, 255, 0.18);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.25),
		0 4px 14px rgba(184, 147, 92, 0.35),
		0 1px 2px rgba(0, 0, 0, 0.12);
}
.smc-tel-btn--primary::before {
	content: '';
	position: absolute;
	top: 0; left: -100%;
	width: 100%; height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
	transition: left 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}
.smc-tel-btn--primary:hover {
	transform: translateY(-2px);
	color: #FFFFFF !important;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.32),
		0 8px 22px rgba(184, 147, 92, 0.45),
		0 2px 4px rgba(0, 0, 0, 0.15);
}
.smc-tel-btn--primary:hover::before { left: 100%; }

/* --- Secondary Yesim : olive outline qui se remplit --- */
.smc-tel-btn--secondary {
	background: transparent;
	color: var(--bleu) !important;
	border: 2px solid var(--olive);
	box-shadow: 0 1px 2px rgba(107, 127, 63, 0.06);
}
.smc-tel-btn--secondary:hover {
	background: var(--olive);
	color: #FFFFFF !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(107, 127, 63, 0.28);
}

.smc-tel-btn--large { padding: 17px 34px; font-size: 17px; border-radius: 14px; }
.smc-tel-btn--small { padding: 9px 18px; font-size: 13px; border-radius: 10px; }
.smc-tel-dual-cta { display: flex; flex-wrap: wrap; gap: 14px; margin: 28px 0 8px; align-items: center; }

/* --- Comparatif 3 colonnes (eSIM vs forfait vs WiFi) --- */
.smc-tel-compare-wrap { overflow-x: auto; margin: 20px 0 24px; }
.smc-tel-compare {
	width: 100%; border-collapse: collapse;
	font-family: 'Figtree', sans-serif; font-size: 14px;
	min-width: 600px;
}
.smc-tel-compare thead { background: var(--bleu); color: var(--cream); }
.smc-tel-compare thead th {
	padding: 14px 12px;
	text-align: left;
	font-family: 'Fraunces', serif; font-weight: 600; font-size: 15px;
	border: 1px solid var(--bleu-deep);
}
.smc-tel-compare thead th.smc-tel-compare__winner { background: var(--or); color: var(--bleu-deep); }
.smc-tel-compare tbody td {
	padding: 12px; border: 1px solid #e5dfd0;
	background: #fcfaf0; color: var(--bleu);
	vertical-align: top;
}
.smc-tel-compare tbody tr:nth-child(even) td { background: var(--cream-soft); }
.smc-tel-compare tbody td.smc-tel-compare__winner {
	background: rgba(184, 147, 92, 0.08) !important;
	border-left: 3px solid var(--or);
	font-weight: 500;
}
.smc-tel-compare tbody td:first-child { background: var(--cream) !important; font-weight: 600; color: var(--bleu-deep); width: 22%; }

/* --- Plans tables (Airalo, opérateurs) --- */
.smc-tel-plans {
	width: 100%; border-collapse: collapse;
	font-family: 'Figtree', sans-serif; font-size: 14px;
	min-width: 500px;
	margin: 12px 0;
}
.smc-tel-plans thead th {
	background: var(--bleu); color: var(--cream);
	padding: 12px; text-align: left;
	font-family: 'Fraunces', serif; font-weight: 600;
	border: 1px solid var(--bleu-deep);
}
.smc-tel-plans tbody td { padding: 11px 12px; border: 1px solid #e5dfd0; background: #fcfaf0; color: var(--bleu); }
.smc-tel-plans tbody tr:nth-child(even) td { background: var(--cream-soft); }
.smc-tel-plans__price { color: var(--or); font-weight: 700; font-size: 15px; }

/* --- Benefits list (avantages eSIM) --- */
.smc-tel-benefits { list-style: none; padding: 0; margin: 16px 0; display: flex; flex-direction: column; gap: 12px; }
.smc-tel-benefits li {
	padding: 14px 18px;
	background: var(--cream-soft);
	border-left: 3px solid var(--olive);
	border-radius: 6px;
	font-size: 15px; line-height: 1.6; color: var(--bleu);
}
.smc-tel-benefits li strong { color: var(--bleu-deep); }

/* --- Grille compatibilité téléphones --- */
.smc-tel-compat-grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px; margin: 20px 0;
}
.smc-tel-compat-card {
	background: var(--cream-soft); border: 1px solid #e5dfd0;
	border-radius: 10px; padding: 16px 18px;
	transition: all 0.2s ease;
}
.smc-tel-compat-card:hover { border-color: var(--or); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(28, 46, 74, 0.08); }
.smc-tel-compat-card__brand { font-family: 'Fraunces', serif; font-size: 17px; font-weight: 600; color: var(--bleu-deep); margin-bottom: 8px; border-bottom: 1px solid rgba(184, 147, 92, 0.3); padding-bottom: 8px; }
.smc-tel-compat-card ul { list-style: none; padding: 0; margin: 0; font-size: 13px; color: var(--bleu); }
.smc-tel-compat-card li { padding: 3px 0; }

/* --- Steps : activation en 3 étapes --- */
.smc-tel-steps {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 20px; margin: 20px 0;
}
.smc-tel-step {
	background: var(--cream); border-radius: 12px; padding: 22px;
	border-top: 4px solid var(--or);
	position: relative;
}
.smc-tel-step__num {
	position: absolute; top: -18px; left: 20px;
	width: 36px; height: 36px; border-radius: 50%;
	background: var(--or); color: var(--cream);
	display: flex; align-items: center; justify-content: center;
	font-family: 'Fraunces', serif; font-size: 18px; font-weight: 700;
	box-shadow: 0 2px 6px rgba(184, 147, 92, 0.4);
}
.smc-tel-step__body h4 { font-family: 'Fraunces', serif; color: var(--bleu-deep); margin: 8px 0 10px; font-size: 18px; }
.smc-tel-step__body p { font-size: 14px; line-height: 1.55; color: var(--bleu); margin: 0; }

/* --- CTA card featured (Airalo section) — contrast forcé ---
   (Écrase l'héritage .smc-voyage { color: var(--encre) }) */
.smc-voyage .smc-tel-cta-card {
	background: linear-gradient(135deg, var(--bleu) 0%, var(--bleu-deep) 100%);
	color: #FFFFFF;
	border-radius: 14px; padding: 36px 32px;
	text-align: center;
	margin: 30px 0;
	box-shadow: 0 8px 28px rgba(28, 46, 74, 0.18);
	position: relative; overflow: hidden;
}
.smc-voyage .smc-tel-cta-card * { color: inherit; }
.smc-voyage .smc-tel-cta-card::before {
	content: ''; position: absolute; inset: 0;
	background: radial-gradient(circle at 80% 20%, rgba(212, 178, 126, 0.18) 0%, transparent 55%);
	pointer-events: none;
}
.smc-voyage .smc-tel-cta-card__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 64px; height: 64px; border-radius: 16px;
	background: linear-gradient(135deg, var(--or-light) 0%, var(--or) 100%);
	color: var(--bleu-deep);
	font-size: 32px;
	margin: 0 auto 18px;
	box-shadow: 0 4px 14px rgba(184, 147, 92, 0.35);
}
.smc-voyage .smc-tel-cta-card__title {
	font-family: 'Fraunces', serif; font-size: 28px; font-weight: 600;
	color: #FFFFFF; margin: 0 0 22px;
}
.smc-voyage .smc-tel-cta-card__bullets {
	list-style: none; padding: 0; margin: 0 auto 26px; max-width: 380px;
	text-align: left; display: flex; flex-direction: column; gap: 10px;
	color: var(--cream);
}
.smc-voyage .smc-tel-cta-card__bullets li {
	font-size: 15px; line-height: 1.55; padding: 4px 0 4px 32px;
	position: relative; color: var(--cream);
}
.smc-voyage .smc-tel-cta-card__bullets li::before {
	content: '✓'; position: absolute; left: 0; top: 4px;
	width: 22px; height: 22px; border-radius: 50%;
	background: var(--or-light); color: var(--bleu-deep);
	display: inline-flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 13px;
}
.smc-voyage .smc-tel-cta-card__bullets strong { color: #FFFFFF; font-weight: 600; }
.smc-voyage .smc-tel-cta-card__note {
	font-size: 12px; margin: 18px 0 0; font-style: italic;
	color: rgba(247, 241, 227, 0.6);
}

/* --- Soft CTA (conseil + bouton inline) --- */
.smc-tel-soft-cta {
	background: var(--cream-soft); border-radius: 10px; padding: 18px 22px;
	margin: 20px 0;
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px;
}
.smc-tel-soft-cta p { margin: 0; color: var(--bleu); font-size: 14px; flex: 1 1 260px; }

/* --- Pros / Cons (2 colonnes) --- */
.smc-tel-pros-cons {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 20px; margin: 20px 0;
}
.smc-tel-pros, .smc-tel-cons {
	background: var(--cream-soft); border-radius: 10px; padding: 20px 22px;
}
.smc-tel-pros { border-left: 4px solid var(--olive); }
.smc-tel-cons { border-left: 4px solid #b05a3a; }
.smc-tel-pros h4, .smc-tel-cons h4 {
	font-family: 'Fraunces', serif; font-size: 17px; font-weight: 600;
	color: var(--bleu-deep); margin: 0 0 12px;
}
.smc-tel-pros ul, .smc-tel-cons ul {
	list-style: none; padding: 0; margin: 0;
	font-size: 14px; line-height: 1.55; color: var(--bleu);
}
.smc-tel-pros li, .smc-tel-cons li { padding: 4px 0 4px 20px; position: relative; }
.smc-tel-pros li::before { content: '✓'; position: absolute; left: 0; color: var(--olive); font-weight: 700; }
.smc-tel-cons li::before { content: '—'; position: absolute; left: 0; color: #b05a3a; font-weight: 700; }

/* --- Operateurs cards --- */
.smc-tel-operators {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 18px; margin: 20px 0 28px;
}
.smc-tel-operator {
	background: var(--cream-soft); border: 1px solid #e5dfd0;
	border-radius: 12px; padding: 20px 22px;
	transition: all 0.2s ease;
}
.smc-tel-operator--leader { border-top: 5px solid var(--or); background: linear-gradient(180deg, #fcfaf0 0%, var(--cream-soft) 100%); }
.smc-tel-operator--alt { border-top: 3px solid var(--olive); }
.smc-tel-operator:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(28, 46, 74, 0.08); }
.smc-tel-operator__head {
	display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
	gap: 10px; margin-bottom: 14px;
	border-bottom: 1px solid rgba(184, 147, 92, 0.3); padding-bottom: 10px;
}
.smc-tel-operator__head h3 { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 600; color: var(--bleu-deep); margin: 0; }
.smc-tel-operator__badge {
	background: var(--or); color: var(--bleu-deep);
	font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
	padding: 3px 10px; border-radius: 12px;
}
.smc-tel-operator__specs { list-style: none; padding: 0; margin: 0; font-size: 14px; line-height: 1.55; color: var(--bleu); }
.smc-tel-operator__specs li { padding: 5px 0; }
.smc-tel-operator__specs li strong { color: var(--bleu-deep); min-width: 150px; display: inline-block; }
.smc-tel-operator__notes { margin-top: 10px !important; padding: 10px !important; background: rgba(28, 46, 74, 0.04); border-radius: 6px; font-size: 13px !important; }

/* --- Régions cards --- */
.smc-tel-regions {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 18px; margin: 20px 0;
}
.smc-tel-region {
	display: flex; gap: 16px;
	background: var(--cream-soft); border-radius: 12px; padding: 20px;
	border-left: 4px solid var(--olive);
	transition: all 0.2s ease;
}
.smc-tel-region:hover { transform: translateX(3px); box-shadow: 0 4px 12px rgba(28, 46, 74, 0.06); }
.smc-tel-region__icon {
	flex-shrink: 0; width: 48px; height: 48px;
	background: var(--bleu); color: var(--or-light);
	border-radius: 10px;
	display: flex; align-items: center; justify-content: center;
	font-size: 26px;
}
.smc-tel-region__body h3 { font-family: 'Fraunces', serif; font-size: 17px; color: var(--bleu-deep); margin: 0 0 8px; }
.smc-tel-region__quality { font-size: 14px; line-height: 1.55; color: var(--bleu); margin: 0 0 6px; }
.smc-tel-region__note { font-size: 13px; color: var(--bleu-soft); margin: 0; font-style: italic; }

/* --- Budget table (enrichissement) --- */
.smc-tel-budget { width: 100%; border-collapse: collapse; font-family: 'Figtree', sans-serif; font-size: 14px; min-width: 600px; }
.smc-tel-budget thead { background: var(--bleu); color: var(--cream); }
.smc-tel-budget thead th { padding: 13px 12px; text-align: left; font-family: 'Fraunces', serif; border: 1px solid var(--bleu-deep); }
.smc-tel-budget tbody td { padding: 12px; border: 1px solid #e5dfd0; background: #fcfaf0; color: var(--bleu); }
.smc-tel-budget tbody tr:nth-child(even) td { background: var(--cream-soft); }
.smc-tel-budget__icon { font-size: 18px; margin-right: 6px; }
.smc-tel-budget__cost { color: var(--or); font-weight: 700; font-size: 15px; }

/* --- Q&A grid (encarts visuels) --- */
.smc-tel-qa-grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 18px; margin: 20px 0;
}
.smc-tel-qa {
	background: var(--cream-soft); border-radius: 12px; padding: 22px 24px;
	border-top: 4px solid var(--or-light);
	transition: all 0.2s ease;
	position: relative;
}
.smc-tel-qa:hover { transform: translateY(-3px); box-shadow: 0 8px 20px rgba(28, 46, 74, 0.08); border-top-color: var(--or); }
.smc-tel-qa__icon {
	position: absolute; top: -20px; right: 20px;
	width: 42px; height: 42px;
	background: var(--or); color: var(--cream);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: 22px;
	box-shadow: 0 2px 8px rgba(184, 147, 92, 0.4);
}
.smc-tel-qa h3 { font-family: 'Fraunces', serif; font-size: 17px; color: var(--bleu-deep); margin: 6px 0 10px; padding-right: 52px; }
.smc-tel-qa p { font-size: 14px; line-height: 1.6; color: var(--bleu); margin: 0; }

/* --- Matrice décisionnelle (flow chart simplifié) --- */
.smc-tel-matrix {
	display: flex; flex-direction: column; gap: 14px;
	margin: 20px 0;
}
.smc-tel-matrix__row {
	display: grid; grid-template-columns: 1fr 1.3fr;
	gap: 16px;
	background: var(--cream-soft); border-radius: 12px; padding: 20px 24px;
	border-left: 5px solid var(--or);
	transition: all 0.2s ease;
}
.smc-tel-matrix__row:hover { transform: translateX(3px); box-shadow: 0 4px 14px rgba(28, 46, 74, 0.08); }
.smc-tel-matrix__question {
	font-family: 'Fraunces', serif; color: var(--bleu-deep); font-size: 17px;
	display: flex; align-items: flex-start; gap: 10px;
}
.smc-tel-matrix__arrow { flex-shrink: 0; font-size: 20px; }
.smc-tel-matrix__answer { display: flex; flex-direction: column; gap: 10px; }
.smc-tel-matrix__answer p { margin: 0; font-size: 15px; line-height: 1.5; color: var(--bleu); }
.smc-tel-matrix__answer .smc-tel-btn { align-self: flex-start; }

/* --- Small text utility --- */
.smc-tel-small { font-size: 13px; color: var(--bleu-soft); margin-top: 10px; }

/* ============================================================
   Responsive
   ============================================================ */
@media ( max-width: 900px ) {
	.smc-tel-pros-cons { grid-template-columns: 1fr; }
	.smc-tel-matrix__row { grid-template-columns: 1fr; gap: 10px; }
	.smc-tel-compat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media ( max-width: 640px ) {
	.smc-tel-tldr { padding: 20px 22px; }
	.smc-tel-tldr__title { font-size: 19px; }
	.smc-tel-tldr__cta { flex-direction: column; align-items: flex-start; }
	.smc-tel-btn { width: 100%; justify-content: center; }
	.smc-tel-btn--small { width: auto; }
	.smc-tel-cta-card { padding: 24px 20px; }
	.smc-tel-cta-card__title { font-size: 22px; }
	.smc-tel-compat-grid { grid-template-columns: 1fr; }
	.smc-tel-operators { grid-template-columns: 1fr; }
	.smc-tel-regions { grid-template-columns: 1fr; }
	.smc-tel-qa-grid { grid-template-columns: 1fr; }
	.smc-tel-soft-cta { flex-direction: column; align-items: flex-start; }
	.smc-tel-dual-cta { flex-direction: column; align-items: stretch; }
}
