/* =========================================================
   E-MONTAGNE — HOMEPAGE RICH CONTENT
   Scope principal : .emhp
   Scope éléments existants : body.page1
   ========================================================= */

.emhp {
	--emhp-ink: #14201d;
	--emhp-ink-soft: #42514c;
	--emhp-dark: #082823;
	--emhp-dark-2: #103d35;
	--emhp-forest: #17664f;
	--emhp-pine: #23906c;
	--emhp-lime: #b9d66b;
	--emhp-snow: #f7fbfa;
	--emhp-ice: #dcedea;
	--emhp-stone: #e8e4db;
	--emhp-sand: #f5eddd;
	--emhp-sun: #f5bd43;
	--emhp-copper: #d96d3f;
	--emhp-white: #ffffff;
	--emhp-border: rgba(20, 51, 43, .13);
	--emhp-shadow-sm: 0 10px 28px rgba(7, 40, 34, .09);
	--emhp-shadow-md: 0 22px 55px rgba(7, 40, 34, .14);
	--emhp-shadow-lg: 0 34px 90px rgba(5, 30, 26, .22);
	--emhp-radius-sm: 16px;
	--emhp-radius-md: 26px;
	--emhp-radius-lg: 40px;
	--emhp-transition: 220ms ease;
	position: relative;
	width: 100%;
	max-width: 1480px;
	margin: 0 auto;
	padding: clamp(28px, 5vw, 72px) clamp(14px, 3vw, 36px);
	color: var(--emhp-ink);
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	box-sizing: border-box;
	overflow: hidden;
	background:
		radial-gradient(circle at 4% 14%, rgba(185, 214, 107, .17), transparent 22%),
		radial-gradient(circle at 94% 32%, rgba(35, 144, 108, .11), transparent 26%),
		linear-gradient(180deg, #f7faf8 0%, #edf4f0 48%, #faf8f1 100%);
	border-radius: clamp(24px, 4vw, 48px);
}

.emhp,
.emhp * {
	box-sizing: border-box;
}

.emhp a {
	color: inherit;
	text-decoration: none;
}

.emhp a:focus-visible,
.emhp summary:focus-visible {
	outline: 3px solid var(--emhp-sun);
	outline-offset: 5px;
}

.emhp h2,
.emhp h3,
.emhp p {
	margin-top: 0;
}

.emhp h2,
.emhp h3 {
	color: inherit;
	background: none;
	background-image: none;
	box-shadow: none;
	text-shadow: none;
}

.emhp h2 {
	margin-bottom: 18px;
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	font-size: clamp(2rem, 1.25rem + 2.3vw, 3.7rem);
	line-height: 1.02;
	letter-spacing: -.05em;
}

.emhp h3 {
	margin-bottom: 12px;
	font-size: clamp(1.25rem, 1.05rem + .7vw, 1.75rem);
	line-height: 1.16;
	letter-spacing: -.025em;
}

.emhp p {
	color: var(--emhp-ink-soft);
	font-size: clamp(1rem, .96rem + .16vw, 1.09rem);
	line-height: 1.72;
}

.emhp__section {
	position: relative;
	max-width: 1240px;
	margin: clamp(34px, 7vw, 94px) auto 0;
}

.emhp__eyebrow,
.emhp__kicker {
	margin: 0 0 14px;
	font-size: .76rem;
	font-weight: 800;
	line-height: 1.3;
	letter-spacing: .16em;
	text-transform: uppercase;
}

.emhp__eyebrow {
	color: #d8efaf;
}

.emhp__kicker {
	color: var(--emhp-forest);
}

.emhp__section-heading {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(270px, .7fr);
	gap: clamp(28px, 5vw, 74px);
	align-items: end;
	margin-bottom: clamp(28px, 4vw, 48px);
}

.emhp__section-heading > p {
	margin-bottom: 6px;
}

.emhp__section-heading--light h2,
.emhp__section-heading--light p {
	color: var(--emhp-white);
}

.emhp__section-heading--light .emhp__kicker {
	color: #d8efaf;
}

/* =========================================================
   SLIDER ET H1 EXISTANTS
   ========================================================= */

body.page1 .slider_wrapper {
	height: clamp(580px, 76vh, 780px) !important;
	min-height: 580px;
	overflow: hidden;
}

body.page1 .slider_wrapper::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		linear-gradient(180deg, rgba(3, 20, 18, .08) 0%, rgba(3, 20, 18, .22) 42%, rgba(3, 20, 18, .82) 100%),
		radial-gradient(circle at 50% 36%, transparent 0%, rgba(2, 17, 14, .18) 100%);
}
/* =========================================================
   SLIDER HOMEPAGE — CAPTION COMPACT ET PREMIUM
   ========================================================= */

body.page1 .slider_wrapper {
	position: relative;
	min-height: clamp(560px, 78svh, 820px) !important;
	height: clamp(560px, 78svh, 820px) !important;
	overflow: hidden;
	isolation: isolate;
}

body.page1 .slider_wrapper::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		linear-gradient(
			180deg,
			rgba(3, 20, 18, .06) 0%,
			rgba(3, 20, 18, .14) 32%,
			rgba(3, 20, 18, .56) 100%
		),
		linear-gradient(
			90deg,
			rgba(3, 20, 18, .18) 0%,
			transparent 48%,
			rgba(3, 20, 18, .12) 100%
		);
}

body.page1 .slider_wrapper .caption {
	position: absolute !important;
	top: 50% !important;
	left: 50% !important;
	z-index: 4 !important;
	width: min(590px, calc(100% - 38px)) !important;
	max-width: 590px !important;
	margin: 0 !important;
	padding: clamp(25px, 4vw, 38px) !important;
	transform: translate(-50%, -50%) !important;
	overflow: visible !important;
	border: 1px solid rgba(255, 255, 255, .2) !important;
	border-radius: 28px !important;
	color: #ffffff !important;
	background:
		linear-gradient(
			145deg,
			rgba(4, 31, 27, .88),
			rgba(8, 48, 40, .76)
		) !important;
	box-shadow:
		0 30px 80px rgba(0, 0, 0, .38),
		inset 0 1px 0 rgba(255, 255, 255, .12) !important;
	text-align: center !important;
	backdrop-filter: blur(14px) saturate(1.12);
	-webkit-backdrop-filter: blur(14px) saturate(1.12);
}

body.page1 .slider_wrapper .caption::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	width: 72px;
	height: 4px;
	transform: translateX(-50%);
	border-radius: 0 0 999px 999px;
	background: linear-gradient(90deg, #b9d66b, #f5bd43);
	box-shadow: 0 4px 18px rgba(245, 189, 67, .24);
}

/* Logo du caption */
body.page1 .slider_wrapper .caption .caplogo,
body.page1 .slider_wrapper .caption img.caplogo {
	display: block;
	width: auto !important;
	max-width: 130px !important;
	max-height: 92px !important;
	margin: 0 auto 20px !important;
	object-fit: contain;
	filter:
		drop-shadow(0 7px 16px rgba(0, 0, 0, .28))
		drop-shadow(0 0 1px rgba(255, 255, 255, .35));
}

/* Si le logo est contenu dans un wrapper */
body.page1 .slider_wrapper .caption .caplogo img {
	display: block;
	width: auto !important;
	max-width: 130px !important;
	max-height: 92px !important;
	margin: 0 auto !important;
	object-fit: contain;
}

body.page1 .emhp-caption {
	max-width: 500px;
	margin: 0 auto;
}

body.page1 .emhp-caption__kicker {
	margin: 0 0 9px !important;
	color: #d8efaf !important;
	background: transparent !important;
	font-size: .72rem !important;
	font-weight: 850 !important;
	line-height: 1.3 !important;
	letter-spacing: .14em !important;
	text-transform: uppercase;
	text-shadow: none !important;
}

body.page1 .emhp-caption__title {
	margin: 0 0 14px !important;
	padding: 0 !important;
	color: #ffffff !important;
	background: transparent !important;
	background-image: none !important;
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	font-size: clamp(1.75rem, 1.35rem + 1.5vw, 2.65rem) !important;
	font-weight: 800 !important;
	line-height: 1.02 !important;
	letter-spacing: -.045em !important;
	text-wrap: balance;
	text-shadow: 0 4px 22px rgba(0, 0, 0, .34) !important;
}

