/* ================================================================
   CŒUR SACRÉ — main.css
   Charte éditoriale luxe — Cormorant Garamond + Manrope
   Palette : crème · vert sapin · terracotta
   ================================================================ */


/* ================================================================
   1. FONTS — self-hosted (privacy-friendly, mieux RGPD)
   ================================================================ */

/* Cormorant Garamond */
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-300-normal.woff2') format('woff2');
	font-weight: 300; font-style: normal; font-display: swap;
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-300-italic.woff2') format('woff2');
	font-weight: 300; font-style: italic; font-display: swap;
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2');
	font-weight: 400; font-style: normal; font-display: swap;
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-400-italic.woff2') format('woff2');
	font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-500-normal.woff2') format('woff2');
	font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-500-italic.woff2') format('woff2');
	font-weight: 500; font-style: italic; font-display: swap;
}
/* Cormorant — extended latin (œ, accents pleins) */
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-ext-300-normal.woff2') format('woff2');
	font-weight: 300; font-style: normal; font-display: swap;
	unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-ext-300-italic.woff2') format('woff2');
	font-weight: 300; font-style: italic; font-display: swap;
	unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-ext-400-normal.woff2') format('woff2');
	font-weight: 400; font-style: normal; font-display: swap;
	unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'Cormorant Garamond';
	src: url('../fonts/cormorant-garamond-latin-ext-400-italic.woff2') format('woff2');
	font-weight: 400; font-style: italic; font-display: swap;
	unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Manrope */
@font-face {
	font-family: 'Manrope';
	src: url('../fonts/manrope-latin-300-normal.woff2') format('woff2');
	font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
	font-family: 'Manrope';
	src: url('../fonts/manrope-latin-400-normal.woff2') format('woff2');
	font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
	font-family: 'Manrope';
	src: url('../fonts/manrope-latin-500-normal.woff2') format('woff2');
	font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
	font-family: 'Manrope';
	src: url('../fonts/manrope-latin-600-normal.woff2') format('woff2');
	font-weight: 600; font-style: normal; font-display: swap;
}


/* ================================================================
   2. TOKENS — variables CSS de la marque
   ================================================================ */
:root {
	--cream:        #F4EEE3;
	--cream-deep:   #EBE2D2;
	--cream-warm:   #ECE3D3;
	--terracotta:   #A04E36;
	--terracotta-d: #7A3A28;
	--forest:       #1F3A2D;
	--forest-d:     #14271E;
	--gold:         #D4A57F;
	--ink:          #181614;
	--ink-soft:     #4A453F;
	--ink-muted:    #8B847C;
	--line:         rgba(24, 22, 20, 0.12);
	--line-warm:    rgba(160, 78, 54, 0.22);

	--display: 'Cormorant Garamond', 'Times New Roman', serif;
	--body:    'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;

	--gutter:  clamp(20px, 4.5vw, 64px);
	--bound:   1480px;
	--prose:   720px;

	--t-fast:  240ms cubic-bezier(0.2, 0.6, 0.2, 1);
	--t-slow:  680ms cubic-bezier(0.16, 0.84, 0.32, 1);
}


/* ================================================================
   3. RESET & BASE
   ================================================================ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
	font-family: var(--body);
	font-weight: 300;
	font-size: 15px;
	line-height: 1.7;
	color: var(--ink);
	background: var(--cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}

img, svg, video { max-width: 100%; display: block; height: auto; }

a { color: inherit; text-decoration: none; }

button { font-family: inherit; cursor: pointer; }

::selection { background: var(--terracotta); color: var(--cream); }


/* Skip link accessibilité */
.skip-link {
	position: absolute; left: -9999px; top: 0;
	background: var(--ink); color: var(--cream);
	padding: 12px 18px; z-index: 999;
	font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
}
.skip-link:focus { left: 12px; top: 12px; }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px; width: 1px; overflow: hidden;
}


/* ================================================================
   4. ATOMES TYPOGRAPHIQUES
   ================================================================ */
.eyebrow {
	font-family: var(--body);
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--terracotta);
	display: inline-flex;
	align-items: center;
	gap: 14px;
}
.eyebrow::before {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}

.italic { font-style: italic; font-weight: 300; }


/* ================================================================
   5. TOPBAR
   ================================================================ */
.topbar {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	padding: 18px var(--gutter);
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	background: rgba(244, 238, 227, 0.86);
	backdrop-filter: saturate(140%) blur(14px);
	-webkit-backdrop-filter: saturate(140%) blur(14px);
	border-bottom: 1px solid var(--line);
	transition: background var(--t-fast), border-color var(--t-fast);
}
.topbar.is-scrolled {
	background: rgba(244, 238, 227, 0.96);
}

.brand {
	font-family: var(--display);
	font-size: 22px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--forest);
	text-align: center;
	white-space: nowrap;
}
.brand .amp {
	font-style: italic;
	font-weight: 400;
	color: var(--terracotta);
	margin: 0 4px;
}
.brand img.custom-logo { max-height: 44px; width: auto; display: inline-block; }

.nav-primary { justify-self: start; }
.nav {
	display: flex;
	gap: 32px;
	list-style: none;
	align-items: center;
	margin: 0; padding: 0;
}
.nav li { list-style: none; }
.nav a {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-soft);
	font-weight: 400;
	position: relative;
	padding: 4px 0;
	transition: color var(--t-fast);
}
.nav a::after {
	content: '';
	position: absolute;
	left: 0; bottom: -2px;
	height: 1px;
	width: 0;
	background: var(--terracotta);
	transition: width var(--t-fast);
}
.nav a:hover { color: var(--terracotta); }
.nav a:hover::after { width: 100%; }

.topbar-right {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 24px;
}

.lang {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 11px;
	letter-spacing: 0.2em;
	color: var(--ink-muted);
}
.lang a {
	transition: color var(--t-fast);
	text-transform: uppercase;
}
.lang a.active { color: var(--ink); font-weight: 500; }
.lang a:hover { color: var(--ink); }
.lang .sep { color: var(--line); }

