/* =============================================================================
 * Boutique v2 — Editorial sandbox
 *
 * Magazine-style asymmetric layout inspired by verholy.com. Chapter-numbered
 * sections, massive italic serif headings that break the grid, photo+pill
 * service rows alternating left/right, clipped-serif manifesto moment,
 * cream tonal breaks. Reveal-on-scroll word-staggered text animations.
 *
 * Selectors namespaced as `.bv2-*` so this file can be deleted cleanly when
 * we promote v2 to the live boutique.
 * ========================================================================== */

/* --- Page-template reset ------------------------------------------------- */
.page-template-page-boutique-v2 .site-header { display: none !important; }
.page-template-page-boutique-v2,
.page-template-page-boutique-v2 .site,
.page-template-page-boutique-v2 .site-content,
.page-template-page-boutique-v2 .site-main,
.page-template-page-boutique-v2 .entry-content {
	max-width: none !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
}
.page-template-page-boutique-v2 { background: var(--exspa-sage-deep, #2B2522); }

.page-template-page-boutique-v2 .bv2-section { margin: 0 !important; }

/* --- Shared section primitives ----------------------------------------- */
.bv2-section {
	position: relative;
	overflow: hidden;
	color: var(--exspa-cream, #EFE8DA);
	font-family: 'Inter', system-ui, sans-serif;
}
.bv2-section__curve {
	position: absolute;
	left: -5%; bottom: -10%;
	width: 80%;
	height: auto;
	color: var(--exspa-cream, #EFE8DA);
	opacity: 0.18;
	pointer-events: none;
}
.bv2-section__curve--right {
	left: auto; right: -5%; bottom: auto; top: 25%;
	width: 50%;
	color: var(--exspa-gold, #8B6F3D);
	opacity: 0.25;
}

/* --- Chapter eyebrow --------------------------------------------------- */
.bv2-chapter {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	margin: 0;
	opacity: 0.55;
}
.bv2-chapter--gold {
	color: var(--exspa-gold, #8B6F3D);
	opacity: 0.95;
}

/* --- Massive italic serif display -------------------------------------- */
.bv2-display {
	font-family: 'Cormorant Garamond', 'EB Garamond', Georgia, serif;
	font-weight: 400;
	line-height: 0.96;
	letter-spacing: -0.015em;
}
.bv2-display em { font-style: italic; }

/* =============================================================================
 * Chapter A · Hero
 * ========================================================================== */
.bv2-hero {
	background: var(--exspa-sage-deep, #2B2522);
	padding: 18vh 6vw 14vh;
	min-height: 92svh;
	display: flex; flex-direction: column; justify-content: center;
}
.bv2-hero > .bv2-chapter {
	position: absolute;
	top: 14vh; right: 6vw;
}
.bv2-hero__title {
	/* -30 % from the previous clamp(72px, 14vw, 240px) per client direction */
	font-size: clamp(50px, 9.8vw, 168px);
	max-width: 14ch;
	color: var(--exspa-cream, #EFE8DA);
	margin: 0;
}
.bv2-hero__sub {
	margin-top: 5vh;
	margin-left: 50%;
	max-width: 38ch;
	font-size: 16.5px;
	line-height: 1.7;
	opacity: 0.72;
}

/* =============================================================================
 * Chapter B · Manifesto (clipped serif over atmospheric backdrop)
 *
 * Layered visual: dim spa photo backdrop fades from full to dark across the
 * section, the massive serif title sits on top with a brighter spa photo
 * clipped through the letters via background-clip: text. The text reads
 * even where the clip image is dark because we add a subtle cream stroke
 * via text-shadow.
 * ========================================================================== */
.bv2-manifesto {
	background: var(--exspa-sage-deep, #2B2522);
	padding: 18vh 5vw 18vh;
	min-height: 90svh;
	position: relative;
	overflow: hidden;
}
.bv2-manifesto__backdrop {
	position: absolute;
	inset: 0;
	background-image: var(--bv2-bg, none);
	background-size: cover;
	background-position: center;
	opacity: 0.40;
	z-index: 0;
	pointer-events: none;
	filter: saturate(0.7) brightness(0.85);
}
/* Layered gradient on top of the backdrop for atmospheric vignette */
.bv2-manifesto::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 30% 40%, transparent 0%, rgba(43, 37, 34, 0.45) 70%),
		linear-gradient(180deg, rgba(43, 37, 34, 0.35) 0%, rgba(43, 37, 34, 0.15) 40%, rgba(43, 37, 34, 0.65) 100%);
	z-index: 1;
	pointer-events: none;
}
.bv2-manifesto > *:not(.bv2-manifesto__backdrop) { position: relative; z-index: 2; }

.bv2-manifesto > .bv2-chapter {
	margin-bottom: 6vh;
	margin-left: 1vw;
}
.bv2-manifesto__title {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-weight: 400;
	font-size: clamp(64px, 13vw, 240px);
	line-height: 0.94;
	letter-spacing: -0.02em;
	max-width: 16ch;
	margin: 0;
	/* The clip stack: bright photo clipped into letters + cream fallback */
	color: rgba(239, 232, 218, 0.92); /* visible even if clip fails */
	background-image: var(--bv2-clip-bg, none);
	background-size: 140% auto;
	background-position: center 42%;
	background-repeat: no-repeat;
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: rgba(239, 232, 218, 0.92);
	/* Subtle outline so the letters always read against any background */
	text-shadow:
		0 0 1px rgba(239, 232, 218, 0.18),
		0 4px 24px rgba(43, 37, 34, 0.6);
}
/* When the browser supports text-fill-color, make text transparent so the
   image shows through fully — but only where the image is bright enough. */
@supports (-webkit-text-fill-color: transparent) {
	.bv2-manifesto__title {
		-webkit-text-fill-color: transparent;
		color: transparent;
	}
}
.bv2-manifesto__title em { font-style: italic; }

.bv2-manifesto__copy {
	position: absolute;
	right: 5vw; bottom: 14vh;
	max-width: 36ch;
	font-size: 15.5px;
	line-height: 1.75;
	color: var(--exspa-cream, #EFE8DA);
	opacity: 0.85;
}

/* =============================================================================
 * Chapter C · Asymmetric service rows
 * ========================================================================== */
.bv2-services {
	background: var(--exspa-sage-deep, #2B2522);
	padding: 16vh 0 18vh;
}
.bv2-services > .bv2-chapter {
	position: absolute;
	top: 10vh; left: 6vw;
}
.bv2-services__heading {
	color: var(--exspa-cream, #EFE8DA);
	font-size: clamp(36px, 5vw, 64px);
	line-height: 1.05;
	margin: 0 0 12vh 6vw;
	max-width: 14ch;
}

.bv2-row {
	position: relative;
	margin-bottom: 14vh;
	min-height: 56vh;
}
.bv2-row:last-of-type { margin-bottom: 0; }

.bv2-row__media {
	width: 62vw;
	max-width: 1100px;
	aspect-ratio: 16 / 10;
	overflow: hidden;
}
.bv2-row__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 1.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.bv2-row:hover .bv2-row__media img { transform: scale(1.04); }

.bv2-row__pill {
	background: var(--exspa-cream, #EFE8DA);
	color: var(--exspa-sage-deep, #2B2522);
	padding: clamp(36px, 4vw, 64px) clamp(28px, 3vw, 56px);
	width: 38vw;
	max-width: 560px;
	position: absolute;
	right: 4vw;
	top: 12%;
	box-shadow: 0 32px 64px -32px rgba(0, 0, 0, 0.45);
}
.bv2-row--mirror .bv2-row__media { margin-left: auto; }
.bv2-row--mirror .bv2-row__pill { right: auto; left: 4vw; }

.bv2-row__num {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--exspa-gold, #8B6F3D);
	margin: 0 0 16px;
	opacity: 0.95;
}
.bv2-row__name {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-weight: 400;
	font-size: clamp(34px, 4vw, 56px);
	line-height: 1.05;
	letter-spacing: -0.01em;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0 0 14px;
}
.bv2-row__name em { font-style: italic; }
.bv2-row__lede {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-style: italic;
	font-size: clamp(18px, 2vw, 23px);
	line-height: 1.3;
	color: var(--exspa-sage, #394839);
	margin: 0 0 30px;
}
.bv2-row__note {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	letter-spacing: 0.03em;
	color: var(--exspa-gold, #8B6F3D);
	margin: -12px 0 26px;
	display: inline-flex;
	align-items: baseline;
	gap: 7px;
}
.bv2-row__note::before {
	content: '+';
	font-weight: 600;
	font-size: 13px;
}
.bv2-row__meta {
	display: flex; gap: 32px;
	border-top: 1px solid rgba(43, 37, 34, 0.18);
	padding-top: 20px;
	margin: 0 0 28px;
	position: relative;
}
.bv2-row__meta::before {
	content: '';
	position: absolute;
	top: -1px; left: 0;
	width: 28px; height: 1px;
	background: var(--exspa-gold, #8B6F3D);
}
.bv2-row__meta > div { display: flex; flex-direction: column; gap: 4px; }
.bv2-row__meta dt {
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--exspa-sage, #394839);
	opacity: 0.7;
	margin: 0;
}
.bv2-row__meta dd {
	margin: 0;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 19px;
	color: var(--exspa-sage-deep, #2B2522);
}
.bv2-row__price {
	font-family: 'Cormorant Garamond', serif;
	font-size: clamp(40px, 4vw, 56px);
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0 0 28px;
	line-height: 1;
}
.bv2-row__price small {
	font-family: 'Inter', sans-serif;
	font-size: 10.5px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--exspa-sage, #394839);
	opacity: 0.65;
	display: block;
	margin-top: 6px;
}
.bv2-row__cta {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
	text-decoration: none;
	padding: 0 0 8px;
	border-bottom: 1px solid var(--exspa-sage-deep, #2B2522);
	transition: gap 280ms ease, color 280ms ease, border-color 280ms ease;
}
.bv2-row__cta:hover { gap: 22px; color: var(--exspa-gold, #8B6F3D); border-color: var(--exspa-gold, #8B6F3D); }
.bv2-row__cta svg { transition: transform 280ms ease; }
.bv2-row__cta:hover svg { transform: translateX(4px); }

/* =============================================================================
 * Chapter D · Engagement (cream tonal break)
 * ========================================================================== */
.bv2-engagement {
	background: var(--exspa-cream, #EFE8DA);
	color: var(--exspa-sage-deep, #2B2522);
	padding: 18vh 0 18vh;
}
.bv2-engagement__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 6vw;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6vw;
	align-items: start;
}
.bv2-engagement__media {
	width: 100%;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	margin-left: -3vw;
	max-width: 520px;
}
.bv2-engagement__media img {
	width: 100%; height: 100%; object-fit: cover;
}
/* Full-width lead line above the image/text row. Holds the first half of the
 * heading ("Parce que notre engagement"); the row continues the sentence. */
.bv2-engagement__head {
	max-width: 1280px;
	margin: 0 auto 5vh;
	padding: 0 6vw;
}
.bv2-engagement__head .bv2-chapter {
	color: var(--exspa-gold, #8B6F3D);
	opacity: 0.95;
	margin-bottom: 20px;
}
.bv2-engagement__lead {
	font-family: var(--exspa-font-display, 'Romance', 'Cormorant Garamond', Georgia, serif);
	font-weight: 400;
	text-transform: uppercase;
	font-size: clamp(28px, 3.8vw, 56px);
	line-height: 1.02;
	letter-spacing: 0.01em;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0;
}
.bv2-engagement__copy { padding-bottom: 4vh; }
/* Second half of the heading, living in the right column under the row. */
.bv2-engagement__rest {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
	text-transform: uppercase;
	font-size: clamp(28px, 3.8vw, 56px);
	line-height: 1.02;
	letter-spacing: -0.01em;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0 0 28px;
}
.bv2-engagement__rest em {
	font-style: italic;
	text-transform: none;
	color: var(--exspa-sage, #394839);
}
.bv2-engagement__body {
	max-width: 44ch;
	font-size: 16px;
	line-height: 1.75;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.85;
	margin: 0;
}

/* =============================================================================
 * Chapter D½ · Soins additionnels — 4-portrait-card grid
 *
 * Inspired by the spa-suite.com "Espace Soins Duo" pattern: deep solid panel,
 * 4 portrait cards in a row, each with a photo and a gold-bordered info area
 * beneath. Adapted to sage-deep + cream + gold (their version was navy + gold).
 * ========================================================================== */
.bv2-soins {
	background: var(--exspa-sage-deep, #2B2522);
	color: var(--exspa-cream, #EFE8DA);
	padding: 14vh 5vw 14vh;
	text-align: center;
}
.bv2-soins__header {
	max-width: 920px;
	margin: 0 auto 8vh;
}
.bv2-soins__header .bv2-chapter { margin-bottom: 24px; }
.bv2-soins__heading {
	font-size: clamp(36px, 5.5vw, 72px);
	color: var(--exspa-cream, #EFE8DA);
	margin: 0 0 28px;
}
.bv2-soins__lede {
	font-size: 16.5px;
	line-height: 1.7;
	max-width: 56ch;
	margin: 0 auto;
	opacity: 0.78;
}

.bv2-soins__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(16px, 2vw, 32px);
	max-width: 1320px;
	margin: 0 auto;
}

.bv2-soin {
	display: flex;
	flex-direction: column;
	transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
}
.bv2-soin:hover { transform: translateY(-6px); }

.bv2-soin__media {
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: var(--exspa-sage, #394839);
}
.bv2-soin__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
}
.bv2-soin:hover .bv2-soin__media img { transform: scale(1.04); }

.bv2-soin__info {
	border: 1px solid var(--exspa-gold, #8B6F3D);
	border-top: none; /* photo edge already closes the box */
	padding: 22px 18px 24px;
	text-align: center;
	background: transparent;
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-height: 110px;
	transition: background 400ms ease, border-color 400ms ease;
}
.bv2-soin:hover .bv2-soin__info {
	background: rgba(139, 111, 61, 0.08);
	border-color: var(--exspa-cream, #EFE8DA);
}

.bv2-soin__title {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-weight: 400;
	font-size: clamp(20px, 1.8vw, 26px);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--exspa-cream, #EFE8DA);
	margin: 0;
	line-height: 1.1;
}
.bv2-soin__sub {
	display: flex;
	justify-content: center;
	align-items: baseline;
	gap: 12px;
	font-size: 14px;
	color: var(--exspa-cream, #EFE8DA);
	opacity: 0.78;
	margin: 0;
	font-family: 'Inter', sans-serif;
}
.bv2-soin__price {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 18px;
	color: var(--exspa-gold, #8B6F3D);
	opacity: 1;
}

.bv2-soins__cta-wrap {
	text-align: center;
	margin-top: 6vh;
}
.bv2-soins__cta {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	padding: 18px 42px;
	background: var(--exspa-gold, #8B6F3D);
	color: var(--exspa-cream, #EFE8DA);
	text-decoration: none;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	border: 1px solid var(--exspa-gold, #8B6F3D);
	transition: background 280ms ease, color 280ms ease, gap 280ms ease, transform 280ms ease;
}
.bv2-soins__cta:hover {
	background: transparent;
	color: var(--exspa-gold, #8B6F3D);
	gap: 22px;
	transform: translateY(-2px);
}
.bv2-soins__cta svg { transition: transform 280ms ease; }
.bv2-soins__cta:hover svg { transform: translateX(4px); }

@media (max-width: 900px) {
	.bv2-soins__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
	.bv2-soins { padding: 10vh 5vw; }
	.bv2-soins__grid { grid-template-columns: 1fr; gap: 24px; }
}

/* =============================================================================
 * Chapter E · Booking — atmospheric backdrop
 *
 * A dim spa photo sits behind the entire section with strong sage-deep
 * gradient overlay so empty space (Amelia widget not yet configured) reads
 * as deliberate atmosphere. The cream booking frame floats on top.
 * ========================================================================== */
.bv2-booking {
	background: var(--exspa-sage-deep, #2B2522);
	padding: 14vh 5vw 16vh;
	position: relative;
	overflow: hidden;
}
.bv2-booking__backdrop {
	position: absolute;
	inset: 0;
	background-image: var(--bv2-bg, none);
	background-size: cover;
	background-position: center 60%;
	opacity: 0.62;
	z-index: 0;
	pointer-events: none;
	filter: saturate(0.85) brightness(0.85);
	/* Longer, gentler bottom dissolve — the photo starts fading at 50%
	   instead of 68% so the transition into the next sage-deep section
	   is genuinely seamless (no visible edge). */
	-webkit-mask-image: linear-gradient(180deg, #000 0%, #000 50%, transparent 100%);
	        mask-image: linear-gradient(180deg, #000 0%, #000 50%, transparent 100%);
}
.bv2-booking::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 50% 100%, rgba(239, 232, 218, 0.08) 0%, transparent 60%),
		linear-gradient(180deg,
			rgba(43, 37, 34, 0.25) 0%,    /* much lighter at top — let the photo breathe */
			rgba(43, 37, 34, 0.10) 25%,   /* near-transparent middle */
			rgba(43, 37, 34, 0.45) 70%,
			var(--exspa-sage-deep, #2B2522) 100%);
	z-index: 1;
	pointer-events: none;
}
.bv2-booking > *:not(.bv2-booking__backdrop) { position: relative; z-index: 2; }

.bv2-booking > .bv2-chapter { margin-bottom: 24px; }
.bv2-booking__heading {
	font-size: clamp(40px, 6vw, 84px);
	color: var(--exspa-cream, #EFE8DA);
	margin: 0 0 24px;
	max-width: 12ch;
}
.bv2-booking__lede {
	max-width: 48ch;
	font-size: 16.5px;
	line-height: 1.65;
	color: var(--exspa-cream, #EFE8DA);
	opacity: 0.85;
	margin: 0 0 64px;
}
.bv2-booking__frame {
	max-width: 1080px;
	margin: 0 auto;
	background: rgba(239, 232, 218, 0.96);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: var(--exspa-sage-deep, #2B2522);
	padding: clamp(32px, 4vw, 64px);
	min-height: 480px;
	box-shadow:
		0 32px 80px -32px rgba(0, 0, 0, 0.5),
		0 0 0 1px rgba(139, 111, 61, 0.12);
}

/* --- Booking trigger cards — PREMIUM LUXURY-BOOKABLE -----------------------
 * Layered card system:
 *   1. .bv2-booking__trigger-paper  — cream layer offset behind the gold
 *      (the "letterhead" beneath the card)
 *   2. .bv2-booking__trigger         — main gold panel
 *   3. ::before / ::after            — inset cream frame + subtle highlight
 *   4. .bv2-booking__trigger-watermark — giant outline numeral (serial stamp)
 *   5. .bv2-booking__trigger-flourish  — gilt corner ornament
 *   6. .bv2-booking__trigger-inner    — actual content stack
 *
 * Hierarchy: number+tag → big italic name → divider → meta+EMBOSSED price → CTA
 * -------------------------------------------------------------------------- */
.bv2-booking__triggers {
	max-width: 1180px;
	margin: 8vh auto 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2vw, 30px);
}
.bv2-booking__trigger {
	background: var(--exspa-gold, #8B6F3D);
	color: var(--exspa-sage-deep, #2B2522);
	border: none;
	padding: 0;
	display: block;
	text-align: left;
	font-family: 'Inter', sans-serif;
	cursor: pointer;
	position: relative;
	min-height: 360px;
	transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1),
	            box-shadow 600ms cubic-bezier(0.22, 1, 0.36, 1);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.12),
		inset 0 -1px 0 rgba(43, 37, 34, 0.18),
		0 1px 0 rgba(43, 37, 34, 0.06);
	isolation: isolate;
}

/* Inset cream frame — "framed certificate" */
.bv2-booking__trigger::before {
	content: '';
	position: absolute;
	inset: 12px;
	border: 1px solid rgba(239, 232, 218, 0.45);
	pointer-events: none;
	z-index: 2;
	transition: border-color 600ms ease, inset 600ms cubic-bezier(0.22, 1, 0.36, 1);
}
/* Diagonal highlight wash (subtle "polished gold" sheen) */
.bv2-booking__trigger::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg,
			rgba(255, 255, 255, 0.10) 0%,
			transparent 35%,
			transparent 65%,
			rgba(43, 37, 34, 0.06) 100%);
	pointer-events: none;
	z-index: 1;
	transition: opacity 600ms ease;
}

/* Paper-layer offset — cream pseudo-card sitting just behind/below the gold */
.bv2-booking__trigger-paper {
	position: absolute;
	inset: 0;
	background: var(--exspa-cream, #EFE8DA);
	transform: translate(6px, 6px);
	z-index: -1;
	transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
	box-shadow: 0 1px 0 rgba(43, 37, 34, 0.08);
}

/* Giant watermark numeral — outline-only, fills the card as a serial stamp */
.bv2-booking__trigger-watermark {
	position: absolute;
	bottom: -0.18em;
	right: -0.08em;
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-style: italic;
	font-weight: 400;
	font-size: clamp(160px, 18vw, 240px);
	line-height: 1;
	color: transparent;
	-webkit-text-stroke: 1px rgba(43, 37, 34, 0.16);
	text-stroke: 1px rgba(43, 37, 34, 0.16);
	pointer-events: none;
	user-select: none;
	z-index: 0;
	transition: opacity 600ms ease, transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Gilt corner flourish — small SVG ornament top-right */
.bv2-booking__trigger-flourish {
	position: absolute;
	top: 18px;
	right: 18px;
	width: 28px;
	height: 28px;
	color: rgba(43, 37, 34, 0.55);
	z-index: 3;
	transition: color 480ms ease, transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Inner content wrapper — sits inside the cream frame */
.bv2-booking__trigger-inner {
	position: relative;
	z-index: 3;
	padding: clamp(32px, 3.2vw, 44px) clamp(28px, 2.8vw, 40px);
	display: flex;
	flex-direction: column;
	gap: clamp(14px, 1.5vw, 18px);
	height: 100%;
	min-height: inherit;
}
.bv2-booking__trigger { display: flex; }
.bv2-booking__trigger-inner { width: 100%; }

/* --- HOVER STATE --------------------------------------------------- */
.bv2-booking__trigger:hover {
	transform: translateY(-6px);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.18),
		inset 0 -1px 0 rgba(43, 37, 34, 0.22),
		0 28px 56px -28px rgba(43, 37, 34, 0.55);
}
.bv2-booking__trigger:hover::before {
	inset: 10px;
	border-color: rgba(239, 232, 218, 0.78);
}
.bv2-booking__trigger:hover .bv2-booking__trigger-paper {
	transform: translate(10px, 10px);
}
.bv2-booking__trigger:hover .bv2-booking__trigger-watermark {
	-webkit-text-stroke-color: rgba(43, 37, 34, 0.28);
	text-stroke-color: rgba(43, 37, 34, 0.28);
	transform: translate(-4px, -4px);
}
.bv2-booking__trigger:hover .bv2-booking__trigger-flourish {
	color: rgba(43, 37, 34, 0.85);
	transform: scale(1.08) rotate(-4deg);
}
/* Hover: the BIG italic price shifts to brand gold — the "decision color"
   highlight. text-shadow also softens to match the lighter color tone. */
.bv2-booking__trigger-price-num {
	transition: color 360ms cubic-bezier(0.22, 1, 0.36, 1),
	            text-shadow 360ms ease;
}
.bv2-booking__trigger:hover .bv2-booking__trigger-price-num {
	color: var(--exspa-gold, #8B6F3D);
	text-shadow:
		0 1px 0 rgba(255, 255, 255, 0.35),
		0 -1px 0 rgba(43, 37, 34, 0.08);
}

/* --- FOCUS (keyboard) --------------------------------------------- */
.bv2-booking__trigger:focus-visible {
	outline: 2px solid var(--exspa-sage-deep, #2B2522);
	outline-offset: 6px;
}

/* --- ACTIVE (press) ----------------------------------------------- */
.bv2-booking__trigger:active {
	transform: translateY(-2px);
	transition-duration: 100ms;
}

/* --- Top row: number + tagline -------------------------------------- */
.bv2-booking__trigger-top {
	display: flex;
	align-items: baseline;
	gap: 14px;
}
.bv2-booking__trigger-num {
	font-family: 'Inter', sans-serif;
	font-style: normal;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.28em;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.7;
	line-height: 1;
	padding-right: 12px;
	border-right: 1px solid rgba(43, 37, 34, 0.25);
}
.bv2-booking__trigger-tag {
	font-size: 10.5px;
	font-weight: 500;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.78;
}

/* --- Name: big italic Cormorant ----------------------------------- */
.bv2-booking__trigger-name {
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-weight: 400;
	font-size: clamp(32px, 3.2vw, 44px);
	line-height: 1.02;
	letter-spacing: -0.01em;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0;
}
.bv2-booking__trigger-name em { font-style: italic; }

/* --- Divider — thin warm-black hairline ---------------------------- */
.bv2-booking__trigger-divider {
	height: 1px;
	background: rgba(43, 37, 34, 0.25);
	margin: clamp(6px, 0.5vw, 10px) 0;
	width: 60px;
	transition: width 480ms cubic-bezier(0.22, 1, 0.36, 1);
}
.bv2-booking__trigger:hover .bv2-booking__trigger-divider {
	width: 100%;
}

/* --- Foot row: meta on left, BIG price on right ------------------- */
.bv2-booking__trigger-foot {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 16px;
	margin-top: auto;
}
.bv2-booking__trigger-meta {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.bv2-booking__trigger-duration {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: clamp(22px, 1.8vw, 26px);
	color: var(--exspa-sage-deep, #2B2522);
	line-height: 1.15;
	letter-spacing: -0.005em;
}
.bv2-booking__trigger-capacity {
	font-size: 10.5px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.7;
}
.bv2-booking__trigger-price {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
}
.bv2-booking__trigger-price-num {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
	font-size: clamp(44px, 4.4vw, 62px);
	line-height: 1;
	letter-spacing: -0.025em;
	color: var(--exspa-sage-deep, #2B2522);
	/* Foil-stamp emboss: subtle highlight on top, soft inner shadow below */
	text-shadow:
		0 1px 0 rgba(255, 255, 255, 0.22),
		0 -1px 0 rgba(43, 37, 34, 0.12);
}
.bv2-booking__trigger-price-unit {
	font-size: 9.5px;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.62;
	margin-top: 6px;
}

/* --- Addon badge (Suite +40€/personne) ---------------------------- */
.bv2-booking__trigger-addon {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 14px 0 0;
	padding: 12px 14px;
	background: rgba(139, 111, 61, 0.08);
	border: 1px solid rgba(139, 111, 61, 0.35);
	border-radius: 2px;
	font-size: 15.5px;
	font-style: italic;
	line-height: 1.4;
	color: var(--exspa-gold, #8B6F3D);
	font-family: 'Cormorant Garamond', 'EB Garamond', Georgia, serif;
}
.bv2-booking__trigger-addon-mark {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	margin-top: 1px;
	color: var(--exspa-gold, #8B6F3D);
}
.bv2-booking__trigger-addon-text {
	display: inline-block;
}
.bv2-booking__trigger:hover .bv2-booking__trigger-addon {
	background: rgba(139, 111, 61, 0.13);
	border-color: var(--exspa-gold, #8B6F3D);
}

/* --- Bottom CTA ribbon -------------------------------------------- */
.bv2-booking__trigger-cta {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: clamp(12px, 1.5vw, 16px);
	padding-top: 16px;
	border-top: 1px solid rgba(43, 37, 34, 0.18);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
}
.bv2-booking__trigger-cta svg {
	margin-left: auto;
	transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}
.bv2-booking__trigger:hover .bv2-booking__trigger-cta svg {
	transform: translateX(8px);
}

@media (max-width: 900px) {
	.bv2-booking__triggers { grid-template-columns: 1fr; }
	.bv2-booking__trigger { min-height: 0; }
}

/* =============================================================================
 * Chapter F · Venir (two-block asymmetric address)
 * ========================================================================== */
.bv2-venir {
	background: var(--exspa-sage-deep, #2B2522);
	padding: 14vh 0 16vh;
}
.bv2-venir__header { text-align: center; margin-bottom: 8vh; padding: 0 5vw; }
.bv2-venir__header .bv2-chapter { margin-bottom: 20px; opacity: 0.55; }
.bv2-venir__heading {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
	font-size: clamp(48px, 7vw, 110px);
	color: var(--exspa-cream, #EFE8DA);
	margin: 0;
}
.bv2-venir__heading em { font-style: italic; }

.bv2-venir__blocks {
	display: grid;
	grid-template-columns: 0.85fr 1.15fr;
	gap: 20px;
	padding: 0 5vw;
	max-width: 1320px;
	margin: 0 auto;
}
.bv2-venir__block {
	background: var(--exspa-cream, #EFE8DA);
	color: var(--exspa-sage-deep, #2B2522);
	padding: clamp(40px, 4vw, 64px);
	position: relative;
	overflow: hidden;
	min-height: 400px;
	display: flex; flex-direction: column; justify-content: space-between;
}
/* Subtle topographic curve texture inside the cream blocks */
.bv2-venir__block::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		repeating-radial-gradient(
			circle at 30% 40%,
			transparent 0px,
			transparent 30px,
			rgba(43, 37, 34, 0.045) 30px,
			rgba(43, 37, 34, 0.045) 31px
		);
	opacity: 0.7;
	pointer-events: none;
}
.bv2-venir__block > * { position: relative; z-index: 1; }

.bv2-venir__block-label {
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--exspa-sage, #394839);
	opacity: 0.7;
	max-width: 30ch;
	line-height: 1.5;
	margin: 0;
}
.bv2-venir__phone {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: clamp(26px, 3vw, 36px);
	color: var(--exspa-sage-deep, #2B2522);
	margin: 14px 0 0;
}
.bv2-venir__block-title {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
	font-size: clamp(28px, 3vw, 44px);
	line-height: 1.08;
	color: var(--exspa-sage-deep, #2B2522);
	margin-top: auto;
}
.bv2-venir__block-body {
	font-family: 'Cormorant Garamond', serif;
	font-weight: 400;
	font-size: clamp(28px, 3.2vw, 48px);
	line-height: 1.12;
	color: var(--exspa-sage-deep, #2B2522);
	margin: 0;
}
.bv2-venir__block-body em { font-style: italic; }
.bv2-venir__addr {
	font-size: 15px;
	color: var(--exspa-sage-deep, #2B2522);
	opacity: 0.82;
	line-height: 1.65;
	max-width: 36ch;
	margin: 20px 0 0;
}
.bv2-venir__cta-wrap { margin-top: 28px; }
.bv2-venir__cta {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--exspa-sage-deep, #2B2522);
	text-decoration: none;
	font-weight: 500;
}
.bv2-venir__cta-arrow {
	width: 46px; height: 46px;
	border: 1px solid var(--exspa-sage-deep, #2B2522);
	border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	transition: background 280ms ease, color 280ms ease, transform 280ms ease;
}
.bv2-venir__cta:hover .bv2-venir__cta-arrow {
	background: var(--exspa-sage-deep, #2B2522);
	color: var(--exspa-cream, #EFE8DA);
	transform: rotate(-45deg);
}

/* =============================================================================
 * Reveal-on-scroll animations
 *
 * `data-reveal-word`  → split into word spans, cascade fade-up
 * `data-reveal-line`  → fade-up + slide as a whole (no split)
 * `data-reveal-row`   → photo fades in, pill slides over with delay
 *
 * JS adds `.is-pending` before reveal, `.is-revealed` once in viewport.
 * ========================================================================== */
[data-reveal-word].is-pending .bv2-word,
[data-reveal-word].is-pending {
	opacity: 0;
}
[data-reveal-word] .bv2-word {
	display: inline-block;
	transform: translateY(110%);
	opacity: 0;
	transition: transform 900ms cubic-bezier(0.22, 1, 0.36, 1),
	            opacity 900ms cubic-bezier(0.22, 1, 0.36, 1);
	transition-delay: var(--bv2-word-delay, 0s);
	will-change: transform, opacity;
}
[data-reveal-word] em { display: inline-block; } /* preserve italic + transforms */
[data-reveal-word].is-revealed .bv2-word {
	transform: translateY(0);
	opacity: 1;
}
[data-reveal-word].is-revealed { opacity: 1; }

[data-reveal-line] {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 950ms cubic-bezier(0.22, 1, 0.36, 1),
	            transform 950ms cubic-bezier(0.22, 1, 0.36, 1);
}
[data-reveal-line].is-revealed { opacity: 1; transform: translateY(0); }

[data-reveal-row] .bv2-row__media {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1100ms cubic-bezier(0.22, 1, 0.36, 1),
	            transform 1100ms cubic-bezier(0.22, 1, 0.36, 1);
}
[data-reveal-row] .bv2-row__pill {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1100ms cubic-bezier(0.22, 1, 0.36, 1) 220ms,
	            transform 1100ms cubic-bezier(0.22, 1, 0.36, 1) 220ms;
}
[data-reveal-row].is-revealed .bv2-row__media,
[data-reveal-row].is-revealed .bv2-row__pill {
	opacity: 1;
	transform: translateY(0);
}

/* Headings that use background-clip text need special handling — fade only */
.bv2-manifesto__title[data-reveal-word].is-pending .bv2-word { opacity: 0; transform: none; }
.bv2-manifesto__title[data-reveal-word] .bv2-word {
	display: inline; /* don't break the bg image continuity across words */
	opacity: 0;
	transform: none;
	transition: opacity 1200ms cubic-bezier(0.22, 1, 0.36, 1);
	transition-delay: var(--bv2-word-delay, 0s);
}
.bv2-manifesto__title[data-reveal-word].is-revealed .bv2-word { opacity: 1; }

/* =============================================================================
 * MOBILE
 * ========================================================================== */
@media (max-width: 1100px) {
	.bv2-row__media { width: 88vw; }
	.bv2-row__pill {
		position: relative;
		right: auto !important; left: auto !important;
		top: auto;
		width: 90vw;
		max-width: 560px;
		margin: -56px auto 0;
	}
	.bv2-row--mirror .bv2-row__media { margin-left: 12vw; }
	.bv2-row--mirror .bv2-row__pill { margin-left: auto; margin-right: auto; }

	.bv2-hero__sub, .bv2-manifesto__copy {
		margin-left: 0; position: static;
		max-width: 90%;
	}
	.bv2-services > .bv2-chapter,
	.bv2-services__heading,
	.bv2-services {
		margin-left: 0;
	}
	.bv2-services > .bv2-chapter { position: relative; top: auto; left: auto; padding: 0 6vw; }
	.bv2-services__heading { margin: 16px 6vw 8vh; }
}
@media (max-width: 768px) {
	.bv2-engagement__inner { grid-template-columns: 1fr; }
	.bv2-engagement__media { margin-left: 0; max-width: 100%; }
	.bv2-venir__blocks { grid-template-columns: 1fr; }
}
@media (max-width: 540px) {
	.bv2-hero { padding: 14vh 5vw 10vh; }
	.bv2-hero > .bv2-chapter { position: relative; top: auto; right: auto; margin-bottom: 32px; }
	.bv2-manifesto { padding: 10vh 5vw; }
	.bv2-services { padding: 10vh 0 12vh; }
}