body.page1 .emhp-caption__text {
	max-width: 490px;
	margin: 0 auto !important;
	color: rgba(255, 255, 255, .84) !important;
	background: transparent !important;
	font-size: clamp(.94rem, .9rem + .16vw, 1.04rem) !important;
	font-weight: 450 !important;
	line-height: 1.62 !important;
	text-shadow: 0 2px 12px rgba(0, 0, 0, .25) !important;
}

/* Neutralise l’ancien style éditorial à l’intérieur du caption */
body.page1 .slider_wrapper .caption .edito_txt_o,
body.page1 .slider_wrapper .caption .edito_txt_o p {
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	color: inherit !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

/* Zone des deux actions */
body.page1 #cpationctarea {
	display: flex !important;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 11px;
	margin: 23px 0 0 !important;
	padding: 0 !important;
}

/* Base commune */
body.page1 #cpationctarea .cta-btn,
body.page1 #cpationctarea .cta2advanced,
body.page1 #cpationctarea a,
body.page1 #cpationctarea span {
	box-sizing: border-box;
}

/* CTA principal */
body.page1 #cpationctarea .cta-btn {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 21px !important;
	border: 1px solid #d8efaf !important;
	border-radius: 999px !important;
	color: #10241f !important;
	background:
		linear-gradient(135deg, #e4f4bd, #b9d66b) !important;
	box-shadow:
		0 12px 28px rgba(0, 0, 0, .22),
		inset 0 1px 0 rgba(255, 255, 255, .55) !important;
	font-size: .88rem !important;
	font-weight: 850 !important;
	line-height: 1.25 !important;
	text-decoration: none !important;
	text-shadow: none !important;
	transition:
		transform 180ms ease,
		box-shadow 180ms ease,
		filter 180ms ease;
}

/* CTA secondaire */
body.page1 #cpationctarea .cta2advanced {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 21px !important;
	border: 1px solid rgba(255, 255, 255, .28) !important;
	border-radius: 999px !important;
	color: #ffffff !important;
	background: rgba(255, 255, 255, .08) !important;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, .09) !important;
	font-size: .88rem !important;
	font-weight: 800 !important;
	line-height: 1.25 !important;
	text-decoration: none !important;
	text-shadow: none !important;
	backdrop-filter: blur(7px);
	-webkit-backdrop-filter: blur(7px);
	transition:
		transform 180ms ease,
		background 180ms ease,
		border-color 180ms ease;
}

body.page1 #cpationctarea .cta-btn:hover,
body.page1 #cpationctarea .cta-btn:focus {
	transform: translateY(-2px);
	filter: brightness(1.04);
	box-shadow:
		0 16px 34px rgba(0, 0, 0, .28),
		inset 0 1px 0 rgba(255, 255, 255, .62) !important;
}

body.page1 #cpationctarea .cta2advanced:hover,
body.page1 #cpationctarea .cta2advanced:focus {
	transform: translateY(-2px);
	border-color: rgba(255, 255, 255, .48) !important;
	background: rgba(255, 255, 255, .15) !important;
}

/* Supprime les éventuels soulignements ou pseudo-éléments du thème */
body.page1 #cpationctarea .cta-btn::before,
body.page1 #cpationctarea .cta-btn::after,
body.page1 #cpationctarea .cta2advanced::before,
body.page1 #cpationctarea .cta2advanced::after {
	display: none !important;
	content: none !important;
}

/* =========================================================
   TABLETTE
   ========================================================= */

@media (max-width: 820px) {
	body.page1 .slider_wrapper {
		min-height: 610px !important;
		height: 610px !important;
	}

	body.page1 .slider_wrapper .caption {
		width: min(540px, calc(100% - 28px)) !important;
		padding: 28px 22px !important;
		border-radius: 24px !important;
	}

	body.page1 .slider_wrapper .caption .caplogo,
	body.page1 .slider_wrapper .caption img.caplogo,
	body.page1 .slider_wrapper .caption .caplogo img {
		max-width: 112px !important;
		max-height: 78px !important;
		margin-bottom: 17px !important;
	}
}

/* =========================================================
   MOBILE
   ========================================================= */

@media (max-width: 560px) {
	body.page1 .slider_wrapper {
		min-height: 600px !important;
		height: 600px !important;
	}

	body.page1 .slider_wrapper .caption {
		top: 51% !important;
		width: calc(100% - 24px) !important;
		padding: 25px 17px !important;
		border-radius: 22px !important;
	}

	body.page1 .emhp-caption__kicker {
		font-size: .66rem !important;
		letter-spacing: .11em !important;
	}

	body.page1 .emhp-caption__title {
		font-size: clamp(1.6rem, 8vw, 2.15rem) !important;
		line-height: 1.04 !important;
	}

	body.page1 .emhp-caption__text {
		font-size: .92rem !important;
		line-height: 1.52 !important;
	}

	body.page1 #cpationctarea {
		display: grid !important;
		grid-template-columns: 1fr;
		gap: 9px;
		margin-top: 19px !important;
	}

	body.page1 #cpationctarea .cta-btn,
	body.page1 #cpationctarea .cta2advanced {
		width: 100% !important;
		min-height: 46px;
		padding: 11px 15px !important;
	}

	body.page1 .slider_wrapper .caption .caplogo,
	body.page1 .slider_wrapper .caption img.caplogo,
	body.page1 .slider_wrapper .caption .caplogo img {
		max-width: 98px !important;
		max-height: 69px !important;
		margin-bottom: 15px !important;
	}
}

body.page1 #cpationctarea {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin-top: 22px;
}

body.page1 #cpationctarea .cta-btn,
body.page1 #cpationctarea .cta2advanced {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 20px;
	border-radius: 999px;
	font-weight: 800;
	line-height: 1.25;
	cursor: pointer;
	transition:
		transform var(--emhp-transition),
		box-shadow var(--emhp-transition),
		background var(--emhp-transition);
}

body.page1 #cpationctarea .cta-btn {
	color: #10241f;
	background: #d8efaf;
	box-shadow: 0 12px 28px rgba(0, 0, 0, .2);
}

body.page1 #cpationctarea .cta2advanced {
	color: #fff;
	border: 1px solid rgba(255, 255, 255, .38);
	background: rgba(255, 255, 255, .11);
}

body.page1 #cpationctarea .cta-btn:hover,
body.page1 #cpationctarea .cta2advanced:hover {
	transform: translateY(-2px);
}

body.page1 .hyperhauth1 {
	position: relative;
	z-index: 8;
	width: min(1160px, calc(100% - 32px));
	margin: -54px auto 0;
}

body.page1 .hyperhauth1 h1.title {
	position: relative !important;
	inset: auto !important;
	display: block !important;
	width: fit-content !important;
	max-width: 930px !important;
	margin: 0 !important;
	padding: 18px 28px !important;
	transform: none !important;
	color: #10241f !important;
	background: rgba(255, 255, 255, .96) !important;
	border: 1px solid rgba(20, 51, 43, .12);
	border-radius: 22px;
	box-shadow: 0 20px 50px rgba(7, 40, 34, .19);
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	font-size: clamp(1.55rem, 1.12rem + 1.55vw, 2.7rem) !important;
	font-weight: 800;
	line-height: 1.08 !important;
	letter-spacing: -.045em;
	text-align: left !important;
	-webkit-line-clamp: initial !important;
	overflow: visible !important;
}

/* =========================================================
   HERO INTERNE
   ========================================================= */

.emhp__summit {
	position: relative;
	min-height: 570px;
	display: flex;
	align-items: flex-end;
	padding: clamp(34px, 7vw, 82px);
	overflow: hidden;
	border-radius: var(--emhp-radius-lg);
	color: var(--emhp-white);
	background:
		radial-gradient(circle at 77% 20%, rgba(245, 189, 67, .32), transparent 18%),
		linear-gradient(135deg, #062d27 0%, #0f5546 51%, #297a5c 100%);
	box-shadow: var(--emhp-shadow-lg);
	isolation: isolate;
}

.emhp__summit::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	opacity: .34;
	background-image:
		repeating-radial-gradient(
			ellipse at 82% 16%,
			transparent 0,
			transparent 18px,
			rgba(255, 255, 255, .13) 19px,
			transparent 20px
		);
}