.book-btn {
	font-family: var(--body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	padding: 13px 24px 12px;
	border: 1px solid var(--ink);
	background: transparent;
	color: var(--ink);
	cursor: pointer;
	transition: background var(--t-fast), color var(--t-fast);
	white-space: nowrap;
}
.book-btn:hover {
	background: var(--ink);
	color: var(--cream);
}

.menu-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	width: 28px;
	height: 18px;
	position: relative;
	padding: 0;
}
.menu-toggle span {
	display: block;
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--ink);
	transition: all var(--t-fast);
}
.menu-toggle span:nth-child(1) { top: 4px; }
.menu-toggle span:nth-child(2) { top: 12px; }
.menu-toggle[aria-expanded="true"] span:nth-child(1) {
	top: 8px; transform: rotate(45deg);
}
.menu-toggle[aria-expanded="true"] span:nth-child(2) {
	top: 8px; transform: rotate(-45deg);
}


/* Menu mobile (overlay) */
.mobile-nav {
	position: fixed;
	inset: 0;
	z-index: 99;
	background: var(--cream);
	padding: 100px var(--gutter) 40px;
	transform: translateY(-100%);
	transition: transform var(--t-slow);
	overflow-y: auto;
}
body.menu-open .mobile-nav { transform: translateY(0); }

.mobile-nav-inner {
	max-width: 600px;
	margin: 0 auto;
}
.mobile-menu {
	list-style: none;
	margin: 0 0 48px; padding: 0;
}
.mobile-menu li { list-style: none; border-bottom: 1px solid var(--line); }
.mobile-menu a {
	display: block;
	padding: 22px 0;
	font-family: var(--display);
	font-size: 28px;
	font-weight: 400;
	color: var(--forest);
	letter-spacing: -0.01em;
	transition: color var(--t-fast), padding var(--t-fast);
}
.mobile-menu a:hover { color: var(--terracotta); padding-left: 12px; }

.mobile-actions {
	display: flex;
	flex-direction: column;
	gap: 24px;
	align-items: flex-start;
	margin-top: 32px;
}


/* ================================================================
   6. HERO (homepage)
   ================================================================ */
.hero {
	min-height: 100vh;
	padding: 130px var(--gutter) 80px;
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: clamp(40px, 6vw, 96px);
	align-items: center;
	position: relative;
}

.hero-corner {
	position: absolute;
	top: 50%;
	left: var(--gutter);
	transform: translateY(50%) rotate(-90deg);
	transform-origin: left top;
	font-size: 10px;
	letter-spacing: 0.36em;
	text-transform: uppercase;
	color: var(--ink-muted);
	white-space: nowrap;
}

.hero-text { position: relative; z-index: 2; }

.hero-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(58px, 10.5vw, 168px);
	line-height: 0.92;
	letter-spacing: -0.025em;
	color: var(--forest);
	margin: 28px 0;
}
.hero-title .row { display: block; }
.hero-title .row.italic { padding-left: clamp(20px, 4vw, 56px); }

.hero-tag {
	font-family: var(--display);
	font-size: clamp(20px, 1.9vw, 27px);
	font-style: italic;
	font-weight: 300;
	color: var(--ink-soft);
	line-height: 1.42;
	max-width: 540px;
	margin-bottom: 48px;
}

.hero-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 28px;
	font-size: 10.5px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-muted);
}
.hero-meta span { position: relative; }
.hero-meta span:not(:last-child)::after {
	content: '·';
	position: absolute;
	right: -18px;
	color: var(--terracotta);
}

.hero-visual {
	aspect-ratio: 4 / 5;
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(31,58,45,0.12), transparent 60%),
		linear-gradient(45deg, #C97A52 0%, #B0613F 35%, #7A3A28 100%);
}
.hero-visual img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(0.92) contrast(1.02);
}
.hero-visual::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(24,22,20,0.35));
	pointer-events: none;
}

.visual-tag {
	position: absolute;
	bottom: 24px; left: 24px;
	font-family: var(--body);
	font-size: 10px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: rgba(244,238,227,0.92);
	z-index: 2;
	display: flex;
	align-items: center;
	gap: 10px;
}
.visual-tag::before {
	content: '';
	width: 18px; height: 1px;
	background: rgba(244,238,227,0.6);
}


/* ================================================================
   7. MANIFESTO
   ================================================================ */
.manifesto {
	padding: clamp(100px, 14vw, 200px) var(--gutter);
	text-align: center;
	position: relative;
}

.manifesto-inner {
	max-width: 920px;
	margin: 0 auto;
}

.manifesto-eyebrow {
	margin-bottom: 36px;
	justify-content: center;
}
.manifesto-eyebrow::after {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}

.manifesto-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(34px, 4.6vw, 62px);
	line-height: 1.18;
	color: var(--forest);
	letter-spacing: -0.01em;
	margin-bottom: 0;
}
.manifesto-title em {
	font-style: italic;
	color: var(--terracotta);
}

.manifesto-rule {
	width: 1px;
	height: 64px;
	background: var(--terracotta);
	margin: 64px auto 0;
	opacity: 0.6;
}


/* ================================================================
   8. EXPERIENCES
   ================================================================ */
.experiences {
	padding: clamp(40px, 6vw, 80px) var(--gutter) clamp(80px, 10vw, 140px);
	max-width: var(--bound);
	margin: 0 auto;
}

.exp-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin-bottom: clamp(60px, 8vw, 100px);
	gap: 40px;
	border-bottom: 1px solid var(--line);
	padding-bottom: 28px;
}
.exp-header h2 {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(40px, 5vw, 72px);
	line-height: 1;
	color: var(--forest);
	letter-spacing: -0.02em;
}
.exp-header em {
	font-style: italic;
	color: var(--terracotta);
	font-weight: 300;
}
.exp-header .count {
	font-family: var(--body);
	font-size: 11px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ink-muted);
	white-space: nowrap;
	padding-bottom: 8px;
}

