.cmplz-video.cmplz-iframe-styles{background-color:transparent}.cmplz-video.cmplz-hidden{visibility:hidden !important}.cmplz-blocked-content-notice{display:none}.cmplz-placeholder-parent{height:inherit}.cmplz-optin .cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-optin .cmplz-wp-video .cmplz-blocked-content-notice,.cmplz-optout .cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-optout .cmplz-wp-video .cmplz-blocked-content-notice{display:block}.cmplz-blocked-content-container,.cmplz-wp-video{animation-name:cmplz-fadein;animation-duration:600ms;background:#FFF;border:0;border-radius:3px;box-shadow:0 0 1px 0 rgba(0,0,0,0.5),0 1px 10px 0 rgba(0,0,0,0.15);display:flex;justify-content:center;align-items:center;background-repeat:no-repeat !important;background-size:cover !important;height:inherit;position:relative}.cmplz-blocked-content-container.gmw-map-cover,.cmplz-wp-video.gmw-map-cover{max-height:100%;position:absolute}.cmplz-blocked-content-container.cmplz-video-placeholder,.cmplz-wp-video.cmplz-video-placeholder{padding-bottom:initial}.cmplz-blocked-content-container iframe,.cmplz-wp-video iframe{visibility:hidden;max-height:100%;border:0 !important}.cmplz-blocked-content-container .cmplz-custom-accept-btn,.cmplz-wp-video .cmplz-custom-accept-btn{white-space:normal;text-transform:initial;cursor:pointer;position:absolute !important;width:100%;top:50%;left:50%;transform:translate(-50%,-50%);max-width:200px;font-size:14px;padding:10px;background-color:rgba(0,0,0,0.5);color:#fff;text-align:center;z-index:98;line-height:23px}.cmplz-blocked-content-container .cmplz-custom-accept-btn:focus,.cmplz-wp-video .cmplz-custom-accept-btn:focus{border:1px dotted #cecece}.cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-wp-video .cmplz-blocked-content-notice{white-space:normal;text-transform:initial;position:absolute !important;width:100%;top:50%;left:50%;transform:translate(-50%,-50%);max-width:300px;font-size:14px;padding:10px;background-color:rgba(0,0,0,0.5);color:#fff;text-align:center;z-index:98;line-height:23px}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-links,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-links{display:block;margin-bottom:10px}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-links a,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-links a{color:#fff}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-blocked-content-notice-body,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-blocked-content-notice-body{display:block}.cmplz-blocked-content-container div div{display:none}.cmplz-wp-video .cmplz-placeholder-element{width:100%;height:inherit}@keyframes cmplz-fadein{from{opacity:0}to{opacity:1}}/*
Theme Name: La Grande Evasion
Theme URI: https://www.la-grande-evasion.com
Author: Côme
Description: Thème personnalisé La Grande Evasion basé sur BlankSlate
Version: 1.0
Text Domain: lagrandeevasion
*/

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{appearance:none;border-radius:0}input[type="search"]{appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:bold}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.sticky{}.bypostauthor{}.wp-caption{}.wp-caption-text{}.gallery-caption{}.alignright{}.alignleft{}.aligncenter{}
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:#f7f7f7;border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;clip-path:none;color:#007acc;display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}

.lge-404 {
	width: min(1200px, calc(100% - 40px));
	margin: 0 auto;
	padding: 60px 0;
	text-align: center;
	color: #000;
}

.lge-404 h1,
.lge-404 p,
.lge-404 a {
	color: #000;
}

:root {
	--lge-font-main: 'Roboto Slab', Georgia, serif;
}

html,
body {
	font-family: var(--lge-font-main);
}

body,
button,
input,
select,
textarea {
	font-family: var(--lge-font-main);
}

h1, h2, h3, h4, h5, h6,
p,
li,
blockquote,
a,
label,
td,
th,
figcaption,
.wp-block-button__link,
.wp-element-button {
	font-family: inherit;
}

/* Éléments fréquents du thème */
.lge-header,
.lge-header a,
.lge-header button,
.lge-main-menu > li > a,
.lge-top-menu a {
	font-family: var(--lge-font-main);
}

img.emoji,
img.wp-smiley {
	display: inline !important;
	width: 1em !important;
	height: 1em !important;
	max-width: 1em !important;
	vertical-align: -0.10em;
	margin-left: 0.05em !important;
	margin-right: 0.28em !important;
}
/* Roboto Slab — self-hosted (v36, latin) */

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 100;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-100.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-200.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-300.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-regular.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-500.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-600.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-700.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-800.woff2) format('woff2');
}

@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(//www.la-grande-evasion.com/wp-content/themes/lagrandeevasion/assets/fonts/roboto-slab-v36-latin-900.woff2) format('woff2');
}
:root {
  /* =========================
     PALETTE GLOBALE
  ========================= */
  --color-cream: #f2efe8;
  --color-cream-soft: #f7f4ee;
  --color-cream-strong: #e9e2d4;

  --color-bg: var(--color-cream);
  --color-surface: #ffffff;
  --color-text: #111111;
  --color-text-soft: rgba(17, 17, 17, 0.88);
  --color-heading: var(--color-primary);
  --color-border: rgba(17, 17, 17, 0.12);

  --color-primary: #c39b58;
  --color-primary-hover: #ad8446;

  --color-surface-dark: rgba(0, 0, 0, 0.35);
  --color-surface-darker: #1c1c1c;
  --color-overlay: rgba(0, 0, 0, 0.6);

  /* =========================
     TYPOGRAPHIE
  ========================= */
  --font-main: "Roboto Slab", Georgia, serif;
  --font-title: "Roboto Slab", Georgia, serif;

  --font-size-body-desktop: 15px;
  --font-size-body-mobile: 15px;

  --line-height-body-desktop: 1.6;
  --line-height-body-mobile: 1.55;

  --paragraph-spacing-desktop: 0.9em;
  --paragraph-spacing-mobile: 0.8em;

  --heading-line-height-tight: 1.08;
  --heading-line-height: 1.18;

  --h1-size-desktop: clamp(24px, 2vw, 30px);
  --h2-size-desktop: clamp(26px, 1.75vw, 27px);
  --h3-size-desktop: clamp(18px, 1.5vw, 24px);
  --h4-size-desktop: clamp(18px, 1.5vw, 24px);
  --h5-size-desktop: 18px;
  --h6-size-desktop: 16px;

  --h1-size-mobile: 24px;
  --h2-size-mobile: 24px;
  --h3-size-mobile: 18px;
  --h4-size-mobile: 18px;
  --h5-size-mobile: 17px;
  --h6-size-mobile: 16px;

  --title-display-size: clamp(38px, 5vw, 72px);
  --title-section-size: var(--h2-size-desktop);
  --title-card-size: clamp(22px, 2.1vw, 30px);

  /* =========================
     COULEURS DE TITRES
  ========================= */
  --title-white: #ffffff;
  --title-gold: var(--color-primary);
  --title-black: #111111;

  /* =========================
     CONTENEURS
  ========================= */
  --container-width: 1200px;
  --container-padding: 20px;
  --content-width-narrow: 1000px;
  --content-width-text: 800px;

  /* =========================
     ESPACEMENTS
  ========================= */
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 20px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 40px;

  --block-gap-desktop: 24px;
  --block-gap-mobile: 18px;
  --separator-space: 10px;

  /* =========================
     RAYONS / OMBRES / ANIMATIONS
  ========================= */
  --radius-small: 8px;
  --radius-medium: 14px;
  --radius-large: 22px;
  --radius-pill: 999px;

  --shadow-strong: 0 10px 50px rgba(0, 0, 0, 0.5);
  --transition: 0.25s ease;

  /* =========================
     MOBILE BG LAYER
     Ajustables par composant si besoin
  ========================= */
  --mobile-bg-top: 130px;
  --mobile-bg-height: 340px;
}