.emhp__summit-content {
	position: relative;
	z-index: 4;
	width: min(810px, 100%);
}

.emhp__summit h2 {
	max-width: 790px;
	color: var(--emhp-white);
	font-size: clamp(2.45rem, 1.5rem + 3.8vw, 5.5rem);
	line-height: .96;
	text-shadow: 0 6px 34px rgba(0, 0, 0, .28);
}

.emhp__lead {
	max-width: 750px;
	margin-bottom: 28px;
	color: rgba(255, 255, 255, .88) !important;
	font-size: clamp(1.04rem, .96rem + .35vw, 1.25rem) !important;
}

.emhp__lead strong {
	color: var(--emhp-white);
}

.emhp__summit-actions,
.emhp__closing-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.emhp__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 13px 22px;
	border: 1px solid transparent;
	border-radius: 999px;
	font-size: .96rem;
	font-weight: 800;
	line-height: 1.25;
	transition:
		transform var(--emhp-transition),
		box-shadow var(--emhp-transition),
		background var(--emhp-transition);
}

.emhp__button:hover {
	transform: translateY(-3px);
}

.emhp__button--light {
	color: var(--emhp-dark) !important;
	background: var(--emhp-white);
	box-shadow: 0 14px 32px rgba(0, 0, 0, .18);
}

.emhp__button--ghost {
	color: var(--emhp-white) !important;
	border-color: rgba(255, 255, 255, .37);
	background: rgba(255, 255, 255, .1);
}

.emhp__button--ghost:hover {
	background: rgba(255, 255, 255, .18);
}

.emhp__summit-points {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
	margin-top: 34px;
}

.emhp__summit-points span {
	display: flex;
	flex-direction: column;
	min-height: 78px;
	justify-content: center;
	padding: 12px 15px;
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 16px;
	color: rgba(255, 255, 255, .73);
	background: rgba(0, 0, 0, .12);
	font-size: .82rem;
	line-height: 1.35;
	backdrop-filter: blur(8px);
}

.emhp__summit-points strong {
	margin-bottom: 3px;
	color: var(--emhp-white);
	font-size: .91rem;
}

.emhp__summit-scenery,
.emhp__ridge,
.emhp__sun {
	position: absolute;
	pointer-events: none;
}

.emhp__summit-scenery {
	inset: 0;
	z-index: 1;
}

.emhp__sun {
	top: 12%;
	right: 11%;
	width: clamp(80px, 10vw, 144px);
	aspect-ratio: 1;
	border-radius: 50%;
	background: rgba(245, 189, 67, .92);
	box-shadow:
		0 0 0 18px rgba(245, 189, 67, .08),
		0 0 80px rgba(245, 189, 67, .34);
}

.emhp__ridge {
	left: -5%;
	width: 110%;
	clip-path: polygon(0 100%, 0 71%, 10% 62%, 18% 72%, 29% 42%, 37% 63%, 50% 25%, 62% 58%, 73% 39%, 82% 66%, 91% 45%, 100% 63%, 100% 100%);
}

.emhp__ridge--far {
	bottom: 16%;
	height: 52%;
	opacity: .27;
	background: #92c9a9;
}

.emhp__ridge--middle {
	bottom: 5%;
	height: 47%;
	opacity: .55;
	background: #1d604f;
	transform: scaleX(1.08);
}

.emhp__ridge--front {
	bottom: -7%;
	height: 43%;
	background: #092d27;
	transform: scaleX(1.13);
}

/* =========================================================
   CARTES UNIVERS
   ========================================================= */

.emhp__universe-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.emhp__universe-card {
	position: relative;
	min-height: 310px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: 28px;
	overflow: hidden;
	border: 1px solid var(--emhp-border);
	border-radius: var(--emhp-radius-md);
	background: rgba(255, 255, 255, .86);
	box-shadow: var(--emhp-shadow-sm);
	transition:
		transform var(--emhp-transition),
		box-shadow var(--emhp-transition),
		border-color var(--emhp-transition);
	isolation: isolate;
}

.emhp__universe-card::before {
	content: "";
	position: absolute;
	right: -42px;
	bottom: -54px;
	z-index: -1;
	width: 180px;
	height: 180px;
	border-radius: 50%;
	opacity: .26;
	background: currentColor;
}

.emhp__universe-card:hover {
	transform: translateY(-7px);
	border-color: rgba(23, 102, 79, .3);
	box-shadow: var(--emhp-shadow-md);
}

.emhp__universe-card--snow {
	color: #2f7790;
}

.emhp__universe-card--trail {
	color: #b86637;
}

.emhp__universe-card--forest {
	color: #197451;
}

.emhp__universe-card--world {
	color: #7c5a9b;
}

.emhp__universe-card--gear {
	color: #96711f;
}

.emhp__universe-card--culture {
	color: #9b4d55;
}

.emhp__universe-card h3 {
	margin-top: 30px;
	color: var(--emhp-ink);
}

.emhp__universe-card p {
	margin-bottom: 24px;
	color: var(--emhp-ink-soft);
}

.emhp__universe-icon {
	display: grid;
	width: 54px;
	height: 54px;
	place-items: center;
	border-radius: 17px;
	background: rgba(255, 255, 255, .82);
	box-shadow: 0 8px 20px rgba(0, 0, 0, .08);
	font-size: 1.7rem;
}

.emhp__universe-number {
	position: absolute;
	top: 28px;
	right: 28px;
	color: rgba(20, 32, 29, .24);
	font-size: .78rem;
	font-weight: 800;
	letter-spacing: .13em;
}

.emhp__card-link {
	margin-top: auto;
	color: var(--emhp-ink);
	font-size: .9rem;
	font-weight: 800;
}

.emhp__card-link::after {
	content: " →";
}

.emhp__quicklinks {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin-top: 24px;
}

.emhp__quicklinks a {
	padding: 10px 15px;
	border: 1px solid var(--emhp-border);
	border-radius: 999px;
	color: var(--emhp-dark);
	background: rgba(255, 255, 255, .73);
	font-size: .87rem;
	font-weight: 750;
	transition:
		background var(--emhp-transition),
		transform var(--emhp-transition);
}

.emhp__quicklinks a:hover {
	transform: translateY(-2px);
	background: var(--emhp-white);
}

/* =========================================================
   SAISONS
   ========================================================= */

.emhp__section--seasons {
	max-width: none;
	margin-right: calc(clamp(14px, 3vw, 36px) * -1);
	margin-left: calc(clamp(14px, 3vw, 36px) * -1);
	padding: clamp(40px, 7vw, 82px) clamp(14px, 5vw, 74px);
	border-radius: var(--emhp-radius-lg);
	background:
		radial-gradient(circle at 12% 20%, rgba(185, 214, 107, .13), transparent 24%),
		linear-gradient(135deg, #092c27, #123f37);
	box-shadow: var(--emhp-shadow-lg);
}

.emhp__season-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.emhp__season-card {
	position: relative;
	min-height: 430px;
	padding: 27px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, .14);
	border-radius: var(--emhp-radius-md);
	background: rgba(255, 255, 255, .07);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .12);
	backdrop-filter: blur(10px);
	transition:
		transform var(--emhp-transition),
		background var(--emhp-transition);
}

.emhp__season-card:hover {
	transform: translateY(-5px);
	background: rgba(255, 255, 255, .11);
}

.emhp__season-card h3,
.emhp__season-card p,
.emhp__season-card a {
	color: var(--emhp-white);
}

.emhp__season-card > p {
	color: rgba(255, 255, 255, .72);
}

.emhp__season-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 42px;
}

.emhp__season-top span {
	display: grid;
	width: 52px;
	height: 52px;
	place-items: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, .13);
	font-size: 1.6rem;
}

.emhp__season-top p {
	margin: 0;
	color: rgba(255, 255, 255, .65);
	font-size: .77rem;
	font-weight: 800;
	letter-spacing: .1em;
	text-transform: uppercase;
}