.exp-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 96px);
	align-items: center;
	margin-bottom: clamp(80px, 10vw, 140px);
}
.exp-row:last-child { margin-bottom: 0; }
.exp-row.reverse .exp-image { order: 2; }
.exp-row.reverse .exp-content { order: 1; }

.exp-image {
	aspect-ratio: 5 / 6;
	position: relative;
	overflow: hidden;
	background: var(--cream-deep);
}
.exp-image img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.2s var(--t-slow);
}
.exp-row:hover .exp-image img { transform: scale(1.04); }

.exp-image-tag {
	position: absolute;
	top: 24px; left: 24px;
	font-family: var(--body);
	font-size: 10px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--cream);
	z-index: 2;
	background: rgba(24,22,20,0.55);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	padding: 8px 14px;
}

.exp-content { padding: 8px 0; }

.exp-num {
	font-family: var(--display);
	font-size: 14px;
	font-style: italic;
	color: var(--terracotta);
	letter-spacing: 0.1em;
	margin-bottom: 16px;
	display: block;
}
.exp-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(34px, 4.4vw, 60px);
	line-height: 1.05;
	color: var(--forest);
	letter-spacing: -0.015em;
	margin-bottom: 24px;
}
.exp-title em { font-style: italic; color: var(--terracotta); font-weight: 300; }

.exp-meta {
	font-size: 11px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	gap: 14px;
}
.exp-meta::before {
	content: '';
	width: 22px; height: 1px;
	background: var(--terracotta);
}

.exp-text {
	font-size: 16px;
	line-height: 1.75;
	color: var(--ink-soft);
	max-width: 480px;
	margin-bottom: 36px;
	font-weight: 300;
}

.link-arrow {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-family: var(--body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ink);
	border-bottom: 1px solid var(--ink);
	padding: 4px 0;
	transition: color var(--t-fast), border-color var(--t-fast);
}
.link-arrow svg { transition: transform var(--t-fast); }
.link-arrow:hover { color: var(--terracotta); border-color: var(--terracotta); }
.link-arrow:hover svg { transform: translateX(6px); }


/* ================================================================
   9. PLACE (block sombre)
   ================================================================ */
.place {
	background: var(--forest);
	color: var(--cream);
	padding: clamp(100px, 14vw, 180px) var(--gutter);
	position: relative;
	overflow: hidden;
}

.place-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(60px, 8vw, 120px);
	align-items: center;
	max-width: var(--bound);
	margin: 0 auto;
}

.place-text .eyebrow { color: var(--gold); }
.place-text .eyebrow::before { background: var(--gold); }

.place-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(40px, 5.5vw, 84px);
	line-height: 1;
	color: var(--cream);
	letter-spacing: -0.02em;
	margin: 28px 0 36px;
}
.place-title .gold { color: var(--gold); font-style: italic; }

.place-content,
.place-text p {
	font-size: 16px;
	line-height: 1.8;
	color: rgba(244,238,227,0.78);
	margin-bottom: 24px;
	font-weight: 300;
	max-width: 540px;
}
.place-content p:last-of-type,
.place-text p:last-of-type { margin-bottom: 40px; }

.place-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 36px 40px;
	margin-top: 48px;
	padding-top: 48px;
	border-top: 1px solid rgba(244,238,227,0.18);
}
.stat-num {
	font-family: var(--display);
	font-size: clamp(40px, 4.5vw, 64px);
	font-weight: 300;
	line-height: 1;
	color: var(--gold);
	letter-spacing: -0.02em;
}
.stat-num small {
	font-size: 0.42em;
	font-style: italic;
	color: rgba(244,238,227,0.55);
	margin-left: 6px;
	font-weight: 300;
}
.stat-label {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(244,238,227,0.55);
	margin-top: 10px;
}

.place-visual {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 12px;
	aspect-ratio: 1 / 1.1;
}
.pv {
	position: relative;
	overflow: hidden;
	background: var(--forest-d);
}
.pv img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.pv-1 { grid-row: 1 / 3; grid-column: 1 / 2; }
.pv-2 { grid-row: 1 / 2; grid-column: 2 / 3; }
.pv-3 { grid-row: 2 / 3; grid-column: 2 / 3; }

.pv-label {
	position: absolute;
	bottom: 14px; left: 14px;
	font-size: 9px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: rgba(244,238,227,0.85);
	z-index: 2;
}


/* ================================================================
   10. PRIVATISATION
   ================================================================ */
.privat {
	padding: clamp(100px, 14vw, 180px) var(--gutter);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 100px);
	align-items: center;
	max-width: var(--bound);
	margin: 0 auto;
}
.privat-img {
	aspect-ratio: 1 / 1.15;
	position: relative;
	overflow: hidden;
	background: var(--cream-deep);
}
.privat-img img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.privat-content .eyebrow { margin-bottom: 28px; }
.privat-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(38px, 5vw, 72px);
	line-height: 1.05;
	color: var(--forest);
	letter-spacing: -0.02em;
	margin-bottom: 32px;
}
.privat-title em { font-style: italic; color: var(--terracotta); font-weight: 300; }

.privat-text {
	font-size: 16px;
	line-height: 1.75;
	color: var(--ink-soft);
	margin-bottom: 32px;
	max-width: 480px;
}

.privat-formats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 40px;
}
.format-pill {
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 8px 16px;
	border: 1px solid var(--line-warm);
	color: var(--ink-soft);
	background: var(--cream);
	font-weight: 400;
}


/* CTA boutons réutilisables */
.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	font-family: var(--body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	padding: 16px 28px 15px;
	background: var(--ink);
	color: var(--cream);
	transition: background var(--t-fast);
	border: none;
}
.btn-primary:hover { background: var(--terracotta); color: var(--cream); }
.btn-primary svg { transition: transform var(--t-fast); }
.btn-primary:hover svg { transform: translateX(6px); }


/* ================================================================
   11. WORDS / AVIS
   ================================================================ */