/* =========================
   VARIANTES DE THÈME
========================= */

.theme-light {
  --color-bg: var(--color-cream);
  --color-text: #111111;
  --color-text-soft: rgba(17, 17, 17, 0.88);
  --color-heading: var(--color-primary);
  --color-border: rgba(17, 17, 17, 0.12);
}

.theme-dark {
  --color-bg: #000000;
  --color-surface: #111111;
  --color-text: #ffffff;
  --color-text-soft: rgba(255, 255, 255, 0.84);
  --color-heading: #ffffff;
  --color-border: rgba(255, 255, 255, 0.14);
}

.theme-gold {
  --color-text: #ffffff;
  --color-text-soft: rgba(255, 255, 255, 0.88);
  --color-heading: #ffffff;
  --color-border: rgba(255, 255, 255, 0.18);
}

/* =========================
   RESET GLOBAL
========================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

html {
  margin: 0;
  padding: 0;
}

/* scroll-behavior conditionné pour respecter les préférences
   d'accessibilité (évite les problèmes de vertiges / épilepsie) */
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

body {
  margin: 0;
  padding: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-main);
  font-size: var(--font-size-body-desktop);
  line-height: var(--line-height-body-desktop);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

/* Exceptions pour les emojis WordPress */
img.emoji,
img.wp-smiley {
  display: inline !important;
  width: 1em;
  height: 1em;
  max-width: 1em;
  vertical-align: -0.12em;
  margin-left: 0.08em;
  margin-right: 0.14em;
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

/* =========================
   LIENS
========================= */

a {
  color: var(--color-heading);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: var(--transition);
}

a:hover,
a:focus {
  color: var(--color-primary-hover);
}

/* =========================
   TYPOGRAPHIE GLOBALE
========================= */

p,
ul,
ol,
li {
  font-size: inherit;
  line-height: inherit;
}

p {
  margin: 0 0 var(--paragraph-spacing-desktop);
  color: var(--color-text-soft);
}

p:last-child {
  margin-bottom: 0;
}

ul,
ol {
  margin: 0 0 var(--paragraph-spacing-desktop);
  padding-left: 1.25em;
  color: var(--color-text-soft);
}

li {
  margin: 0 0 0.3em;
  color: inherit;
}

li:last-child {
  margin-bottom: 0;
}

h1,
h2,
h4,
h5,
h6 {
  margin: 0;
  font-family: var(--font-title);
  color: var(--color-heading);
}

/* h3 utilise --color-text (plus neutre) plutôt que --color-heading (or)
   car il sert souvent de titre de section secondaire sur fond sombre
   ou à l'intérieur de blocs déjà colorés. Intentionnel. */
h3 {
  margin: 0;
  font-family: var(--font-title);
  color: var(--color-text);
}

h1 {
  font-size: var(--h1-size-desktop);
  line-height: var(--heading-line-height-tight);
  margin-bottom: 0.45em;
}

h2 {
  font-size: var(--h2-size-desktop);
  line-height: var(--heading-line-height-tight);
  font-weight: 500;
  margin-top: 1.1em;
  margin-bottom: 0.55em;
}

h3 {
  font-size: var(--h3-size-desktop);
  line-height: var(--heading-line-height);
  font-weight: 500;
  margin-top: 1em;
  margin-bottom: 0.45em;
}

h4 {
  font-size: var(--h4-size-desktop);
  line-height: var(--heading-line-height);
  margin-bottom: 0.4em;
}

h5 {
  font-size: var(--h5-size-desktop);
  line-height: var(--heading-line-height);
  margin-bottom: 0.35em;
}

h6 {
  font-size: var(--h6-size-desktop);
  line-height: var(--heading-line-height);
  margin-bottom: 0.35em;
}

strong,
b {
  color: var(--color-text);
  font-weight: 700;
}

small {
  font-size: 0.9em;
}

blockquote {
  margin: 0 0 1.2em;
  padding-left: 1.2em;
  border-left: 3px solid currentColor;
  color: var(--color-text);
  font-style: italic;
  line-height: inherit;
}

hr {
  margin: 1.2em 0;
  border: none;
  border-top: 1px solid var(--color-border);
}

/* =========================
   SÉPARATEUR WORDPRESS
========================= */

.wp-block-separator {
  border: none;
  background: transparent;
  opacity: 0;
  height: var(--separator-space);
  margin: 0;
}

/* =========================
   CLASSES TEXTE UTILITAIRES
========================= */

.text-soft {
  color: var(--color-text-soft);
}

.text-strong {
  color: var(--color-text);
}

/* Utilisation de la cascade CSS plutôt que !important :
   ces classes sont appliquées directement sur les éléments
   ou sur un conteneur proche, ce qui garantit la priorité. */
.text-gold {
  color: var(--title-gold);
}

.text-gold * {
  color: inherit;
}

.text-center {
  text-align: center;
}

.title-uppercase {
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.title-display {
  font-size: var(--title-display-size);
  line-height: 1.02;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.title-section {
  font-size: var(--title-section-size);
  line-height: var(--heading-line-height-tight);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.title-card {
  font-size: var(--title-card-size);
  line-height: 1.08;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

/* =========================
   COULEURS DE TITRES DIRECTES
   Appliquées sur l'élément heading lui-même.
   On utilise une spécificité élevée (h1.title-white etc.)
   pour éviter les !important tout en restant prioritaires
   sur les styles de base.
========================= */

h1.title-white,
h2.title-white,
h3.title-white,
h4.title-white,
h5.title-white,
h6.title-white {
  color: var(--title-white);
}

h1.title-white *,
h2.title-white *,
h3.title-white *,
h4.title-white *,
h5.title-white *,
h6.title-white * {
  color: inherit;
}

h1.title-gold,
h2.title-gold,
h3.title-gold,
h4.title-gold,
h5.title-gold,
h6.title-gold {
  color: var(--title-gold);
}

h1.title-gold *,
h2.title-gold *,
h3.title-gold *,
h4.title-gold *,
h5.title-gold *,
h6.title-gold * {
  color: inherit;
}

h1.title-black,
h2.title-black,
h3.title-black,
h4.title-black,
h5.title-black,
h6.title-black {
  color: var(--title-black);
}

h1.title-black *,
h2.title-black *,
h3.title-black *,
h4.title-black *,
h5.title-black *,
h6.title-black * {
  color: inherit;
}

/* =========================
   COULEURS DE TITRES PAR ZONE
   Appliquées sur un conteneur parent (.zone-titles-*).
   La spécificité (.zone-titles-white h1) suffit à l'emporter
   sur les styles de base sans recourir à !important.
========================= */

.zone-titles-white h1,
.zone-titles-white h2,
.zone-titles-white h3,
.zone-titles-white h4,
.zone-titles-white h5,
.zone-titles-white h6 {
  color: var(--title-white);
}

.zone-titles-white h1 *,
.zone-titles-white h2 *,
.zone-titles-white h3 *,
.zone-titles-white h4 *,
.zone-titles-white h5 *,
.zone-titles-white h6 * {
  color: inherit;
}

.zone-titles-gold h1,
.zone-titles-gold h2,
.zone-titles-gold h3,
.zone-titles-gold h4,
.zone-titles-gold h5,
.zone-titles-gold h6 {
  color: var(--title-gold);
}

.zone-titles-gold h1 *,
.zone-titles-gold h2 *,
.zone-titles-gold h3 *,
.zone-titles-gold h4 *,
.zone-titles-gold h5 *,
.zone-titles-gold h6 * {
  color: inherit;
}

.zone-titles-black h1,
.zone-titles-black h2,
.zone-titles-black h3,
.zone-titles-black h4,
.zone-titles-black h5,
.zone-titles-black h6 {
  color: var(--title-black);
}

.zone-titles-black h1 *,
.zone-titles-black h2 *,
.zone-titles-black h3 *,
.zone-titles-black h4 *,
.zone-titles-black h5 *,
.zone-titles-black h6 * {
  color: inherit;
}

/* =========================
   CONTENEURS GLOBAUX
========================= */

.site-container {
  width: 100%;
  max-width: var(--container-width);
  margin: 0 auto;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

.site-container--narrow {
  max-width: var(--content-width-narrow);
}

.site-container--text {
  max-width: var(--content-width-text);
}

.lge-container {
  width: min(1400px, calc(100% - 40px));
  margin: 0 auto;
}

.wp-block[data-align="full"] {
  width: 100%;
  max-width: none;
}

/* =========================
   UTILITAIRES VISUELS
========================= */

.has-responsive-bg {
  background-image: var(--bg-desktop);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.has-mobile-bg-layer {
  position: relative;
}

.title-gradient-gold {
  background: linear-gradient(
    6deg,
    rgba(120, 100, 62, 1) 0%,
    rgba(237, 187, 100, 1) 50%,
    rgba(159, 123, 63, 1) 100%
  );
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* =========================
   BOUTONS GLOBAUX
========================= */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  padding: 12px 24px;
  border: 1px solid transparent;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  transition: var(--transition);
  cursor: pointer;
}

.btn--pill {
  border-radius: var(--radius-pill);
}

.btn--rounded {
  border-radius: var(--radius-small);
}

.btn--outline-light {
  background: rgba(0, 0, 0, 0.5);
  color: #ffffff;
  border-color: #ffffff;
}

.btn--outline-light:hover,
.btn--outline-light:focus {
  background: rgba(255, 255, 255, 0.92);
  color: #000000;
}

.btn--primary {
  background: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
}

.btn--primary:hover,
.btn--primary:focus {
  background: var(--color-primary-hover);
  color: #ffffff;
  border-color: var(--color-primary-hover);
}

.btn--dark {
  background: #111111;
  color: var(--color-cream);
  border-color: #111111;
}

.btn--dark:hover,
.btn--dark:focus {
  background: #2a2a2a;
  color: var(--color-cream);
  border-color: #2a2a2a;
}

.btn-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 15px 24px;
  width: 100%;
}

/* =========================
   FLÈCHES SLIDER GLOBALES
========================= */

.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  padding: 10px;
  background: rgba(0, 0, 0, 0.6);
  color: #ffffff;
  border: none;
  border-radius: var(--radius-small);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: var(--transition);
}

.slider-arrow:hover,
.slider-arrow:focus {
  background: rgba(0, 0, 0, 0.8);
}

/* =========================
   MODALE GLOBALE
========================= */

.modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
}

.modal.is-open {
  display: flex;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
}

.modal__dialog {
  position: relative;
  width: calc(100% - 32px);
  max-width: 720px;
  padding: 20px;
  background: var(--color-surface-darker);
  color: #ffffff;
  border-radius: var(--radius-medium);
  box-shadow: var(--shadow-strong);
  text-align: center;
}

.modal__close {
  position: absolute;
  top: 8px;
  right: 10px;
  background: transparent;
  color: #ffffff;
  border: none;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.modal__title {
  margin: 0 0 12px;
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  line-height: 1.2;
  text-align: center;
  color: #ffffff;
}

.modal__image {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto 14px;
  border-radius: var(--radius-small);
}

.modal__text {
  margin: 0 0 20px;
  font-size: clamp(1rem, 2.3vw, 1.25rem);
  line-height: 1.55;
  white-space: pre-wrap;
  text-align: center;
  color: #ffffff;
}

/* =========================
   BASE WORDPRESS / PAGES
========================= */

body.page {
  background: #000000;
}

body.page:has(.page-bg-light) {
  background: var(--color-bg);
}

body.page .site,
body.page .site-content,
body.page .content-area,
body.page .site-main,
body.page article,
body.page .entry-content {
  background: transparent;
}

body.page .entry-header {
  display: none;
}

body.page .ast-container {
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body.page .entry-content {
  margin: 0;
}

body.page .entry-content > * {
  margin-top: 0;
  margin-bottom: 0;
}

body.page .entry-content > * + * {
  margin-top: var(--block-gap-desktop);
}

body.page .entry-content > *:first-child {
  margin-top: 0;
}

body.page .entry-content > *:last-child {
  margin-bottom: 0;
}

body.page .entry-content > .wp-block-spacer {
  height: var(--separator-space);
}

body.page .entry-content > [class*="wp-block-lge-"] {
  margin-top: 0;
  margin-bottom: 0;
}

/* =========================
   RESPONSIVE GLOBAL
========================= */

@media (max-width: 768px) {
  :root {
    --container-padding: 16px;
  }

  body {
    font-size: var(--font-size-body-mobile);
    line-height: var(--line-height-body-mobile);
  }

  p {
    margin-bottom: var(--paragraph-spacing-mobile);
  }

  ul,
  ol {
    margin-bottom: var(--paragraph-spacing-mobile);
  }

  h1 {
    font-size: var(--h1-size-mobile);
  }

  h2 {
    font-size: var(--h2-size-mobile);
    margin-top: 1em;
    margin-bottom: 0.5em;
  }

  h3 {
    font-size: var(--h3-size-mobile);
    margin-top: 0.9em;
    margin-bottom: 0.45em;
  }

  h4 {
    font-size: var(--h4-size-mobile);
  }

  h5 {
    font-size: var(--h5-size-mobile);
  }

  h6 {
    font-size: var(--h6-size-mobile);
  }

  .title-section {
    font-size: var(--h2-size-mobile);
  }

  .title-card {
    font-size: var(--h3-size-mobile);
  }

  .has-responsive-bg {
    background-image: var(--bg-mobile, var(--bg-desktop));
  }

  /* Le positionnement du calque mobile est piloté par les
     variables --mobile-bg-top et --mobile-bg-height, définissables
     au niveau du composant pour s'adapter aux différents contextes. */
  .has-mobile-bg-layer::before {
    content: "";
    position: absolute;
    top: var(--mobile-bg-top);
    left: 0;
    width: 100%;
    height: var(--mobile-bg-height);
    background-image: var(--bg-mobile, var(--bg-desktop));
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
    z-index: 0;
  }

  .btn-grid-2 {
    grid-template-columns: repeat(2, minmax(150px, 1fr));
    gap: 12px;
  }

  .btn {
    width: 100%;
    min-width: 0;
  }

  .slider-arrow {
    top: auto;
    bottom: 16px;
    transform: none;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .modal__dialog {
    width: calc(100% - 24px);
    padding: 16px;
  }

  .modal__text {
    font-size: 1rem;
    line-height: 1.5;
  }

  body.page .entry-content > * + * {
    margin-top: var(--block-gap-mobile);
  }
}

/* =======================
   Ajout par Ludo  
======================= */
/* Permet d'aligner un h2 à gauche plutôt qu'il soit centré */
.lge-h2-left {	
	text-align: left;
}

/* Ajout par Ludo le 09/05/26 pour pouvoir ajouter des boutons !
 * en utilisant la balise <a href="#ancre-contact-chambery" class="lge-bouton">
   Attention c'est long ! */

/* Cette classe est à mettre dans une div qui englobe le bouton pour pouvoir le centrer */
.lge-centreur-bouton{	
	text-align: center;
}

.lge-bouton {
	display: inline-block;
	align-items: center;
	justify-content: center;
	min-width: 160px;
	max-width: 500px;
	padding: 12px 12px;
	background: #c39b58;
	color: #FFF;
	font-size: 1.1em;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	border: 2px solid #fff;
	border-radius: 25px;
	transition: background 0.3s ease, color 0.3s ease;
}

.lge-bouton:hover {
	background: rgba(255, 255, 255, 0.9);
	color: #000;
}

@media (max-width: 768px) {
	.lge-bouton {
		min-width: 0;
		max-width: 320px;
		padding: 12px 12px;
		font-size: 0.95rem;
		border-radius: 22px;
		background: #c39b58;
	}
}

@media (max-width: 480px) {
	.lge-bouton {
		font-size: 0.9rem;
		padding: 9px 6px;
	}
}
/* Fin ajout Ludo du 09/05/26 */#masthead {
	display: none !important;
}
:root {
	--lge-top-offset: 0px;
	--lge-header-clearance: 190px;
	--lge-header-gap: 20px;
}

.lge-header {
	--lge-container: 1420px;
	--lge-x: 24px;
	--lge-logo-col: 360px;
	--lge-city-col: 210px;
	--lge-gold: #b28a46;
	--lge-gold-hover: #9c773b;
	--lge-dark: #111111;
	--lge-black: #000000;
	--lge-text: #ffffff;

	position: absolute;
	top: var(--lge-top-offset);
	left: 0;
	width: 100%;
	z-index: 9999;
	background: transparent;
	color: var(--lge-text);
}

body.admin-bar .lge-header {
	top: calc(32px + var(--lge-top-offset));
}

@media (max-width: 920px) {
	:root {
		--lge-top-offset: 12px;
		--lge-header-clearance: 150px;
	}
}

@media (max-width: 782px) {
	body.admin-bar .lge-header {
		top: calc(46px + var(--lge-top-offset));
	}
}

@media (max-width: 520px) {
	:root {
		--lge-top-offset: 10px;
		--lge-header-clearance: 135px;
	}
}

.lge-header__container {
	width: 100%;
	max-width: var(--lge-container);
	margin: 0 auto;
	padding-left: var(--lge-x);
	padding-right: var(--lge-x);
	box-sizing: border-box;
}

/* =========================================================
   BASE
========================================================= */
.lge-header,
.lge-header__desktop,
.lge-header__mobile,
.lge-header__mobile-top,
.lge-header__mobile-main {
	background: transparent;
}


.lge-header a,
.lge-header a:visited,
.lge-header a:hover,
.lge-header a:focus,
.lge-header a:active {
	text-decoration: none !important;
	outline: none !important;
	box-shadow: none !important;
}

.lge-header__branding .custom-logo-link,
.lge-header__branding .lge-header__logo-link,
.lge-header__extra-logo-link {
	display: inline-flex;
	align-items: flex-start;
	line-height: 0;
	margin: 0;
	padding: 0;
}

.lge-header__branding img,
.lge-header__branding .custom-logo,
.lge-header__extra-logo {
	display: block;
	width: auto;
	height: auto;
	margin: 0;
	padding: 0;
}

/* =========================================================
   DESKTOP
========================================================= */

.lge-header__mobile,
.lge-header__top-nav-mobile,
.lge-burger {
	display: none;
}
.lge-header__desktop {
	display: block;
	position: relative;
}

.lge-header__desktop-inner {
	display: grid;
	grid-template-columns: var(--lge-logo-col) minmax(0, 1fr);
	grid-template-areas:
		"logo top"
		"logo main";
	column-gap: 20px;
	/* Modif par Ludo le 13/04/26 pour esthétique
	row-gap: 10px; */
	row-gap: 0px; 
	align-items: start;
	padding-top: 0;
	padding-right: calc(var(--lge-city-col) + 18px);
}

/* zone logos desktop */

.lge-header__branding--desktop {
	grid-area: logo;
	align-self: start;
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding-top: 0;
	z-index: 2;
	line-height: 0;
}

.lge-header__extra-logo-link {
	display: inline-flex;
	align-items: flex-start;
	flex: 0 0 auto;
}

.lge-header__extra-logo {
	display: block;
	width: auto;
	height: 130px;
	max-width: 90px;
	object-fit: contain;
}

.lge-header__branding--desktop .custom-logo-link,
.lge-header__branding--desktop .lge-header__logo-link {
	display: inline-flex;
	align-items: flex-start;
	flex: 0 1 auto;
}

.lge-header__branding--desktop .custom-logo {
	margin-top: 52px;
	display: block;
	width: auto;
	height: auto;
	max-width: 200px;
	max-height: 168px;
}

/* top nav desktop */

.lge-header__top-nav--desktop {
	grid-area: top;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-height: 68px;
}

.lge-top-menu {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 34px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.lge-top-menu li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.lge-top-menu a,
.lge-top-menu a:visited,
.lge-top-menu a:hover,
.lge-top-menu a:focus,
.lge-top-menu a:active {
	color: var(--lge-text) !important;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.2px;
}

.lge-top-menu a:hover,
.lge-top-menu a:focus,
.lge-top-menu .current-menu-item > a,
.lge-top-menu .current_page_item > a {
	opacity: 0.8;
}

/* bouton ville desktop : complètement à droite */

.lge-header__city--desktop {
	position: absolute;
	top: 0;
	right: 0;
	width: var(--lge-city-col);
	align-self: auto;
	justify-self: auto;
	z-index: 200;
}

.lge-city-toggle {
	appearance: none;
	-webkit-appearance: none;
	position: relative;
	width: 100%;
	border: none;
	background: var(--lge-gold) !important;
	color: var(--lge-text) !important;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	outline: none !important;
	box-shadow: none !important;
	-webkit-tap-highlight-color: transparent;
}

.lge-city-toggle:hover,
.lge-city-toggle:focus,
.lge-city-toggle:active {
	background: var(--lge-gold) !important;
	color: var(--lge-text) !important;
}

.lge-header__city--desktop .lge-city-toggle {
	height: 68px;
	min-height: 68px;
	padding: 14px 38px 14px 16px;
	border-radius: 0 0 14px 14px;
	gap: 8px;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: 0.2px;
	text-transform: none;
}

.lge-city-toggle__label {
	opacity: 0.95;
	text-transform: uppercase;
	letter-spacing: 0.7px;
}

.lge-city-toggle__value {
	font-weight: 800;
	line-height: 1;
	text-align: center;
}

.lge-city-toggle__arrow {
	position: absolute;
	right: 14px;
	top: 50%;
	display: block;
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-65%) rotate(45deg);
	line-height: 1;
	pointer-events: none;
}

.lge-city-dropdown {
	position: absolute;
	right: 0;
	left: auto;
	top: calc(100%);
	min-width: 100%;
	background: var(--lge-dark);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.3);
	display: none;
	z-index: 9999;
}

.lge-header__city:hover .lge-city-dropdown,
.lge-header__city:focus-within .lge-city-dropdown,
.lge-header__city.is-open .lge-city-dropdown {
	display: block;
}

.lge-city-dropdown a,
.lge-city-dropdown a:visited,
.lge-city-dropdown a:hover,
.lge-city-dropdown a:focus,
.lge-city-dropdown a:active {
	display: block;
	padding: 15px 18px;
	color: var(--lge-text) !important;
	font-size: 15px;
	text-align: center;
	white-space: nowrap;
	background: var(--lge-dark) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.lge-city-dropdown a:last-child {
	border-bottom: none;
}

.lge-city-dropdown a:hover,
.lge-city-dropdown a:focus,
.lge-city-dropdown a:active {
	background: #1a1a1a !important;
}

/* menu principal desktop */

.lge-header__main-nav--desktop {
	grid-area: main;
	width: 100%;
	align-self: start;
	pointer-events: none;
}

.lge-main-menu {
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
	flex-wrap: nowrap;
	pointer-events: auto;
}

.lge-main-menu > li {
	position: relative;
	margin: 0;
	padding: 0;
	list-style: none;
}

.lge-main-menu > li > a {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	/* Modif par Ludo le 13/04/26 pour esthétique
	min-height: 66px; */
	min-height: 50px;
	padding: 12px 15px;
	background: var(--lge-gold);
	color: var(--lge-text) !important;
	text-transform: uppercase;
	font-size: 12px;
	line-height: 1.15;
	font-weight: 800;
	letter-spacing: 0.8px;
	border-radius: 12px;
}

.lge-main-menu > li > a:hover,
.lge-main-menu > li > a:focus,
.lge-main-menu > li.current-menu-item > a,
.lge-main-menu > li.current_page_item > a {
	background: var(--lge-gold-hover);
	color: var(--lge-text) !important;
}

.lge-main-menu > li.menu-item-has-children > a::after {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	margin-left: 6px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	transform-origin: center;
	line-height: 1;
	flex: 0 0 auto;
}

.lge-main-menu .sub-menu {
	position: absolute;
	top: calc(100%);
	left: 0;
	min-width: 250px;
	margin: 0;
	padding: 0;
	list-style: none;
	background: var(--lge-dark);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
	display: none;
	z-index: 200;
}

.lge-main-menu > li:hover > .sub-menu,
.lge-main-menu > li:focus-within > .sub-menu {
	display: block;
}

.lge-main-menu .sub-menu li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.lge-main-menu .sub-menu a,
.lge-main-menu .sub-menu a:visited,
.lge-main-menu .sub-menu a:hover,
.lge-main-menu .sub-menu a:focus,
.lge-main-menu .sub-menu a:active {
	display: block;
	padding: 15px 18px;
	color: var(--lge-text) !important;
	background: var(--lge-dark) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.lge-main-menu .sub-menu li:last-child a {
	border-bottom: none;
}

.lge-main-menu .sub-menu a:hover,
.lge-main-menu .sub-menu a:focus {
	background: #1b1b1b !important;
}


/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 1180px) {
	.lge-header__desktop {
		display: none;
	}

	.lge-header__mobile {
		display: block;
		background: transparent !important;
	}
	.lge-salle-hero__inner {
		padding: calc(var(--lge-header-clearance) + 10px) 0 24px;
	}

	.lge-header__container {
		padding-left: 16px;
		padding-right: 16px;
	}

	.lge-header__mobile-top .lge-header__container {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-height: 44px;
	padding-top: 0;
	padding-bottom: 0;
}

	.lge-header__city--mobile {
	position: relative;
	width: auto;
	margin-left: auto;
	z-index: 9999;
}

	.lge-header__city--mobile .lge-city-toggle {
		width: auto !important;
		height: 38px;
		min-height: 38px;
		padding: 0 38px 0 16px;
		border-radius: 12px;
		gap: 0;
		font-size: 14px;
		font-weight: 800;
		white-space: nowrap;
	}

	
	.lge-header__city--mobile:hover .lge-city-dropdown,
	.lge-header__city--mobile:focus-within .lge-city-dropdown {
		display: none;
	}

	.lge-header__city--mobile.is-open .lge-city-dropdown {
		display: block;
	}

	.lge-header__mobile-main .lge-header__container {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: space-between;
		gap: 8px;
		padding-top: 0;
		padding-bottom: 14px;
	}

	.lge-header__branding--mobile {
		display: flex;
		flex: 0 1 auto;
		max-width: calc(100% - 60px);
		align-items: flex-start;
		margin-top: -8px;
		line-height: 0;
	}

	/* logo secondaire caché sur mobile */
	.lge-header__branding--mobile .lge-header__extra-logo-link,
	.lge-header__branding--mobile .lge-header__extra-logo,
	.lge-header__extra-logo-link,
	.lge-header__extra-logo {
		display: none !important;
	}

	/* logo principal un peu plus grand sur mobile */
	.lge-header__branding--mobile img,
	.lge-header__branding--mobile .custom-logo {
		width: 205px;
		max-width: 205px;
		max-height: none;
		height: auto;
	}

	.lge-burger {
		display: inline-flex !important;
		width: 44px;
		height: 44px;
		margin: 2px 0 0 auto !important;
		align-self: flex-start;
		align-items: center;
		justify-content: center;
		flex-direction: column;
		gap: 7px;
		padding: 0;
		border: none;
		background: transparent;
		cursor: pointer;
		outline: none !important;
		box-shadow: none !important;
		-webkit-tap-highlight-color: transparent;
	}

	.lge-burger span {
		display: block;
		width: 30px;
		height: 4px;
		border-radius: 2px;
		background: var(--lge-gold);
		transition: transform 0.25s ease, opacity 0.25s ease;
	}

	.lge-burger.is-open span:nth-child(1) {
		transform: translateY(11px) rotate(45deg);
	}

	.lge-burger.is-open span:nth-child(2) {
		opacity: 0;
	}

	.lge-burger.is-open span:nth-child(3) {
		transform: translateY(-11px) rotate(-45deg);
	}

	.lge-header__main-nav--mobile {
		display: none;
		order: 3;
		flex: 0 0 100%;
		width: 100%;
		max-width: 100%;
		margin-top: 10px;
		padding: 18px 16px 22px;
		background: #ae8740;
		border-radius: 16px;
		box-sizing: border-box;
	}

	.lge-header__main-nav--mobile.is-open {
		display: block !important;
	}

	.lge-header__top-nav-mobile {
		display: block;
		margin: 0 0 16px 0;
		padding: 0 0 16px 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.18);
	}

	.lge-top-menu--mobile {
		display: flex !important;
		justify-content: center;
		gap: 22px;
		flex-wrap: nowrap;
		margin: 0;
		padding: 0;
		list-style: none;
	}

	.lge-top-menu--mobile li {
		margin: 0;
		padding: 0;
		list-style: none;
	}

	.lge-top-menu--mobile a,
	.lge-top-menu--mobile a:visited,
	.lge-top-menu--mobile a:hover,
	.lge-top-menu--mobile a:focus,
	.lge-top-menu--mobile a:active {
		color: #ffffff !important;
		font-size: 12px;
		font-weight: 600;
		white-space: nowrap;
	}

	.lge-main-menu--mobile {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		justify-content: flex-start;
		gap: 18px !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
		background: transparent !important;
		list-style: none !important;
	}

	.lge-main-menu--mobile > li,
	.lge-main-menu--mobile .sub-menu li {
		width: 100%;
		margin: 0;
		padding: 0;
		list-style: none;
	}

	.lge-main-menu--mobile > li > a {
		display: flex !important;
		align-items: center !important;
		justify-content: flex-start !important;
		width: 100% !important;
		min-height: auto !important;
		padding: 0 !important;
		background: transparent !important;
		color: #ffffff !important;
		text-transform: uppercase !important;
		text-align: left !important;
		font-size: 15px !important;
		line-height: 1.2 !important;
		font-weight: 800 !important;
		letter-spacing: 0.9px !important;
		border-radius: 0 !important;
		box-shadow: none !important;
	}

	.lge-main-menu--mobile > li > a:hover,
	.lge-main-menu--mobile > li > a:focus,
	.lge-main-menu--mobile > li.current-menu-item > a,
	.lge-main-menu--mobile > li.current_page_item > a {
		background: transparent !important;
		color: #ffffff !important;
	}

	.lge-main-menu--mobile > li.menu-item-has-children > a::after {
		content: "";
		display: inline-block;
		width: 6px;
		height: 6px;
		margin-left: 8px !important;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		transform: rotate(45deg) translateY(-2px);
		transform-origin: center;
		line-height: 1;
		flex: 0 0 auto;
	}

	.lge-main-menu--mobile .sub-menu {
		position: static !important;
		display: none;
		width: 100%;
		min-width: 100%;
		margin: 10px 0 0 0;
		padding: 0;
		background: transparent !important;
		box-shadow: none !important;
		border-radius: 0;
	}

	.lge-main-menu--mobile > li:hover > .sub-menu,
	.lge-main-menu--mobile > li:focus-within > .sub-menu,
	.lge-main-menu--mobile > li.is-open > .sub-menu {
		display: block;
	}

	.lge-main-menu--mobile .sub-menu a,
	.lge-main-menu--mobile .sub-menu a:visited,
	.lge-main-menu--mobile .sub-menu a:hover,
	.lge-main-menu--mobile .sub-menu a:focus,
	.lge-main-menu--mobile .sub-menu a:active {
		display: block !important;
		width: 100% !important;
		padding: 8px 0 8px 18px !important;
		background: transparent !important;
		color: #ffffff !important;
		border: none !important;
		font-size: 13px !important;
		box-sizing: border-box !important;
		box-shadow: none !important;
	}
}

@media (max-width: 767px) {
	.lge-salle-fullbleed {
		margin-top: calc(-1 * var(--lge-header-clearance));
	}
	.lge-salle-hero__inner {
		padding: calc(var(--lge-header-clearance) + 18px) 0 24px;
	}


	.lge-salle-hero-wrap {
		padding: 0 0 18px;
		background: transparent;
	}

	.lge-salle-hero {
		min-height: 620px;
	}

	.lge-salle-hero__inner {
		padding: calc(var(--lge-header-clearance) + 110px) 0 24px;
	}
}

@media (max-width: 520px) {
	.lge-salle-hero-wrap {
		padding: 0 0 14px;
	}

	.lge-salle-hero__inner {
		padding: calc(var(--lge-header-clearance) + 110px) 0 20px;
	}
	
	.lge-header__container {
		padding-left: 12px;
		padding-right: 12px;
	}

	.lge-header__mobile-top .lge-header__container {
		min-height: 46px;
	}

	.lge-header__city--mobile .lge-city-toggle {
		height: 40px;
		min-height: 40px;
		padding: 0 36px 0 14px;
		font-size: 13px;
	}

	.lge-header__city--mobile .lge-city-dropdown {
		min-width: 165px;
	}

	.lge-header__branding--mobile {
		margin-top: -10px;
	}

	.lge-header__branding--mobile img,
	.lge-header__branding--mobile .custom-logo {
		width: 185px;
		max-width: 185px;
	}

	.lge-burger {
		width: 42px;
		height: 42px;
		margin-top: 0 !important;
	}

	.lge-burger span {
		width: 28px;
		height: 4px;
	}

	.lge-top-menu--mobile {
		gap: 16px;
	}

	.lge-top-menu--mobile a,
	.lge-top-menu--mobile a:visited,
	.lge-top-menu--mobile a:hover,
	.lge-top-menu--mobile a:focus,
	.lge-top-menu--mobile a:active {
		font-size: 11px;
	}

	.lge-header__main-nav--mobile {
		padding: 18px 14px 22px;
		border-radius: 14px;
	}

	.lge-main-menu--mobile {
		gap: 16px !important;
	}

	.lge-main-menu--mobile > li > a {
		font-size: 14px !important;
	}

	.lge-main-menu--mobile .sub-menu a,
	.lge-main-menu--mobile .sub-menu a:visited,
	.lge-main-menu--mobile .sub-menu a:hover,
	.lge-main-menu--mobile .sub-menu a:focus,
	.lge-main-menu--mobile .sub-menu a:active {
		font-size: 12px !important;
	}
}
/* =========================================================
   MENU ACF - CARTES SOUS-MENU
========================================================= */

.lge-main-menu,
.lge-main-menu .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.lge-main-menu > .menu-item {
	position: relative;
}

.lge-main-menu__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
}

/* =========================
   SOUS-MENU DESKTOP
========================= */

.lge-header__desktop .lge-main-menu > .menu-item > .lge-main-submenu {
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	z-index: 200;

	width: auto;
	min-width: 0;
	margin: 0;
	padding: 14px;

	display: grid !important;
	grid-template-columns: repeat(3, 150px);
	gap: 14px;
	justify-content: start;

	background: #ae8740;
	border-radius: 14px;
	overflow: visible;

	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
}

.lge-header__desktop .lge-main-menu > .menu-item:hover > .lge-main-submenu,
.lge-header__desktop .lge-main-menu > .menu-item:focus-within > .lge-main-submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.lge-header__desktop .lge-main-menu > .menu-item > .lge-main-submenu > li {
	margin: 0;
	padding: 0;
	min-width: 0;
	list-style: none;
}

/* =========================
   CARTE
========================= */

.lge-menu-card {
	display: flex !important;
	flex-direction: column;
	align-items: stretch;
	width: 150px;
	padding: 0 !important;
	text-decoration: none;
	border: 0 !important;
	border-radius: 0;
	box-shadow: none !important;
	background: transparent !important;
	overflow: visible;
}

.lge-main-menu .sub-menu .lge-menu-card,
.lge-main-menu .sub-menu .lge-menu-card:visited,
.lge-main-menu .sub-menu .lge-menu-card:hover,
.lge-main-menu .sub-menu .lge-menu-card:focus,
.lge-main-menu .sub-menu .lge-menu-card:active {
	display: flex !important;
	padding: 0 !important;
	background: transparent !important;
	color: #ffffff !important;
	border: none !important;
	text-decoration: none !important;
}

/* carré de fond */
.lge-menu-card__image {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	background-color: var(--lge-menu-card-bg, #1a1a1a);
	border-radius: 12px;
	flex: 0 0 auto;
}

/* zone titre sous le carré */
.lge-menu-card__content {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 8px 4px 0;
	text-align: center;
	background: transparent;
}

.lge-menu-card__title {
	display: block;
	width: 100%;
	color: #ffffff;
	font-size: 0.8rem;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

/* =========================
   MOBILE
========================= */

@media (max-width: 980px) {
	.lge-header__mobile .lge-main-menu > .menu-item > .lge-main-submenu {
		position: static !important;
		width: 100%;
		min-width: 0;
		margin: 0;
		padding: 10px 0 0;

		display: none !important;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;

		background: transparent !important;
		border-radius: 0;
		box-shadow: none !important;

		opacity: 0;
		visibility: hidden;
		transform: none;
	}

	.lge-header__mobile .lge-main-menu > .menu-item.is-open > .lge-main-submenu,
	.lge-header__mobile .lge-main-menu > .menu-item.open > .lge-main-submenu,
	.lge-header__mobile .lge-main-menu > .menu-item.submenu-open > .lge-main-submenu,
	.lge-header__mobile .lge-main-menu > .menu-item:focus-within > .lge-main-submenu,
	.lge-header__mobile .lge-main-menu > .menu-item > .lge-main-menu__link[aria-expanded="true"] + .lge-main-submenu {
		display: grid !important;
		opacity: 1;
		visibility: visible;
	}

	.lge-menu-card {
		width: 100%;
	}

	.lge-menu-card__image {
		width: 100%;
		aspect-ratio: 1 / 1;
		border-radius: 10px;
	}

	.lge-menu-card__content {
		padding: 7px 2px 0;
	}

	.lge-menu-card__title {
		font-size: 0.74rem;
		line-height: 1.15;
	}
}
:root {
    --lge-footer-gold: var(--lge-gold, #ae8740);
    --lge-footer-gold-dark: var(--lge-gold-dark, #8f6b2d);
    --lge-footer-cream: var(--lge-cream, #efe9df);
    --lge-footer-black: var(--lge-black, #050505);
    --lge-footer-white: var(--lge-white, #ffffff);
    --lge-footer-text: var(--lge-text, #111111);
}

.lge-footer {
    position: relative;
    overflow: hidden;
    color: var(--lge-footer-text);
    background: var(--lge-footer-black);
}

.lge-footer__top {
    position: relative;
    overflow: hidden;
    background: var(--lge-footer-cream);
    padding: 34px 0 38px;
}

.lge-footer__top::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 8px;
    background: linear-gradient(
        90deg,
        transparent 0,
        rgba(174, 135, 64, 0.95) 12%,
        rgba(174, 135, 64, 0.75) 88%,
        transparent 100%
    );
    opacity: 0.9;
}

.lge-footer__top::after {
    content: "";
    position: absolute;
    right: 40px;
    bottom: 22px;
    width: 260px;
    height: 220px;
    background: url(https://dev.la-grande-evasion.com/wp-content/uploads/2026/03/corbeau-footer@2x.webp) no-repeat center center;
    background-size: contain;
    opacity: 0.22;
    pointer-events: none;
}

.lge-footer__top-inner,
.lge-footer__bottom-inner,
.lge-footer__legal {
    width: min(1240px, calc(100% - 48px));
    margin: 0 auto;
}

.lge-footer__cities-line {
    display: none;
}

.lge-footer__cities-intro,
.lge-footer__cities-grid {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.lge-footer__cities-intro {
    display: block;
    margin-bottom: 22px;
    padding-left: 0;
}

.lge-footer__title {
    margin: 0;		 
    font-family: var(--font-headings, inherit);
    font-size: clamp(1.5rem, 2.4vw, 1.5rem);
    line-height: 1;
    letter-spacing: 0.08em;
	/* Modif par Ludo le 16/04/26 text-align: left; */
    text-align: center;
	/* Fin modif */
    text-transform: uppercase;
    color: var(--lge-footer-gold);
	/* Ajout par Ludo le 16/04/26 */
	margin-bottom: 40px;	
	/*Fin ajout */
}

.lge-footer__cities-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(3, minmax(170px, 240px));
    justify-content: start;
    gap: 70px;
    padding-left: 0;
    padding-right: 0;
}

.lge-footer__city {
    max-width: 240px;
}

.lge-footer__city-name {
    margin: 0 0 10px;
    font-family: var(--font-headings, inherit);
    font-size: clamp(1.1rem, 1.5vw, 1.5rem);
    line-height: 1;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #000;
}

.lge-footer__address {
    display: flex;
    flex-direction: column;
    gap: 1px;
    margin: 0 0 12px;
    font-style: normal;
    font-size: 0.9rem;
    line-height: 1.35;
    color: rgba(0, 0, 0, 0.9);
}

.lge-footer__phone {
    display: inline-block;
    margin: 0 0 12px;
    font-size: 0.92rem;
    font-weight: 700;
    color: #000;
    text-decoration: none;
}

.lge-footer__city-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.lge-footer__city-links a {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    width: fit-content;
    font-size: 0.92rem;
    line-height: 1.35;
    font-weight: 700;
    color: #000;
    text-decoration: none;
    transition: color 0.2s ease, transform 0.2s ease;
}

.lge-footer__city-links a:hover,
.lge-footer__phone:hover,
.lge-footer__legal a:hover {
    color: var(--lge-footer-gold-dark);
}

.lge-footer__city-links a:hover {
    transform: translateX(3px);
}

.lge-footer__city-links a .arrow,
.lge-footer__city-links a span:last-child {
    font-size: 0.95rem;
}

.lge-footer__arrow,
.lge-footer__social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.lge-footer__arrow svg,
.lge-footer__social-icon svg {
    display: block;
    width: 1em;
    height: 1em;
    fill: currentColor;
}

.lge-footer__bottom {
    position: relative;
    padding: 54px 0 24px;
    background: var(--lge-footer-black);
    color: var(--lge-footer-white);
    border-top: 1px solid rgba(174, 135, 64, 0.18);
}

.lge-footer__bottom::before {
    display: none;
}

.lge-footer__bottom-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 370px;
    gap: 54px;
    align-items: center;
}

.lge-footer__brand {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 34px;
    align-items: center;
}

.lge-footer__brand-mark {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
}

.lge-footer__brand-logo {
    display: inline-block;
    font-family: var(--font-headings, inherit);
    font-size: 3.2rem;
    line-height: 0.86;
    color: #fff;
}

.lge-footer__logo-image {
    display: block;
    width: 100%;
    max-width: 180px;
    height: auto;
    object-fit: contain;
}

.lge-footer__brand-text {
    max-width: 640px;
}

.lge-footer__city-name a {
    color: inherit;
    text-decoration: none;
}

.lge-footer__city-name a:hover {
    text-decoration: underline;
}

.lge-footer__brand-text p {
    margin: 0 0 16px;
    font-size: 1.02rem;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.96);
}

.lge-footer__brand-text p:first-child {
    margin-bottom: 14px;
    font-size: 1.14rem;
    font-weight: 700;
}

.lge-footer__brand-text p:last-child {
    margin-bottom: 0;
}

.lge-footer__socials {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lge-footer__social {
    display: grid;
    grid-template-columns: 54px 1fr;
    gap: 18px;
    align-items: center;
    min-height: 92px;
    padding: 18px 24px;
    background: var(--lge-footer-gold);
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease, background 0.2s ease;
}

.lge-footer__social:hover {
    background: var(--lge-footer-gold-dark);
    transform: translateY(-2px);
}

.lge-footer__social-icon {
    font-size: 2rem;
}

.lge-footer__social-text {
    font-family: var(--font-headings, inherit);
    font-size: 1.18rem;
    line-height: 1.12;
    letter-spacing: 0.05em;
}

.lge-footer__legal {
    margin-top: 26px;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.lge-footer__legal p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.72);
}

.lge-footer__legal a {
    color: inherit;
    text-decoration: none;
}

@media (max-width: 1080px) {
    .lge-footer__cities-grid {
        gap: 40px;
    }

    .lge-footer__bottom-inner {
        grid-template-columns: minmax(0, 1fr) 320px;
        gap: 32px;
    }

    .lge-footer__brand {
        gap: 24px;
    }
}

@media (max-width: 920px) {
    .lge-footer__top::after {
        right: 10px;
        bottom: 14px;
        width: 180px;
        height: 150px;
        opacity: 0.14;
    }

    .lge-footer__top-inner,
    .lge-footer__bottom-inner,
    .lge-footer__brand {
        display: block;
    }

    .lge-footer__cities-intro,
    .lge-footer__cities-grid {
        max-width: none;
    }

    .lge-footer__cities-grid {
        grid-template-columns: 1fr;
        gap: 30px;
        justify-content: stretch;
    }

    .lge-footer__city {
        max-width: none;
    }

    .lge-footer__brand-mark {
        justify-content: flex-start;
        margin-bottom: 18px;
    }

    .lge-footer__socials {
        max-width: 460px;
        margin-top: 28px;
    }
}

/* =========================
   Mobile : 2 villes + 1 dessous
========================= */
@media (max-width: 640px) {
	.lge-footer__top {
		padding: 20px 0 24px;
	}

	.lge-footer__cities-intro,
	.lge-footer__cities-grid {
		max-width: 100%;
	}

	.lge-footer__cities-intro {
		margin-bottom: 14px;
	}

	.lge-footer__title {
		font-size: 1.3rem;
		letter-spacing: 0.06em;
	}

	.lge-footer__cities-grid {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px 18px;
		margin: 0;
		padding: 0;
	}

	/* 3e ville en dessous sur toute la largeur */
	.lge-footer__city:nth-child(3) {
		grid-column: 1 / -1;
	}

	.lge-footer__city-name {
		font-size: 1rem;
		margin: 0 0 6px;
		line-height: 1.05;
	}

	.lge-footer__address {
		font-size: 0.78rem;
		line-height: 1.2;
		margin: 0 0 8px;
	}

	.lge-footer__phone {
		font-size: 0.8rem;
		line-height: 1.2;
		margin: 0 0 8px;
	}

	.lge-footer__city-links {
		gap: 2px;
	}

	.lge-footer__city-links a {
		font-size: 0.78rem;
		line-height: 1.2;
		gap: 6px;
	}

	.lge-footer__top::after {
		width: 110px;
		height: 90px;
		right: -6px;
		bottom: 8px;
		opacity: 0.1;
	}
}

/* =========================
   Mobile : partie noire + logo
========================= */
@media (max-width: 640px) {
	.lge-footer__bottom {
		padding: 28px 0 18px;
	}

	.lge-footer__bottom-inner {
		grid-template-columns: 1fr;
		gap: 22px;
		align-items: start;
	}

	.lge-footer__brand {
		grid-template-columns: 110px 1fr;
		gap: 16px;
		align-items: center;
	}

	.lge-footer__brand-mark {
		justify-content: flex-start;
	}

	.lge-footer__logo-image {
		max-width: 100px;
	}

	.lge-footer__brand-text p:first-child {
		font-size: 0.98rem;
		margin-bottom: 8px;
	}

	.lge-footer__brand-text p {
		font-size: 0.84rem;
		line-height: 1.45;
	}

	.lge-footer__socials {
		gap: 10px;
	}

	.lge-footer__social {
		grid-template-columns: 44px 1fr;
		min-height: 72px;
		padding: 12px 16px;
	}

	.lge-footer__social-text {
		font-size: 0.95rem;
		line-height: 1.1;
	}

	.lge-footer__legal {
		margin-top: 18px;
		padding-top: 10px;
	}

	.lge-footer__legal p {
		font-size: 0.78rem;
		line-height: 1.35;
	}
}