.emhp__season-card ul {
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}

.emhp__season-card li {
	position: relative;
	margin: 0;
	padding: 12px 0 12px 22px;
	border-top: 1px solid rgba(255, 255, 255, .1);
	list-style: none;
}

.emhp__season-card li::before {
	content: "▲";
	position: absolute;
	top: 15px;
	left: 1px;
	color: #d8efaf;
	font-size: .6rem;
}

.emhp__season-card a {
	font-size: .91rem;
	font-weight: 700;
}

.emhp__season-card a:hover {
	text-decoration: underline;
	text-underline-offset: 4px;
}

/* =========================================================
   GUIDES
   ========================================================= */

.emhp__guide-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.emhp__guide-card {
	position: relative;
	min-height: 230px;
	display: flex;
	flex-direction: column;
	padding: 24px 58px 24px 24px;
	border: 1px solid var(--emhp-border);
	border-radius: var(--emhp-radius-sm);
	background: rgba(255, 255, 255, .86);
	box-shadow: var(--emhp-shadow-sm);
	transition:
		transform var(--emhp-transition),
		box-shadow var(--emhp-transition);
}

.emhp__guide-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--emhp-shadow-md);
}

.emhp__guide-card p {
	margin-bottom: 0;
	font-size: .95rem;
	line-height: 1.58;
}

.emhp__guide-tag {
	width: fit-content;
	margin-bottom: 28px;
	padding: 6px 10px;
	border-radius: 999px;
	color: var(--emhp-forest);
	background: rgba(35, 144, 108, .1);
	font-size: .72rem;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.emhp__guide-arrow {
	position: absolute;
	top: 22px;
	right: 22px;
	display: grid;
	width: 34px;
	height: 34px;
	place-items: center;
	border-radius: 50%;
	color: var(--emhp-white);
	background: var(--emhp-dark);
	font-size: 1rem;
	transition: transform var(--emhp-transition);
}

.emhp__guide-card:hover .emhp__guide-arrow {
	transform: rotate(12deg) scale(1.07);
}

/* =========================================================
   DESTINATIONS
   ========================================================= */

.emhp__section--destinations {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(390px, .9fr);
	gap: clamp(34px, 6vw, 84px);
	align-items: center;
	padding: clamp(34px, 6vw, 70px);
	border: 1px solid var(--emhp-border);
	border-radius: var(--emhp-radius-lg);
	background:
		linear-gradient(120deg, rgba(255, 255, 255, .93), rgba(232, 244, 238, .85));
	box-shadow: var(--emhp-shadow-md);
}

.emhp__destination-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 18px 28px;
	margin-top: 26px;
}

.emhp__text-link {
	color: var(--emhp-forest) !important;
	font-weight: 800;
	text-decoration: underline !important;
	text-decoration-color: rgba(23, 102, 79, .3) !important;
	text-decoration-thickness: 2px !important;
	text-underline-offset: 5px;
}