.words {
	background: var(--cream-warm);
	padding: clamp(80px, 12vw, 160px) var(--gutter);
	text-align: center;
	position: relative;
}
.words-eyebrow {
	margin-bottom: 56px;
	justify-content: center;
}
.words-eyebrow::after {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}
.quote {
	font-family: var(--display);
	font-weight: 300;
	font-style: italic;
	font-size: clamp(26px, 3.4vw, 44px);
	line-height: 1.35;
	color: var(--forest);
	max-width: 980px;
	margin: 0 auto 36px;
	letter-spacing: -0.01em;
}
.quote::before { content: '« '; color: var(--terracotta); font-style: normal; }
.quote::after  { content: ' »'; color: var(--terracotta); font-style: normal; }

.quote-author {
	font-size: 11px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.quote-rating {
	font-family: var(--display);
	font-style: italic;
	font-size: 14px;
	color: var(--terracotta);
	margin-top: 4px;
	letter-spacing: 0.2em;
}

.words-meta {
	margin-top: 64px;
	padding-top: 32px;
	border-top: 1px solid var(--line);
	display: flex;
	justify-content: center;
	gap: 64px;
	flex-wrap: wrap;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-muted);
}
.words-meta strong {
	display: block;
	font-family: var(--display);
	font-style: italic;
	font-size: 22px;
	font-weight: 400;
	letter-spacing: 0;
	color: var(--terracotta);
	text-transform: none;
	margin-bottom: 4px;
}


/* ================================================================
   12. PRACTICAL
   ================================================================ */
.practical {
	padding: clamp(100px, 14vw, 180px) var(--gutter);
	max-width: var(--bound);
	margin: 0 auto;
}
.practical-header {
	text-align: center;
	margin-bottom: clamp(60px, 8vw, 100px);
}
.practical-header .eyebrow {
	justify-content: center;
	margin-bottom: 28px;
}
.practical-header .eyebrow::after {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}
.practical-header h2 {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(40px, 5vw, 72px);
	color: var(--forest);
	letter-spacing: -0.015em;
}
.practical-header h2 em { font-style: italic; color: var(--terracotta); font-weight: 300; }

.practical-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(28px, 4vw, 56px);
	border-top: 1px solid var(--line);
	padding-top: clamp(40px, 5vw, 64px);
}

.pinfo h3 {
	font-family: var(--body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 24px;
}
.pinfo .big {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(22px, 2.4vw, 30px);
	line-height: 1.3;
	color: var(--forest);
	margin-bottom: 16px;
	letter-spacing: -0.005em;
}
.pinfo .big a { color: inherit; transition: color var(--t-fast); }
.pinfo .big a:hover { color: var(--terracotta); }
.pinfo p {
	font-size: 14px;
	line-height: 1.75;
	color: var(--ink-soft);
}
.pinfo ul {
	list-style: none;
	font-size: 14px;
	line-height: 1.95;
	color: var(--ink-soft);
}
.pinfo ul li {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 4px 0;
}
.pinfo ul li span:last-child {
	color: var(--ink);
	font-weight: 400;
}
.pinfo .small-link {
	display: inline-block;
	margin-top: 16px;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--terracotta);
	border-bottom: 1px solid var(--terracotta);
	padding-bottom: 2px;
	transition: opacity var(--t-fast);
}
.pinfo .small-link:hover { opacity: 0.7; }


/* ================================================================
   13. FOOTER
   ================================================================ */
.footer {
	background: var(--ink);
	color: var(--cream);
	padding: clamp(80px, 10vw, 130px) var(--gutter) 32px;
}
.footer-top {
	max-width: var(--bound);
	margin: 0 auto clamp(60px, 8vw, 96px);
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: clamp(28px, 4vw, 64px);
	padding-bottom: 64px;
	border-bottom: 1px solid rgba(244,238,227,0.12);
}
.footer-brand {
	font-family: var(--display);
	font-size: clamp(40px, 4.5vw, 64px);
	font-weight: 300;
	letter-spacing: -0.01em;
	line-height: 1;
	color: var(--cream);
	margin-bottom: 18px;
}
.footer-brand em { font-style: italic; color: var(--gold); font-weight: 300; }
.footer-tagline {
	font-family: var(--display);
	font-style: italic;
	font-size: 18px;
	color: rgba(244,238,227,0.65);
	max-width: 360px;
	font-weight: 300;
	line-height: 1.5;
}

.footer h4 {
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--gold);
	margin-bottom: 22px;
}
.footer ul,
.footer .menu { list-style: none; padding: 0; margin: 0; }
.footer ul li,
.footer .menu li { margin-bottom: 10px; list-style: none; }
.footer ul a,
.footer .menu a {
	font-size: 14px;
	color: rgba(244,238,227,0.78);
	transition: color var(--t-fast);
}
.footer ul a:hover,
.footer .menu a:hover { color: var(--cream); }

.footer-bottom {
	max-width: var(--bound);
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 18px;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(244,238,227,0.45);
}
.footer-bottom .menu {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}
.footer-bottom a { transition: color var(--t-fast); }
.footer-bottom a:hover { color: var(--cream); }


/* ================================================================
   14. PAGE GÉNÉRIQUE
   ================================================================ */
.page-template {
	padding-top: 100px; /* topbar fixed compense */
}

.page-hero {
	padding: clamp(80px, 10vw, 140px) var(--gutter) clamp(60px, 8vw, 100px);
	max-width: var(--bound);
	margin: 0 auto;
	text-align: center;
	position: relative;
}
.page-hero-inner {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}
.page-hero-eyebrow {
	justify-content: center;
	margin-bottom: 28px;
}
.page-hero-eyebrow::after {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}
.page-hero-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(40px, 6.5vw, 100px);
	line-height: 1.02;
	color: var(--forest);
	letter-spacing: -0.02em;
	margin-bottom: 32px;
}
.page-hero-intro {
	font-family: var(--display);
	font-size: clamp(18px, 1.8vw, 24px);
	font-style: italic;
	font-weight: 300;
	color: var(--ink-soft);
	line-height: 1.5;
	max-width: 640px;
	margin: 0 auto;
}
.page-hero-image {
	margin-top: clamp(48px, 6vw, 80px);
	aspect-ratio: 21 / 9;
	overflow: hidden;
}
.page-hero-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.page-content {
	padding: clamp(60px, 8vw, 120px) var(--gutter);
}
.content-inner {
	max-width: var(--prose);
	margin: 0 auto;
}
.content-inner > * { margin-bottom: 1.4em; }
.content-inner h2 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(30px, 3.4vw, 44px);
	line-height: 1.15;
	color: var(--forest);
	margin: 2em 0 0.8em;
	letter-spacing: -0.015em;
}
.content-inner h3 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(22px, 2.4vw, 30px);
	color: var(--forest);
	margin: 1.6em 0 0.6em;
	letter-spacing: -0.01em;
}
.content-inner p {
	font-size: 16px;
	line-height: 1.8;
	color: var(--ink-soft);
	font-weight: 300;
}
.content-inner a {
	color: var(--terracotta);
	border-bottom: 1px solid var(--line-warm);
	transition: border-color var(--t-fast);
}
.content-inner a:hover { border-color: var(--terracotta); }
.content-inner blockquote {
	font-family: var(--display);
	font-style: italic;
	font-weight: 300;
	font-size: clamp(22px, 2.4vw, 30px);
	line-height: 1.4;
	color: var(--forest);
	border-left: 2px solid var(--terracotta);
	padding-left: clamp(20px, 3vw, 36px);
	margin: 2em 0;
}
.content-inner ul, .content-inner ol {
	padding-left: 1.4em;
	font-size: 16px;
	line-height: 1.85;
	color: var(--ink-soft);
}
.content-inner li { margin-bottom: 0.5em; }
.content-inner img,
.content-inner figure {
	margin: 2em 0;
}
.content-inner figcaption {
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-top: 12px;
	text-align: center;
}


/* ================================================================
   15. CARTE / MENU
   ================================================================ */
.carte {
	padding: clamp(40px, 5vw, 80px) var(--gutter) clamp(80px, 10vw, 120px);
}
.carte-inner {
	max-width: 920px;
	margin: 0 auto;
}
.carte-intro {
	font-family: var(--display);
	font-style: italic;
	font-size: clamp(18px, 2vw, 24px);
	color: var(--ink-soft);
	text-align: center;
	margin-bottom: clamp(48px, 6vw, 80px);
	font-weight: 300;
}
.carte-pdf {
	text-align: center;
	padding: clamp(60px, 8vw, 100px) 0;
}
.carte-pdf-meta {
	margin-top: 18px;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-muted);
}
.carte-section {
	margin-bottom: clamp(60px, 7vw, 96px);
	padding-bottom: clamp(48px, 6vw, 64px);
	border-bottom: 1px solid var(--line);
}
.carte-section:last-child { border-bottom: 0; margin-bottom: 0; }
.carte-section-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(28px, 3.4vw, 44px);
	color: var(--forest);
	letter-spacing: -0.01em;
	margin-bottom: 36px;
	text-align: center;
	font-style: italic;
}
.carte-items {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 28px;
}
.carte-item { padding: 4px 0; }
.carte-item-head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 16px;
	margin-bottom: 6px;
}
.carte-item-name {
	font-family: var(--display);
	font-weight: 500;
	font-size: clamp(18px, 1.7vw, 22px);
	color: var(--forest);
	display: inline-flex;
	align-items: baseline;
	gap: 12px;
	flex-wrap: wrap;
}
.carte-badge {
	display: inline-block;
	font-family: var(--body);
	font-size: 9px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 3px 8px;
	color: var(--cream);
	background: var(--terracotta);
	vertical-align: middle;
}
.carte-badge-vege        { background: #4F6B41; }
.carte-badge-sans_gluten { background: #8A7B4F; }
.carte-badge-nouveau     { background: var(--ink); }
.carte-badge-signature   { background: var(--terracotta); }

.carte-item-price {
	font-family: var(--display);
	font-style: italic;
	font-weight: 400;
	font-size: 18px;
	color: var(--terracotta);
	white-space: nowrap;
	flex-shrink: 0;
}
.carte-item-desc {
	font-size: 14px;
	line-height: 1.6;
	color: var(--ink-soft);
	font-weight: 300;
}
.carte-item-allerg {
	font-size: 11px;
	letter-spacing: 0.06em;
	color: var(--ink-muted);
	margin-top: 4px;
	font-style: italic;
}


/* ================================================================
   16. BLOG ARCHIVE
   ================================================================ */
.blog-archive { padding-top: 100px; }

.blog-hero {
	padding: clamp(80px, 10vw, 140px) var(--gutter) clamp(40px, 6vw, 80px);
	text-align: center;
	border-bottom: 1px solid var(--line);
}
.blog-hero-inner {
	max-width: 760px;
	margin: 0 auto;
}
.blog-hero-inner .eyebrow {
	justify-content: center;
	margin-bottom: 28px;
}
.blog-hero-inner .eyebrow::after {
	content: '';
	display: block;
	width: 28px;
	height: 1px;
	background: var(--terracotta);
}
.blog-hero-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(44px, 6vw, 88px);
	line-height: 1;
	color: var(--forest);
	letter-spacing: -0.02em;
	margin-bottom: 20px;
}
.blog-hero-intro {
	font-family: var(--display);
	font-style: italic;
	font-size: clamp(17px, 1.7vw, 22px);
	color: var(--ink-soft);
	font-weight: 300;
	max-width: 600px;
	margin: 0 auto;
}

.blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(28px, 4vw, 56px);
	max-width: var(--bound);
	margin: 0 auto;
	padding: clamp(60px, 8vw, 100px) var(--gutter);
}