.emhp__destination-map {
	position: relative;
	min-height: 440px;
	overflow: hidden;
	border-radius: 34px;
	background:
		radial-gradient(circle at 22% 24%, rgba(245, 189, 67, .9) 0 7%, transparent 7.4%),
		linear-gradient(145deg, #0d443a, #1c765d);
	box-shadow: var(--emhp-shadow-md);
	isolation: isolate;
}

.emhp__destination-map::before,
.emhp__destination-map::after {
	content: "";
	position: absolute;
	left: -8%;
	width: 116%;
	clip-path: polygon(0 100%, 0 66%, 10% 55%, 19% 68%, 32% 35%, 44% 61%, 55% 27%, 66% 60%, 78% 42%, 88% 64%, 100% 48%, 100% 100%);
}

.emhp__destination-map::before {
	bottom: 17%;
	height: 48%;
	opacity: .32;
	background: #c2dbc3;
}

.emhp__destination-map::after {
	bottom: -4%;
	height: 48%;
	background: #092e28;
}

.emhp__map-lines {
	position: absolute;
	inset: 0;
	z-index: 2;
	opacity: .22;
	background-image:
		repeating-radial-gradient(
			ellipse at 56% 42%,
			transparent 0,
			transparent 18px,
			rgba(255, 255, 255, .34) 19px,
			transparent 20px
		);
}

.emhp__map-point {
	position: absolute;
	z-index: 4;
	width: min(210px, 60%);
	padding: 14px 16px;
	border: 1px solid rgba(255, 255, 255, .2);
	border-radius: 17px;
	color: var(--emhp-white);
	background: rgba(5, 32, 27, .7);
	box-shadow: 0 16px 34px rgba(0, 0, 0, .22);
	backdrop-filter: blur(9px);
}

.emhp__map-point span {
	display: block;
	margin-bottom: 5px;
	color: #d8efaf;
	font-size: .7rem;
	font-weight: 800;
	letter-spacing: .12em;
}

.emhp__map-point strong,
.emhp__map-point small {
	display: block;
}

.emhp__map-point strong {
	margin-bottom: 3px;
	font-size: .91rem;
}

.emhp__map-point small {
	color: rgba(255, 255, 255, .66);
	font-size: .76rem;
}

.emhp__map-point--one {
	top: 10%;
	left: 7%;
}

.emhp__map-point--two {
	top: 40%;
	right: 6%;
}

.emhp__map-point--three {
	right: 18%;
	bottom: 8%;
}

/* =========================================================
   PRÉPARATION ET SÉCURITÉ
   ========================================================= */

.emhp__prepare-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.emhp__prepare-step {
	position: relative;
	min-height: 230px;
	padding: 25px;
	border: 1px solid var(--emhp-border);
	border-radius: var(--emhp-radius-sm);
	background: rgba(255, 255, 255, .78);
}

.emhp__prepare-step > span {
	display: inline-flex;
	margin-bottom: 36px;
	color: var(--emhp-forest);
	font-size: .76rem;
	font-weight: 900;
	letter-spacing: .12em;
}

.emhp__prepare-step p {
	margin-bottom: 0;
	font-size: .93rem;
	line-height: 1.6;
}

.emhp__safety {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: 24px;
	align-items: center;
	margin-top: 18px;
	padding: clamp(24px, 4vw, 38px);
	border-radius: var(--emhp-radius-md);
	color: var(--emhp-white);
	background:
		linear-gradient(125deg, #6b351f, #a95532);
	box-shadow: var(--emhp-shadow-md);
}

.emhp__safety h3,
.emhp__safety p {
	color: var(--emhp-white);
}

.emhp__safety p {
	margin-bottom: 0;
	color: rgba(255, 255, 255, .81);
}

.emhp__safety-icon {
	display: grid;
	width: 58px;
	height: 58px;
	place-items: center;
	border-radius: 18px;
	background: rgba(255, 255, 255, .13);
	font-size: 1.35rem;
}

.emhp__safety-label {
	margin-bottom: 5px !important;
	color: #ffe3a2 !important;
	font-size: .72rem !important;
	font-weight: 900;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.emhp__safety > a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 11px 17px;
	border-radius: 999px;
	color: #6b351f;
	background: var(--emhp-white);
	font-size: .86rem;
	font-weight: 800;
	white-space: nowrap;
}

/* =========================================================
   APPROCHE ÉDITORIALE
   ========================================================= */

.emhp__section--approach {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
	gap: clamp(35px, 7vw, 90px);
	align-items: center;
}

.emhp__approach-grid {
	display: grid;
	gap: 12px;
}

.emhp__approach-grid > div {
	display: grid;
	grid-template-columns: 46px minmax(0, 1fr);
	column-gap: 16px;
	padding: 21px;
	border: 1px solid var(--emhp-border);
	border-radius: var(--emhp-radius-sm);
	background: rgba(255, 255, 255, .75);
}

.emhp__approach-grid span {
	grid-row: 1 / span 2;
	display: grid;
	width: 46px;
	height: 46px;
	place-items: center;
	border-radius: 15px;
	color: var(--emhp-white);
	background: var(--emhp-forest);
	font-weight: 900;
}

.emhp__approach-grid h3 {
	margin-bottom: 5px;
	font-size: 1.08rem;
}

.emhp__approach-grid p {
	margin-bottom: 0;
	font-size: .9rem;
	line-height: 1.55;
}

/* =========================================================
   FAQ
   ========================================================= */

.emhp__faq-list {
	display: grid;
	gap: 12px;
}

.emhp__faq-list details {
	overflow: hidden;
	border: 1px solid var(--emhp-border);
	border-radius: 20px;
	color: var(--emhp-ink);
	background: rgba(255, 255, 255, .9);
	box-shadow: var(--emhp-shadow-sm);
}

.emhp__faq-list summary {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 76px;
	padding: 19px 72px 19px 24px;
	color: var(--emhp-ink);
	background: transparent;
	font-size: clamp(1rem, .95rem + .2vw, 1.12rem);
	font-weight: 800;
	line-height: 1.35;
	list-style: none;
	cursor: pointer;
}

.emhp__faq-list summary::-webkit-details-marker {
	display: none;
}

.emhp__faq-list summary::after {
	content: "+";
	position: absolute;
	top: 50%;
	right: 20px;
	display: grid;
	width: 38px;
	height: 38px;
	place-items: center;
	transform: translateY(-50%);
	border-radius: 50%;
	color: var(--emhp-white);
	background: var(--emhp-forest);
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1;
	transition:
		transform var(--emhp-transition),
		background var(--emhp-transition);
}

.emhp__faq-list details[open] summary::after {
	content: "−";
	transform: translateY(-50%) rotate(180deg);
	background: var(--emhp-copper);
}

.emhp__faq-list details > div {
	padding: 0 24px 22px;
}

.emhp__faq-list details > div p {
	margin: 0;
	color: var(--emhp-ink-soft);
}

/* =========================================================
   CLOSING
   ========================================================= */

.emhp__closing {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 40px;
	align-items: center;
	max-width: 1240px;
	margin: clamp(36px, 7vw, 92px) auto 0;
	padding: clamp(32px, 6vw, 68px);
	overflow: hidden;
	border-radius: var(--emhp-radius-lg);
	color: var(--emhp-white);
	background:
		radial-gradient(circle at 90% 10%, rgba(245, 189, 67, .25), transparent 25%),
		linear-gradient(130deg, #082823, #17664f);
	box-shadow: var(--emhp-shadow-lg);
}

.emhp__closing::after {
	content: "";
	position: absolute;
	right: -6%;
	bottom: -31%;
	width: 46%;
	height: 100%;
	opacity: .22;
	background: #cbe4cb;
	clip-path: polygon(0 100%, 14% 58%, 32% 70%, 54% 20%, 71% 61%, 86% 42%, 100% 71%, 100% 100%);
}

.emhp__closing > * {
	position: relative;
	z-index: 2;
}

.emhp__closing h2,
.emhp__closing p {
	color: var(--emhp-white);
}

.emhp__closing h2 {
	max-width: 790px;
	font-size: clamp(1.8rem, 1.25rem + 2vw, 3.2rem);
}

.emhp__closing p {
	max-width: 760px;
	margin-bottom: 0;
	color: rgba(255, 255, 255, .79);
}

.emhp__closing-kicker {
	margin-bottom: 8px !important;
	color: #d8efaf !important;
	font-size: .76rem !important;
	font-weight: 900;
	letter-spacing: .13em;
	text-transform: uppercase;
}

.emhp__closing-actions {
	flex-direction: column;
	align-items: stretch;
	min-width: 225px;
}

/* =========================================================
   FLUX D’ARTICLES EXISTANT
   ========================================================= */

body.page1 .sscms_content_index {
	margin-top: 36px;
}

body.page1 .classic_display_article > h2 {
	margin-bottom: 26px;
	color: #123f36;
	background: none;
	background-image: none;
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	font-size: clamp(1.7rem, 1.25rem + 1.3vw, 2.6rem);
	line-height: 1.1;
	letter-spacing: -.035em;
}

body.page1 .classic_display_article .gal_item {
	overflow: hidden;
	border-radius: 18px;
	box-shadow: 0 12px 30px rgba(7, 40, 34, .1);
	transition:
		transform 220ms ease,
		box-shadow 220ms ease;
}

body.page1 .classic_display_article .gal_item:hover {
	transform: translateY(-4px);
	box-shadow: 0 22px 46px rgba(7, 40, 34, .17);
}

body.page1 .classic_display_article .gal_item img {
	transition: transform 420ms ease;
}

body.page1 .classic_display_article .gal_item:hover img {
	transform: scale(1.035);
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 1080px) {
	.emhp__universe-grid,
	.emhp__guide-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.emhp__prepare-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.emhp__section--destinations,
	.emhp__section--approach {
		grid-template-columns: 1fr;
	}

	.emhp__destination-map {
		min-height: 420px;
	}

	.emhp__closing {
		grid-template-columns: 1fr;
	}

	.emhp__closing-actions {
		flex-direction: row;
		min-width: 0;
	}
}

@media (max-width: 820px) {
	body.page1 .slider_wrapper {
		height: 650px !important;
		min-height: 650px;
	}

	body.page1 .slider_wrapper .caption {
		width: calc(100% - 28px);
		padding: 24px 18px !important;
	}

	body.page1 .hyperhauth1 {
		margin-top: -34px;
	}

	body.page1 .hyperhauth1 h1.title {
		width: 100% !important;
		padding: 17px 20px !important;
	}

	.emhp {
		padding: 22px 12px 34px;
		border-radius: 26px;
	}

	.emhp__summit {
		min-height: 650px;
		padding: 38px 24px;
	}

	.emhp__summit-points {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.emhp__section-heading {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.emhp__season-grid {
		grid-template-columns: 1fr;
	}

	.emhp__season-card {
		min-height: 0;
	}

	.emhp__safety {
		grid-template-columns: auto minmax(0, 1fr);
	}

	.emhp__safety > a {
		grid-column: 1 / -1;
	}

	.emhp__section--seasons {
		margin-right: -12px;
		margin-left: -12px;
		border-radius: 28px;
	}
}

@media (max-width: 620px) {
	body.page1 .slider_wrapper {
		height: 620px !important;
		min-height: 620px;
	}

	body.page1 .slider_wrapper .caption .caplogo {
		max-width: 145px;
	}

	body.page1 #cpationctarea {
		flex-direction: column;
		align-items: stretch;
	}

	body.page1 #cpationctarea .cta-btn,
	body.page1 #cpationctarea .cta2advanced {
		width: 100%;
	}

	.emhp h2 {
		font-size: clamp(1.75rem, 8vw, 2.55rem);
	}

	.emhp__summit {
		min-height: 690px;
		padding: 34px 19px;
		border-radius: 26px;
	}

	.emhp__summit h2 {
		font-size: clamp(2.25rem, 12vw, 3.5rem);
	}

	.emhp__summit-actions,
	.emhp__closing-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.emhp__button {
		width: 100%;
	}

	.emhp__summit-points,
	.emhp__universe-grid,
	.emhp__guide-grid,
	.emhp__prepare-grid {
		grid-template-columns: 1fr;
	}

	.emhp__universe-card {
		min-height: 280px;
	}

	.emhp__section--destinations {
		padding: 27px 19px;
		border-radius: 26px;
	}

	.emhp__destination-map {
		min-height: 480px;
	}

	.emhp__map-point {
		width: calc(100% - 34px);
		right: 17px;
		left: 17px;
	}

	.emhp__map-point--one {
		top: 7%;
	}

	.emhp__map-point--two {
		top: 38%;
	}

	.emhp__map-point--three {
		right: 17px;
		bottom: 7%;
	}

	.emhp__safety {
		grid-template-columns: 1fr;
	}

	.emhp__safety-icon {
		width: 48px;
		height: 48px;
	}

	.emhp__approach-grid > div {
		grid-template-columns: 42px minmax(0, 1fr);
		padding: 18px;
	}

	.emhp__approach-grid span {
		width: 42px;
		height: 42px;
	}

	.emhp__faq-list summary {
		min-height: 72px;
		padding: 17px 62px 17px 18px;
	}

	.emhp__faq-list summary::after {
		right: 14px;
		width: 36px;
		height: 36px;
	}

	.emhp__faq-list details > div {
		padding: 0 18px 20px;
	}

	.emhp__closing {
		padding: 30px 20px;
		border-radius: 26px;
	}
}

@media (prefers-reduced-motion: no-preference) {
	.emhp__summit,
	.emhp__universe-card,
	.emhp__season-card,
	.emhp__guide-card,
	.emhp__prepare-step,
	.emhp__destination-map,
	.emhp__closing {
		animation: emhp-rise .72s both;
	}

	.emhp__universe-card:nth-child(2),
	.emhp__season-card:nth-child(2),
	.emhp__guide-card:nth-child(2),
	.emhp__prepare-step:nth-child(2) {
		animation-delay: .06s;
	}

	.emhp__universe-card:nth-child(3),
	.emhp__season-card:nth-child(3),
	.emhp__guide-card:nth-child(3),
	.emhp__prepare-step:nth-child(3) {
		animation-delay: .12s;
	}

	.emhp__universe-card:nth-child(4),
	.emhp__guide-card:nth-child(4),
	.emhp__prepare-step:nth-child(4) {
		animation-delay: .18s;
	}
}

@media (prefers-reduced-motion: reduce) {
	.emhp *,
	body.page1 .slider_wrapper * {
		scroll-behavior: auto !important;
		animation: none !important;
		transition-duration: .01ms !important;
	}
}

@keyframes emhp-rise {
	from {
		opacity: 0;
		transform: translateY(18px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* =========================================================
   PATCH HOMEPAGE — H1, HERO PLEINE HAUTEUR ET CARTES
   ========================================================= */

/*
 * Le rich content est placé dans la colonne principale,
 * à côté de la sidebar. Les media queries basées uniquement
 * sur la largeur de l’écran ne suffisent donc pas.
 */
.emhp {
	container-name: emhp-home;
	container-type: inline-size;
}

/* H1 intégré au hero */
.emhp .emhp__h1 {
	max-width: 900px;
	margin: 0 0 20px !important;
	padding: 0 !important;
	color: #ffffff !important;
	background: transparent !important;
	background-image: none !important;
	border: 0 !important;
	box-shadow: none !important;
	font-family: "IBM Plex Sans", "Open Sans", Arial, sans-serif;
	font-size: clamp(2.55rem, 1.45rem + 4.1vw, 5.5rem);
	font-weight: 800;
	line-height: .94;
	letter-spacing: -.06em;
	text-align: left;
	text-wrap: balance;
	text-shadow: 0 7px 34px rgba(0, 0, 0, .34);
}

.emhp .emhp__hero-hook {
	max-width: 740px;
	margin: 0 0 18px;
	color: #d8efaf;
	font-size: clamp(1.18rem, 1rem + .7vw, 1.75rem);
	font-weight: 750;
	line-height: 1.28;
	letter-spacing: -.025em;
	text-wrap: balance;
}

/* Hero interne sur toute la hauteur de l’écran */
.emhp .emhp__summit {
	width: 100%;
	min-height: 100svh;
	height: auto;
	align-items: center;
}

@supports (min-height: 100dvh) {
	.emhp .emhp__summit {
		min-height: 100dvh;
	}
}

/* Les cartes sont désormais des DIV, pas des liens blocs */
.emhp .emhp__universe-card,
.emhp .emhp__guide-card {
	width: 100%;
	min-width: 0;
	overflow: hidden;
}

.emhp .emhp__universe-card > *,
.emhp .emhp__guide-card > * {
	position: relative;
	z-index: 2;
	min-width: 0;
}

.emhp .emhp__universe-card h3,
.emhp .emhp__universe-card p,
.emhp .emhp__guide-card h3,
.emhp .emhp__guide-card p {
	max-width: 100%;
	overflow-wrap: normal;
	word-break: normal;
	hyphens: auto;
}

.emhp .emhp__card-link {
	position: relative;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	width: fit-content;
	margin-top: auto;
	padding: 9px 13px;
	border-radius: 999px;
	color: var(--emhp-white);
	background: var(--emhp-dark);
	font-size: .86rem;
	font-weight: 800;
	line-height: 1.25;
	transition:
		transform var(--emhp-transition),
		background var(--emhp-transition),
		box-shadow var(--emhp-transition);
}

.emhp .emhp__card-link::after {
	content: " →";
	margin-left: 5px;
}

.emhp .emhp__card-link:hover {
	transform: translateY(-2px);
	background: var(--emhp-forest);
	box-shadow: 0 9px 20px rgba(7, 40, 34, .18);
}

.emhp .emhp__guide-card h3 a {
	color: var(--emhp-ink);
	text-decoration: none;
}

.emhp .emhp__guide-card h3 a:hover {
	color: var(--emhp-forest);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

/*
 * Valeurs desktop normales.
 * Les container queries ci-dessous prendront ensuite le relais
 * selon la largeur réelle de la colonne principale.
 */
.emhp .emhp__universe-grid,
.emhp .emhp__guide-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	align-items: stretch;
}

.emhp .emhp__universe-card {
	min-height: 310px;
}

/* Colonne réelle comprise entre 621 et 920 px */
@container emhp-home (max-width: 920px) {
	.emhp__section-heading {
		grid-template-columns: 1fr;
		gap: 12px;
		align-items: start;
	}

	.emhp__universe-grid,
	.emhp__guide-grid,
	.emhp__prepare-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.emhp__season-grid {
		grid-template-columns: 1fr;
	}

	.emhp__section--destinations,
	.emhp__section--approach,
	.emhp__closing {
		grid-template-columns: 1fr;
	}

	.emhp__closing-actions {
		flex-direction: row;
		min-width: 0;
	}

	.emhp__summit-points {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* Cas visible sur ta capture : colonne étroite avec sidebar */
@container emhp-home (max-width: 620px) {
	.emhp .emhp__summit {
		min-height: 100svh;
		padding: clamp(30px, 8cqw, 52px) clamp(18px, 6cqw, 30px);
		border-radius: 26px;
	}

	.emhp .emhp__h1 {
		font-size: clamp(2.35rem, 11cqw, 3.75rem);
		line-height: .96;
		letter-spacing: -.055em;
	}

	.emhp .emhp__hero-hook {
		font-size: clamp(1.08rem, 4.8cqw, 1.42rem);
	}

	.emhp__summit-actions,
	.emhp__closing-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.emhp__button {
		width: 100%;
	}

	.emhp__summit-points {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.emhp__universe-grid,
	.emhp__guide-grid,
	.emhp__prepare-grid {
		grid-template-columns: 1fr;
	}

	.emhp__universe-card {
		min-height: 290px;
		padding: 25px;
	}

	.emhp__guide-card {
		min-height: 220px;
	}

	.emhp__section--seasons {
		margin-right: -12px;
		margin-left: -12px;
		padding-right: 18px;
		padding-left: 18px;
		border-radius: 26px;
	}

	.emhp__destination-map {
		min-height: 480px;
	}

	.emhp__safety {
		grid-template-columns: 1fr;
	}

	.emhp__safety > a {
		width: 100%;
		white-space: normal;
	}

	.emhp__faq-list summary {
		padding-right: 64px;
	}
}

/* Très petite largeur réelle */
@container emhp-home (max-width: 390px) {
	.emhp .emhp__h1 {
		font-size: clamp(2.15rem, 11.5cqw, 3rem);
	}

	.emhp__summit-points {
		grid-template-columns: 1fr;
	}

	.emhp__universe-card {
		min-height: 270px;
	}

	.emhp__section--destinations {
		padding-right: 18px;
		padding-left: 18px;
	}

	.emhp__map-point {
		width: calc(100% - 28px);
		right: 14px;
		left: 14px;
	}
}

/* =========================================================
   PATCH FINAL HP
   - listes sans puces
   - numéros des cartes alignés
   - CTA commercial prioritaire
   - titre mobile proportionné
   - repères du hero cliquables
   ========================================================= */

/* Listes des blocs saisonniers : aucune puce native ou ajoutée */
.emhp .emhp__season-card ul,
.emhp .emhp__season-card li {
	list-style: none !important;
}

.emhp .emhp__season-card ul {
	margin-left: 0 !important;
	padding-left: 0 !important;
}

.emhp .emhp__season-card li {
	padding-left: 0 !important;
}

.emhp .emhp__season-card li::before,
.emhp .emhp__season-card li::after,
.emhp .emhp__season-card li::marker {
	display: none !important;
	content: none !important;
}

/* Numéros 01, 02, 03... parfaitement alignés en haut à droite */
.emhp .emhp__universe-number {
	position: absolute !important;
	top: 28px !important;
	right: 28px !important;
	bottom: auto !important;
	left: auto !important;
	z-index: 4 !important;
	display: block !important;
	width: auto !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	transform: none !important;
	color: rgba(20, 32, 29, .24) !important;
	font-size: .78rem !important;
	font-weight: 800 !important;
	font-variant-numeric: tabular-nums;
	line-height: 1 !important;
	letter-spacing: .13em !important;
}

/* Les quatre repères du hero deviennent de vraies cartes cliquables */
.emhp .emhp__summit-points a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
	min-height: 78px;
	padding: 12px 15px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 16px;
	color: rgba(255, 255, 255, .73) !important;
	background: rgba(0, 0, 0, .12);
	box-shadow: none;
	font-size: .82rem;
	line-height: 1.35;
	text-decoration: none !important;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	transition:
		transform 180ms ease,
		background 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease;
}

.emhp .emhp__summit-points a strong {
	display: block;
	margin: 0 0 3px;
	color: #ffffff !important;
	font-size: .91rem;
	line-height: 1.25;
}

.emhp .emhp__summit-points a small {
	display: block;
	color: rgba(255, 255, 255, .72) !important;
	font-size: .8rem;
	line-height: 1.35;
}

.emhp .emhp__summit-points a:hover,
.emhp .emhp__summit-points a:focus-visible {
	transform: translateY(-3px);
	border-color: rgba(216, 239, 175, .58);
	background: rgba(255, 255, 255, .12);
	box-shadow: 0 13px 26px rgba(0, 0, 0, .17);
}

/* Le conteneur du vrai CTA commercial prend davantage de place */
body.page1 #cpationctarea .cta-btn-container-ss {
	flex: 1 1 300px !important;
	width: auto !important;
	max-width: 360px;
	margin: 0 !important;
	padding: 0 !important;
}

/* CTA commercial principal */
body.page1 #cpationctarea .cta-btn.cta2advanced {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 100% !important;
	min-height: 52px !important;
	padding: 13px 23px !important;
	border: 1px solid #d8efaf !important;
	border-radius: 999px !important;
	color: #10241f !important;
	background:
		linear-gradient(135deg, #e6f5bd 0%, #cbe47d 55%, #b9d66b 100%) !important;
	box-shadow:
		0 15px 34px rgba(0, 0, 0, .26),
		inset 0 1px 0 rgba(255, 255, 255, .66) !important;
	font-size: .92rem !important;
	font-weight: 850 !important;
	line-height: 1.25 !important;
	text-align: center !important;
	text-decoration: none !important;
	text-shadow: none !important;
	cursor: pointer;
	transition:
		transform 180ms ease,
		filter 180ms ease,
		box-shadow 180ms ease;
}

body.page1 #cpationctarea .cta-btn.cta2advanced:hover,
body.page1 #cpationctarea .cta-btn.cta2advanced:focus {
	transform: translateY(-3px);
	filter: brightness(1.04);
	box-shadow:
		0 19px 40px rgba(0, 0, 0, .31),
		inset 0 1px 0 rgba(255, 255, 255, .72) !important;
}

/* Explorer reste visible, mais devient bien le bouton secondaire */
body.page1 #cpationctarea .emhp-caption__explore {
	flex: 0 1 190px !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 48px !important;
	padding: 12px 19px !important;
	border: 1px solid rgba(255, 255, 255, .3) !important;
	border-radius: 999px !important;
	color: #ffffff !important;
	background: rgba(255, 255, 255, .08) !important;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, .1) !important;
	font-size: .87rem !important;
	font-weight: 800 !important;
	line-height: 1.25 !important;
	text-align: center !important;
	text-decoration: none !important;
	text-shadow: none !important;
	backdrop-filter: blur(7px);
	-webkit-backdrop-filter: blur(7px);
	transition:
		transform 180ms ease,
		background 180ms ease,
		border-color 180ms ease;
}

body.page1 #cpationctarea .emhp-caption__explore:hover,
body.page1 #cpationctarea .emhp-caption__explore:focus {
	transform: translateY(-2px);
	border-color: rgba(255, 255, 255, .5) !important;
	background: rgba(255, 255, 255, .15) !important;
}

/* Mobile : conserver l'impact et les proportions du titre desktop */
@media (max-width: 560px) {
	body.page1 .emhp-caption__title {
		max-width: 11.5ch !important;
		margin: 0 auto 14px !important;
		font-size: clamp(2.1rem, 10.7vw, 3rem) !important;
		font-weight: 800 !important;
		line-height: .96 !important;
		letter-spacing: -.055em !important;
		text-wrap: balance;
	}

	body.page1 #cpationctarea {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 10px !important;
	}

	body.page1 #cpationctarea .cta-btn-container-ss,
	body.page1 #cpationctarea .emhp-caption__explore {
		width: 100% !important;
		max-width: none !important;
	}

	body.page1 #cpationctarea .cta-btn.cta2advanced {
		min-height: 52px !important;
		font-size: .92rem !important;
	}

	body.page1 #cpationctarea .emhp-caption__explore {
		min-height: 45px !important;
		font-size: .84rem !important;
	}

	.emhp .emhp__universe-number {
		top: 24px !important;
		right: 24px !important;
	}
}