.post-card {
	display: block;
}
.post-card-link {
	display: block;
	height: 100%;
}
.post-card-image {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--cream-deep);
	margin-bottom: 24px;
}
.post-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.8s var(--t-slow);
}
.post-card:hover .post-card-image img { transform: scale(1.04); }

.post-card-body { padding: 0 4px; }
.post-card-cat {
	display: inline-block;
	font-size: 10px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 14px;
}
.post-card-title {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(22px, 2.2vw, 30px);
	line-height: 1.18;
	color: var(--forest);
	letter-spacing: -0.01em;
	margin-bottom: 12px;
	transition: color var(--t-fast);
}
.post-card:hover .post-card-title { color: var(--terracotta); }

.post-card-excerpt {
	font-size: 14px;
	line-height: 1.7;
	color: var(--ink-soft);
	font-weight: 300;
	margin-bottom: 18px;
}
.post-card-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-muted);
	padding-top: 16px;
	border-top: 1px solid var(--line);
}
.post-card-arrow {
	font-family: var(--display);
	font-size: 18px;
	color: var(--terracotta);
	transition: transform var(--t-fast);
}
.post-card:hover .post-card-arrow { transform: translateX(6px); }


/* Pagination */
.pagination,
.nav-links {
	display: flex;
	justify-content: center;
	gap: 8px;
	padding: 0 var(--gutter) clamp(80px, 10vw, 140px);
}
.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	font-size: 13px;
	font-family: var(--body);
	font-weight: 400;
	color: var(--ink-soft);
	border: 1px solid var(--line);
	transition: all var(--t-fast);
}
.page-numbers:hover { border-color: var(--terracotta); color: var(--terracotta); }
.page-numbers.current {
	background: var(--ink);
	color: var(--cream);
	border-color: var(--ink);
}
.page-numbers.dots { border: none; }


/* Empty state */
.empty-state {
	padding: clamp(80px, 10vw, 140px) var(--gutter);
	text-align: center;
	font-family: var(--display);
	font-style: italic;
	font-size: 22px;
	color: var(--ink-muted);
}


/* ================================================================
   17. SINGLE ARTICLE
   ================================================================ */
.single-article {
	padding-top: 100px;
}

.article {
	max-width: var(--prose);
	margin: 0 auto;
	padding: clamp(60px, 8vw, 120px) var(--gutter);
}

.article-header {
	text-align: center;
	margin-bottom: clamp(48px, 6vw, 72px);
}
.article-cat {
	display: inline-block;
	font-size: 10px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 24px;
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
	transition: border-color var(--t-fast);
}
.article-cat:hover { border-bottom-color: var(--terracotta); }

.article-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(32px, 5vw, 64px);
	line-height: 1.1;
	color: var(--forest);
	letter-spacing: -0.02em;
	margin-bottom: 24px;
}
.article-lede {
	font-family: var(--display);
	font-style: italic;
	font-size: clamp(18px, 2vw, 24px);
	font-weight: 300;
	line-height: 1.5;
	color: var(--ink-soft);
	max-width: 600px;
	margin: 0 auto 24px;
}
.article-meta {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-muted);
	display: flex;
	gap: 14px;
	justify-content: center;
	flex-wrap: wrap;
}
.article-meta-sep { color: var(--terracotta); }

.article-feature-image {
	margin: clamp(40px, 5vw, 64px) 0;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
.article-feature-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.article-content {
	font-size: 17px;
	line-height: 1.85;
	color: var(--ink-soft);
	font-weight: 300;
}
.article-content > * + * { margin-top: 1.4em; }
.article-content p:first-of-type::first-letter {
	font-family: var(--display);
	font-size: 4em;
	font-weight: 400;
	float: left;
	line-height: 0.9;
	margin: 0.05em 0.12em -0.05em 0;
	color: var(--terracotta);
}
.article-content h2 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(28px, 3.4vw, 40px);
	line-height: 1.2;
	color: var(--forest);
	margin-top: 2em;
	margin-bottom: 0.6em;
	letter-spacing: -0.01em;
}
.article-content h3 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(22px, 2.4vw, 28px);
	color: var(--forest);
	margin-top: 1.6em;
	margin-bottom: 0.5em;
}
.article-content blockquote {
	font-family: var(--display);
	font-style: italic;
	font-weight: 300;
	font-size: clamp(22px, 2.6vw, 32px);
	line-height: 1.4;
	color: var(--forest);
	border-left: 2px solid var(--terracotta);
	padding: 0.4em 0 0.4em clamp(20px, 3vw, 36px);
	margin: 1.8em 0;
}
.article-content blockquote p { margin: 0; }
.article-content a {
	color: var(--ink);
	border-bottom: 1px solid var(--terracotta);
	transition: color var(--t-fast);
}
.article-content a:hover { color: var(--terracotta); }
.article-content ul, .article-content ol { padding-left: 1.4em; }
.article-content li + li { margin-top: 0.4em; }
.article-content figure { margin: 2em -40px; }
.article-content figure img { margin: 0; }
.article-content figcaption {
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-top: 14px;
	text-align: center;
}
.article-content code {
	font-family: ui-monospace, 'SF Mono', Consolas, monospace;
	font-size: 0.9em;
	background: var(--cream-deep);
	padding: 2px 6px;
}

.article-footer {
	margin-top: clamp(60px, 8vw, 100px);
	padding-top: clamp(40px, 5vw, 64px);
	border-top: 1px solid var(--line);
}
.article-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}
.article-nav-prev { text-align: left; }
.article-nav-next { text-align: right; grid-column: 2; }
.article-nav-label {
	display: block;
	font-size: 10px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--ink-muted);
	margin-bottom: 8px;
	transition: color var(--t-fast);
}
.article-nav a:hover .article-nav-label { color: var(--terracotta); }
.article-nav-title {
	font-family: var(--display);
	font-style: italic;
	font-size: 18px;
	color: var(--forest);
	font-weight: 400;
}


/* ================================================================
   18. SEARCH FORM
   ================================================================ */
.search-form {
	display: flex;
	max-width: 480px;
	margin: 0 auto;
	border-bottom: 1px solid var(--ink);
}
.search-form label { flex: 1; }
.search-input {
	width: 100%;
	font-family: var(--body);
	font-size: 14px;
	padding: 12px 0;
	background: transparent;
	border: none;
	color: var(--ink);
}
.search-input:focus { outline: none; }
.search-input::placeholder { color: var(--ink-muted); }
.search-submit {
	background: transparent;
	border: none;
	padding: 0 12px;
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--terracotta);
	cursor: pointer;
}


/* ================================================================
   19. 404
   ================================================================ */
.page-404 {
	padding: clamp(120px, 14vw, 200px) var(--gutter);
	text-align: center;
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
}
.error-inner {
	max-width: 600px;
}
.error-inner .eyebrow {
	justify-content: center;
	margin-bottom: 24px;
	font-family: var(--display);
	font-size: 80px;
	color: var(--terracotta);
	font-style: italic;
	font-weight: 300;
	letter-spacing: 0;
	text-transform: none;
}
.error-inner .eyebrow::before { display: none; }
.error-title {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(36px, 4.5vw, 56px);
	color: var(--forest);
	margin-bottom: 20px;
	letter-spacing: -0.02em;
}
.error-text {
	font-size: 16px;
	line-height: 1.7;
	color: var(--ink-soft);
	margin-bottom: 40px;
}
.error-links { margin-bottom: 60px; }


/* ================================================================
   20. REVEAL ANIMATIONS
   ================================================================ */
.reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 1s var(--t-slow), transform 1s var(--t-slow);
}
.reveal.in {
	opacity: 1;
	transform: translateY(0);
}
.reveal.delay-1 { transition-delay: 0.1s; }
.reveal.delay-2 { transition-delay: 0.2s; }
.reveal.delay-3 { transition-delay: 0.3s; }

@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; }
	*, *::before, *::after { animation: none !important; transition: none !important; }
}


/* ================================================================
   21. RESPONSIVE
   ================================================================ */
@media (max-width: 980px) {
	.nav-primary { display: none; }
	.menu-toggle { display: block; justify-self: start; }
	.topbar { grid-template-columns: 1fr auto 1fr; }
	.topbar-right .book-btn { display: none; }
	.topbar-right .lang { display: none; }

	.hero {
		grid-template-columns: 1fr;
		gap: 48px;
		padding-top: 110px;
		min-height: auto;
	}
	.hero-corner { display: none; }

	.exp-row {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.exp-row.reverse .exp-image { order: 0; }
	.exp-row.reverse .exp-content { order: 0; }

	.place-grid { grid-template-columns: 1fr; gap: 60px; }
	.place-stats { grid-template-columns: 1fr 1fr; gap: 28px; }

	.privat { grid-template-columns: 1fr; }

	.practical-grid { grid-template-columns: 1fr; gap: 40px; }
	.practical-grid > * + * { padding-top: 40px; border-top: 1px solid var(--line); }

	.footer-top {
		grid-template-columns: 1fr 1fr;
		gap: 40px;
	}
	.footer-top .footer-col-brand { grid-column: 1 / -1; }

	.blog-grid { grid-template-columns: repeat(2, 1fr); }

	.article-content figure { margin-left: 0; margin-right: 0; }
}

@media (max-width: 640px) {
	.topbar { padding: 14px var(--gutter); }
	.brand { font-size: 16px; }

	.hero { padding-top: 100px; padding-bottom: 60px; }
	.hero-meta { gap: 20px; }
	.hero-meta span:not(:last-child)::after { right: -14px; }

	.exp-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}

	.footer-top { grid-template-columns: 1fr; gap: 36px; }
	.footer-bottom { font-size: 10px; flex-direction: column; align-items: flex-start; }

	.quote { font-size: 22px; }
	.words-meta { gap: 24px; flex-direction: column; }

	.blog-grid { grid-template-columns: 1fr; }

	.article-content figure { margin: 1.5em 0; }
	.article-nav { grid-template-columns: 1fr; }
	.article-nav-next { grid-column: 1; text-align: left; }

	.carte-item-head { flex-direction: column; gap: 4px; align-items: flex-start; }
}

/* ================================================================
   CARTE — polish supplémentaire
   ================================================================ */

/* ================================================================
   SOUS-MENU DÉROULANT (header)
   ================================================================ */

/* Le parent doit être positionné pour que le sous-menu se positionne dessous */
.nav > li,
.nav .menu-item-has-children {
	position: relative;
}

/* Le sous-menu : caché par défaut, déroule au hover */
.nav .sub-menu {
	position: absolute;
	top: calc(100% + 14px);
	left: 50%;
	transform: translateX(-50%);
	min-width: 240px;
	background: var(--cream);
	border: 1px solid var(--line);
	padding: 18px 0;
	list-style: none;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--t-fast), transform var(--t-fast), visibility var(--t-fast);
	box-shadow: 0 8px 32px rgba(24, 22, 20, 0.06);
	z-index: 50;
}

/* Petite flèche indicative au-dessus du sous-menu */
.nav .sub-menu::before {
	content: '';
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%) rotate(45deg);
	width: 10px;
	height: 10px;
	background: var(--cream);
	border-top: 1px solid var(--line);
	border-left: 1px solid var(--line);
}

/* Hover sur le parent → affiche le sous-menu */
.nav > li:hover > .sub-menu,
.nav > li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(-6px);
}

/* Items du sous-menu */
.nav .sub-menu li {
	list-style: none;
	margin: 0;
}
.nav .sub-menu a {
	display: block;
	padding: 10px 24px;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-soft);
	white-space: nowrap;
	transition: color var(--t-fast), background var(--t-fast), padding-left var(--t-fast);
}
.nav .sub-menu a::after { display: none; } /* pas de soulignement sur les sous-items */
.nav .sub-menu a:hover {
	color: var(--terracotta);
	background: var(--cream-deep);
	padding-left: 28px;
}