/* =========================================================
PATCH FINAL HOMEPAGE
Compatible avec le HTML réellement généré par le CMS
========================================================= */

/* ---------------------------------------------------------

1. LISTES SAISONNIÈRES : SUPPRIMER TOUTES LES PUCES CMS
   --------------------------------------------------------- */

.emhp .emhp__season-card ul,
.emhp .emhp__season-card ol {
margin-left: 0 !important;
padding-left: 0 !important;
list-style: none !important;
}

.emhp .emhp__season-card li {
position: relative;
margin-left: 0 !important;
padding: 12px 0 !important;
list-style: none !important;
background-image: none !important;
}

.emhp .emhp__season-card li::before,
.emhp .emhp__season-card li::after,
.emhp .emhp__season-card li a::before,
.emhp .emhp__season-card li a::after {
display: none !important;
content: none !important;
width: 0 !important;
height: 0 !important;
margin: 0 !important;
padding: 0 !important;
background: none !important;
background-image: none !important;
border: 0 !important;
}

.emhp .emhp__season-card li::marker {
content: "" !important;
font-size: 0 !important;
}

/* ---------------------------------------------------------
2. NUMÉROS 01, 02, 03... ALIGNÉS DANS LES CARTES
--------------------------------------------------------- */

.emhp .emhp__universe-card {
position: relative !important;
}