/* Indicateur visuel "▾" sur le parent qui a des enfants */
.nav .menu-item-has-children > a::before {
	content: '';
	display: inline-block;
	width: 5px;
	height: 5px;
	border-right: 1px solid currentColor;
	border-bottom: 1px solid currentColor;
	transform: rotate(45deg);
	margin-right: 8px;
	margin-bottom: 2px;
	transition: transform var(--t-fast);
	opacity: 0.6;
}
.nav .menu-item-has-children:hover > a::before {
	transform: rotate(225deg);
}

/* En mobile, le sous-menu se déploie inline (pas de hover possible) */
@media (max-width: 980px) {
	.mobile-menu .sub-menu {
		list-style: none;
		padding: 0 0 0 20px;
		margin: 12px 0 0;
		border-left: 1px solid var(--line);
	}
	.mobile-menu .sub-menu a {
		font-family: var(--body);
		font-size: 13px;
		font-weight: 400;
		letter-spacing: 0.16em;
		text-transform: uppercase;
		padding: 10px 0;
		color: var(--ink-soft);
	}
	.mobile-menu .sub-menu a:hover {
		color: var(--terracotta);
		padding-left: 8px;
	}
}

/* ============================================================
   FIX SOUS-MENU — alignement gauche du parent
   ============================================================ */

.nav .sub-menu {
	position: absolute;
	top: calc(100% + 14px);
	left: 0;                  /* ← aligné au bord gauche du parent */
	transform: none;          /* ← plus de translateX(-50%) */
	min-width: 240px;
	background: var(--cream);
	border: 1px solid var(--line);
	padding: 18px 0;
	list-style: none;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--t-fast), transform var(--t-fast), visibility var(--t-fast);
	box-shadow: 0 8px 32px rgba(24, 22, 20, 0.06);
	z-index: 50;
}

.nav .sub-menu::before {
	content: '';
	position: absolute;
	top: -6px;
	left: 24px;               /* ← flèche au-dessus du parent, pas au milieu du sous-menu */
	transform: rotate(45deg); /* ← plus de translateX(-50%) */
	width: 10px;
	height: 10px;
	background: var(--cream);
	border-top: 1px solid var(--line);
	border-left: 1px solid var(--line);
}

.nav > li:hover > .sub-menu,
.nav > li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(-6px);  /* ← plus de translateX(-50%) */
}

/* ================================================================
   CARTE — items "inclus" sans prix réel
   ================================================================ */

/* Quand le prix est "inclus", on l'affiche en plus discret pour ne pas
   casser le rythme visuel de la carte */
.carte-item-price:where([data-inclus="true"]) {
	font-size: 12px;
	font-style: italic;
	font-weight: 400;
	color: var(--ink-muted);
	letter-spacing: 0.04em;
	text-transform: lowercase;
}

/* ================================================================
   PAGE ANNIVERSAIRE — formula cards
   ================================================================ */

.content-inner .formula-cards {
	gap: 24px;
	margin: 2.5em -16px;
}

.content-inner .formula-card {
	border: 1px solid var(--line-warm);
	background: var(--cream);
	padding: clamp(28px, 3vw, 40px);
	transition: border-color 0.3s ease, transform 0.3s ease;
	display: flex !important;
	flex-direction: column;
	flex-basis: 0;
}

.content-inner .formula-card:hover {
	border-color: var(--terracotta);
	transform: translateY(-4px);
}

/* Card en avant (la grande tablée — celle qu'on veut pousser le plus) */
.content-inner .formula-card.formula-card-featured {
	background: var(--forest);
	color: var(--cream);
	border-color: var(--forest);
}
.content-inner .formula-card.formula-card-featured h3,
.content-inner .formula-card.formula-card-featured .formula-price {
	color: var(--cream);
}
.content-inner .formula-card.formula-card-featured p,
.content-inner .formula-card.formula-card-featured ul {
	color: rgba(244,238,227,0.78);
}
.content-inner .formula-card.formula-card-featured .formula-capacity {
	color: var(--gold);
}
.content-inner .formula-card.formula-card-featured .formula-price {
	border-top-color: rgba(244,238,227,0.18);
}
.content-inner .formula-card.formula-card-featured .formula-price em {
	color: var(--gold);
}

/* Capacité — sur-titre orange en haut de la card */
.content-inner .formula-capacity {
	font-family: var(--body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 16px !important;
}

/* H3 dans la card — taille ajustée */
.content-inner .formula-card h3 {
	font-family: var(--display);
	font-weight: 300;
	font-size: clamp(28px, 3vw, 38px);
	margin-top: 0 !important;
	margin-bottom: 16px;
	color: var(--forest);
	letter-spacing: -0.01em;
}

/* Liste des inclus — points discrets */
.content-inner .formula-card ul {
	list-style: none;
	padding-left: 0;
	margin: 16px 0;
	font-size: 14px;
	line-height: 1.7;
}
.content-inner .formula-card ul li {
	padding-left: 18px;
	position: relative;
	margin-bottom: 6px;
}
.content-inner .formula-card ul li::before {
	content: '';
	position: absolute;
	left: 0; top: 12px;
	width: 8px;
	height: 1px;
	background: var(--terracotta);
}

/* Tarif en bas de card — séparé par une ligne */
.content-inner .formula-price {
	margin-top: auto !important;
	padding-top: 24px;
	border-top: 1px solid var(--line);
	font-family: var(--display);
	font-size: 18px;
	font-weight: 400;
	color: var(--forest);
	letter-spacing: -0.005em;
}
.content-inner .formula-price em {
	font-style: italic;
	color: var(--terracotta);
	display: block;
	font-size: 0.9em;
	margin-top: 4px;
}

/* Mobile — les cards passent en pile */
@media (max-width: 980px) {
	.content-inner .formula-cards {
		flex-direction: column;
		gap: 20px;
	}
	.content-inner .formula-card {
		margin-bottom: 0;
	}
}