.emhp .emhp__universe-card > .emhp__universe-number {
position: absolute !important;
top: 29px !important;
right: 29px !important;
bottom: auto !important;
left: auto !important;
z-index: 5 !important;
display: block !important;
width: auto !important;
min-width: 0 !important;
height: auto !important;
margin: 0 !important;
padding: 0 !important;
transform: none !important;
color: rgba(20, 32, 29, .25) !important;
background: transparent !important;
font-size: .78rem !important;
font-weight: 800 !important;
font-variant-numeric: tabular-nums;
line-height: 1 !important;
letter-spacing: .13em !important;
text-align: right !important;
}

/* ---------------------------------------------------------
3. LES QUATRE REPÈRES DU HERO SONT CLIQUABLES
--------------------------------------------------------- */

.emhp .emhp__summit-points a {
display: flex !important;
flex-direction: column;
justify-content: center;
min-width: 0;
min-height: 78px;
padding: 12px 15px;
overflow: hidden;
border: 1px solid rgba(255, 255, 255, .17);
border-radius: 16px;
color: rgba(255, 255, 255, .74) !important;
background: rgba(0, 0, 0, .14);
box-shadow: none;
font-size: .82rem;
line-height: 1.35;
text-decoration: none !important;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
transition:
transform 180ms ease,
border-color 180ms ease,
background 180ms ease,
box-shadow 180ms ease;
}

.emhp .emhp__summit-points a strong {
display: block;
margin: 0 0 4px;
color: #ffffff !important;
font-size: .91rem;
font-weight: 800;
line-height: 1.22;
}

.emhp .emhp__summit-points a small {
display: block;
color: rgba(255, 255, 255, .72) !important;
font-size: .8rem;
line-height: 1.34;
}

.emhp .emhp__summit-points a:hover,
.emhp .emhp__summit-points a:focus-visible {
transform: translateY(-3px);
border-color: rgba(216, 239, 175, .64);
background: rgba(255, 255, 255, .12);
box-shadow: 0 14px 28px rgba(0, 0, 0, .2);
}

/* ---------------------------------------------------------
4. CAPTION : STRUCTURE CMS CONSERVÉE
--------------------------------------------------------- */

body.page1 #cpationctarea {
display: grid !important;
grid-template-columns:
minmax(270px, 1.15fr)
minmax(180px, .85fr);
gap: 12px !important;
align-items: stretch;
width: 100%;
max-width: 690px;
margin: 24px auto 0 !important;
padding: 0 !important;
}

/*

* CTA principal réellement généré par le CMS :
*
* <span class="kamesen cta2advanced">...</span>
  */
  body.page1 #cpationctarea > span.kamesen.cta2advanced {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 54px !important;
  margin: 0 !important;
  padding: 13px 23px !important;
  border: 1px solid #d8efaf !important;
  border-radius: 999px !important;
  color: #10241f !important;
  background:
  linear-gradient(
  135deg,
  #eef8d2 0%,
  #d7ec9c 45%,
  #b9d66b 100%
  ) !important;
  box-shadow:
  0 16px 36px rgba(0, 0, 0, .29),
  inset 0 1px 0 rgba(255, 255, 255, .74) !important;
  font-size: .93rem !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
  text-align: center !important;
  text-decoration: none !important;
  text-shadow: none !important;
  cursor: pointer !important;
  transition:
  transform 180ms ease,
  filter 180ms ease,
  box-shadow 180ms ease;
  }

body.page1 #cpationctarea > span.kamesen.cta2advanced:hover,
body.page1 #cpationctarea > span.kamesen.cta2advanced:focus {
transform: translateY(-3px);
filter: brightness(1.035);
box-shadow:
0 20px 43px rgba(0, 0, 0, .34),
inset 0 1px 0 rgba(255, 255, 255, .8) !important;
}

/*

* Bouton secondaire réellement généré par le CMS :
*
* <a href="#pintitle">Explorer les guides</a>
  */
  body.page1 #cpationctarea > a[href="#pintitle"] {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 50px !important;
  margin: 0 !important;
  padding: 12px 20px !important;
  border: 1px solid rgba(255, 255, 255, .31) !important;
  border-radius: 999px !important;
  color: #ffffff !important;
  background: rgba(255, 255, 255, .085) !important;
  box-shadow:
  inset 0 1px 0 rgba(255, 255, 255, .1) !important;
  font-size: .87rem !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  text-align: center !important;
  text-decoration: none !important;
  text-shadow: none !important;
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  transition:
  transform 180ms ease,
  border-color 180ms ease,
  background 180ms ease;
  }

body.page1 #cpationctarea > a[href="#pintitle"]:hover,
body.page1 #cpationctarea > a[href="#pintitle"]:focus {
transform: translateY(-2px);
border-color: rgba(255, 255, 255, .52) !important;
background: rgba(255, 255, 255, .15) !important;
}

/* Neutraliser les effets parasites du thème */
body.page1 #cpationctarea > span.kamesen.cta2advanced::before,
body.page1 #cpationctarea > span.kamesen.cta2advanced::after,
body.page1 #cpationctarea > a[href="#pintitle"]::before,
body.page1 #cpationctarea > a[href="#pintitle"]::after {
display: none !important;
content: none !important;
}

/* ---------------------------------------------------------
5. MOBILE : TITRE AUSSI IMPACTANT QUE SUR DESKTOP
--------------------------------------------------------- */

@media (max-width: 560px) {
body.page1 .slider_wrapper .caption {
width: calc(100% - 24px) !important;
padding: 25px 17px 23px !important;
}


body.page1 .emhp-caption__title {
	width: 100% !important;
	max-width: 12ch !important;
	margin: 0 auto 15px !important;
	padding: 0 !important;
	color: #ffffff !important;
	font-size: clamp(2.2rem, 10.5vw, 2.95rem) !important;
	font-weight: 800 !important;
	line-height: .96 !important;
	letter-spacing: -.055em !important;
	text-align: center !important;
	text-wrap: balance;
}

body.page1 .emhp-caption__text {
	max-width: 32ch !important;
	margin-right: auto !important;
	margin-left: auto !important;
	font-size: .93rem !important;
	line-height: 1.5 !important;
}

body.page1 #cpationctarea {
	grid-template-columns: 1fr !important;
	gap: 10px !important;
	margin-top: 20px !important;
}

body.page1 #cpationctarea > span.kamesen.cta2advanced {
	min-height: 53px !important;
	font-size: .92rem !important;
}

body.page1 #cpationctarea > a[href="#pintitle"] {
	min-height: 45px !important;
	font-size: .84rem !important;
}

.emhp .emhp__universe-card > .emhp__universe-number {
	top: 25px !important;
	right: 25px !important;
}


}


/* =========================================================
MOBILE — CONSERVER TOUT LE CONTENU DU CAPTION
========================================================= */

@media (max-width: 560px) {
	/* Hauteur suffisante pour le logo, le titre, le texte et les CTA */
	body.page1 .slider_wrapper {
	height: max(100svh, 720px) !important;
	min-height: 720px !important;
	}


	/* Caption centré sans découpe verticale */
	body.page1 .slider_wrapper .caption {
		top: 50% !important;
		left: 50% !important;
		width: calc(100% - 20px) !important;
		max-width: 520px !important;
		max-height: none !important;
		margin: 0 !important;
		padding: 22px 16px !important;
		transform: translate(-50%, -50%) !important;
		overflow: visible !important;
		box-sizing: border-box !important;
	}

	/* Ne jamais masquer ou tronquer le contenu éditorial */
	body.page1 .slider_wrapper .caption .edito_txt_o,
	body.page1 .slider_wrapper .caption .emhp-caption,
	body.page1 .slider_wrapper .caption .emhp-caption__kicker,
	body.page1 .slider_wrapper .caption .emhp-caption__title,
	body.page1 .slider_wrapper .caption .emhp-caption__text {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		width: auto !important;
		max-height: none !important;
		overflow: visible !important;
		-webkit-line-clamp: initial !important;
	}

	/* Titre avec le même impact et les mêmes proportions que sur desktop */
	body.page1 .emhp-caption__title {
		max-width: 12ch !important;
		margin: 0 auto 14px !important;
		font-size: clamp(2.05rem, 10.5vw, 2.85rem) !important;
		font-weight: 800 !important;
		line-height: .96 !important;
		letter-spacing: -.055em !important;
		text-align: center !important;
		text-wrap: balance;
	}

	/* Le texte explicatif reste intégralement présent */
	body.page1 .emhp-caption__text {
		max-width: 35ch !important;
		margin: 0 auto !important;
		font-size: .92rem !important;
		line-height: 1.5 !important;
		text-align: center !important;
	}

	body.page1 .emhp-caption__kicker {
		margin-bottom: 9px !important;
	}

	/* Logo légèrement compacté pour libérer de la hauteur */
	body.page1 .slider_wrapper .caption .caplogo,
	body.page1 .slider_wrapper .caption img.caplogo,
	body.page1 .slider_wrapper .caption .caplogo img {
		max-width: 88px !important;
		max-height: 64px !important;
		margin-bottom: 14px !important;
	}

	body.page1 #cpationctarea {
		margin-top: 18px !important;
	}

}


@media (max-width: 768px) {
	.emhp .emhp__universe-grid,
	.emhp .emhp__guide-grid {
		grid-template-columns: minmax(0, 1fr) !important;
	}
}