/* =========================================================
   DOMAINE DES EVIS - CSS FINAL ELEMENTOR
   Base conservée : modèle Elementor avec images, sliders et pictos
   Charte : Marcellus titres, Manrope textes, palette Domaine des Evis
   ========================================================= */



:root {
  --dde-white: #ffffff;
  --dde-ivory: #F8F4EA;
  --dde-brun: #8A7564;
  --dde-green: #859679;
  --dde-green-deep: #1f2d1e;
  --dde-lavender: #C8C1D4;
  --dde-blue: #AEB9C1;
  --dde-text: #22301f;
  --dde-muted: #6f675e;
  --dde-line: rgba(138, 117, 100, 0.24);
  --dde-title: "Marcellus", Georgia, serif;
  --dde-body: "Manrope", Arial, sans-serif;
}

html,
body {
  overflow-x: hidden !important;
  background: var(--dde-ivory) !important;
}

.dde-v6,
.dde-v6 * {
  box-sizing: border-box;
}

.dde-v6 {
  position: relative;
  font-family: var(--dde-body) !important;
  color: var(--dde-text);
  overflow: hidden;
}

.dde-v6 a {
  color: inherit;
  text-decoration: none;
}

.dde-v6 p,
.dde-v6 .elementor-widget-text-editor {
  font-family: var(--dde-body) !important;
  color: var(--dde-muted) !important;
  font-size: clamp(0.98rem, 1vw, 1.08rem) !important;
  line-height: 1.68 !important;
}

.dde-v6 .elementor-widget:not(:last-child),
.dde-v6 .elementor-element:not(:last-child) {
  margin-bottom: 0;
}

.dde-shell {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
}

.dde-section {
  position: relative;
  padding: clamp(74px, 8vw, 124px) 0 !important;
  overflow: hidden;
}

/* Typographies */
.dde-eyebrow .elementor-heading-title,
.section-eyebrow {
  display: inline-block;
  margin-bottom: 22px;
  color: var(--dde-brun) !important;
  font-family: var(--dde-body) !important;
  font-size: clamp(0.72rem, 0.82vw, 0.86rem) !important;
  font-weight: 800 !important;
  letter-spacing: 0.24em !important;
  word-spacing: 0.32em !important;
  line-height: 1.15 !important;
  text-transform: uppercase !important;
}

.dde-h2 .elementor-heading-title,
.signature h2 {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-weight: 400 !important;
  line-height: 1.02 !important;
  font-size: clamp(2.65rem, 4.4vw, 4.95rem) !important;
  letter-spacing: -0.045em !important;
  text-wrap: balance;
}

.dde-h3 .elementor-heading-title,
.dde-access-card h4.elementor-heading-title {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-weight: 400 !important;
  line-height: 1.06 !important;
  font-size: clamp(1.75rem, 2.35vw, 2.65rem) !important;
  letter-spacing: -0.03em !important;
}

/* Boutons */
.dde-v6 .elementor-widget-button .elementor-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 48px;
  padding: 14px 30px !important;
  border-radius: 999px !important;
  background: var(--dde-white) !important;
  color: var(--dde-green-deep) !important;
  border: 1px solid rgba(133, 150, 121, 0.38) !important;
  font-family: var(--dde-body) !important;
  font-size: 0.78rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.075em !important;
  text-transform: uppercase !important;
  white-space: nowrap;
  transition: transform 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}

.dde-v6 .elementor-widget-button .elementor-button:hover {
  transform: translateY(-2px);
  background: var(--dde-blue) !important;
  color: var(--dde-green-deep) !important;
  border-color: var(--dde-blue) !important;
}

.dde-leaf .elementor-button-text::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 15px;
  margin-left: 12px;
  background: var(--dde-green);
  border-radius: 80% 0 80% 0;
  transform: rotate(-34deg) translateY(2px);
}

/* Hero */
.dde-hero {
  width: 100vw !important;
  max-width: 100vw !important;
  min-height: 100vh !important;
  height: 100vh;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 0 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center;
  color: var(--dde-white) !important;
  background-color: var(--dde-green-deep) !important;
  background-size: cover !important;
  background-position: center !important;
  overflow: hidden;
}

.dde-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(16, 25, 15, 0.52) 0%, rgba(16, 25, 15, 0.15) 42%, rgba(16, 25, 15, 0.54) 100%),
    radial-gradient(circle at center, rgba(0, 0, 0, 0.02) 0 34%, rgba(0, 0, 0, 0.42) 100%);
  pointer-events: none;
}

.dde-hero > .elementor-element {
  position: relative;
  z-index: 2;
}

.dde-hero-content {
  width: min(980px, calc(100% - 38px)) !important;
  max-width: 980px !important;
  margin: auto !important;
  padding-top: clamp(70px, 8vw, 108px) !important;
  display: grid !important;
  justify-items: center !important;
}

.dde-hero-title .elementor-heading-title {
  font-family: var(--dde-title) !important;
  color: var(--dde-white) !important;
  font-size: clamp(2.85rem, 5vw, 5.8rem) !important;
  font-weight: 400 !important;
  letter-spacing: -0.045em !important;
  line-height: 0.98 !important;
  text-shadow: 0 4px 28px rgba(0, 0, 0, 0.42);
}

.dde-hero-title i {
  font-style: italic;
  font-family: inherit !important;
}

.dde-hero-text p {
  margin-top: 26px !important;
  max-width: 920px;
  color: rgba(255, 255, 255, 0.92) !important;
  font-size: clamp(1.08rem, 1.55vw, 1.34rem) !important;
  line-height: 1.55 !important;
  text-shadow: 0 3px 22px rgba(0, 0, 0, 0.42);
}

.dde-hero-cta {
  margin-top: 38px;
}

/* Intro */
.dde-intro,
.dde-spaces-intro,
.dde-space-block,
.dde-exteriors,
.dde-facilities,
.dde-pricing,
.dde-booking {
  background: var(--dde-ivory) !important;
}

.dde-space-block-alt,
.dde-projects,
.dde-map-section {
  background: var(--dde-white) !important;
}

.dde-intro-card {
  max-width: 980px !important;
  text-align: center !important;
}

.dde-intro-card p {
  max-width: 850px;
  margin: 24px auto 0 !important;
  font-size: clamp(1.05rem, 1.35vw, 1.22rem) !important;
}

.dde-intro-strong p {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-size: clamp(1.7rem, 2.6vw, 2.75rem) !important;
  font-weight: 400 !important;
  line-height: 1.12 !important;
  margin-top: 30px !important;
}

/* Aérien + arguments */
.dde-aerial {
  background: var(--dde-ivory) !important;
  padding: 0 !important;
}

.dde-aerial-img img {
  width: 100% !important;
  height: min(70vh, 700px) !important;
  min-height: 430px;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  filter: saturate(0.94) contrast(0.96);
}

.dde-key-grid {
  width: min(1180px, calc(100% - 48px)) !important;
  margin: -72px auto 0 !important;
  position: relative !important;
  z-index: 2;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0 !important;
  padding: 0 !important;
  background: var(--dde-lavender) !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
  isolation: isolate;
}

.dde-key-grid::before,
.dde-key-grid::after {
  content: "";
  position: absolute;
  top: 52px;
  bottom: 52px;
  width: 1px;
  background: rgba(255, 255, 255, 0.72);
  pointer-events: none;
  z-index: 4;
}

.dde-key-grid::before { left: 33.333%; }
.dde-key-grid::after { left: 66.666%; }

.dde-key-card {
  min-height: 0 !important;
  padding: clamp(40px, 4vw, 58px) clamp(30px, 4vw, 54px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
}

.dde-key-card .elementor-heading-title {
  font-size: clamp(1.9rem, 2.45vw, 2.75rem) !important;
}

.dde-key-card p,
.dde-key-card .elementor-widget-text-editor {
  margin-top: 18px !important;
  color: rgba(31, 45, 30, 0.82) !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
  max-width: 340px;
}

/* Espaces */
.dde-spaces-intro {
  text-align: center;
  padding: clamp(72px, 7vw, 108px) 0 clamp(38px, 4vw, 64px) !important;
}

.dde-spaces-intro .dde-h2 .elementor-heading-title {
  max-width: 940px !important;
  margin-inline: auto;
}

.dde-space-block {
  padding: clamp(48px, 5vw, 76px) 0 !important;
}

.dde-space-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr) !important;
  gap: clamp(34px, 6vw, 88px) !important;
  align-items: center !important;
  width: min(1180px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
}

.dde-space-layout.reverse {
  grid-template-columns: minmax(0, 1.22fr) minmax(0, 0.78fr) !important;
}

.dde-space-layout.reverse .dde-space-copy { order: 2; }
.dde-space-layout.reverse .dde-slider-col { order: 1; }

.dde-space-copy {
  max-width: 470px !important;
}

.dde-space-copy .dde-h2 .elementor-heading-title {
  font-size: clamp(2.55rem, 3.55vw, 4rem) !important;
  max-width: 520px !important;
  margin-inline: 0 !important;
}

.dde-space-copy p {
  margin-top: 20px !important;
  font-size: clamp(1.02rem, 1.18vw, 1.12rem) !important;
}

/* Sliders */
.dde-slider-col {
  background: var(--dde-ivory) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.dde-slider .swiper,
.dde-slider .elementor-image-carousel-wrapper,
.dde-slider .elementor-image-carousel,
.dde-slider .swiper-wrapper,
.dde-slider .swiper-slide {
  height: 520px !important;
  min-height: 520px !important;
}

.dde-slider img,
.dde-slider .swiper-slide-image {
  width: 100% !important;
  height: 520px !important;
  min-height: 520px !important;
  object-fit: cover !important;
  object-position: center !important;
  filter: saturate(0.96) contrast(0.96);
  display: block !important;
}

.dde-slider .elementor-swiper-button {
  width: 46px !important;
  height: 46px !important;
  border: 1px solid rgba(255, 255, 255, 0.64);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  color: var(--dde-green-deep) !important;
  display: grid !important;
  place-items: center !important;
}

.dde-slider .elementor-swiper-button svg {
  width: 17px !important;
  height: 17px !important;
  fill: currentColor !important;
}

.dde-slider .swiper-pagination {
  bottom: 14px !important;
}

.dde-slider .swiper-pagination-bullet {
  width: 8px !important;
  height: 8px !important;
  background: rgba(255, 255, 255, 0.58) !important;
  opacity: 1 !important;
}

.dde-slider .swiper-pagination-bullet-active {
  width: 24px !important;
  border-radius: 999px !important;
  background: var(--dde-white) !important;
}

/* Galerie espaces extérieurs */
.dde-exteriors .elementor-image-gallery {
  margin-top: clamp(40px, 5vw, 68px) !important;
}

.dde-exteriors .gallery {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

.dde-exteriors .gallery br {
  display: none !important;
}

.dde-exteriors .gallery-item {
  float: none !important;
  clear: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.dde-exteriors .gallery-icon,
.dde-exteriors .gallery-icon a {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
}

.dde-exteriors .gallery img {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: clamp(300px, 29vw, 480px) !important;
  object-fit: cover !important;
  object-position: center !important;
  border: 0 !important;
  filter: saturate(0.95) contrast(0.96);
}

/* Bloc signature HTML éventuel : masqué si l'ancien doublon existe encore */
.signature {
  display: none !important;
}

/* Accordéon usages */
.dde-accordion {
  max-width: 960px !important;
  margin: clamp(42px, 6vw, 72px) auto 0 !important;
  border-top: 1px solid rgba(138, 117, 100, 0.25) !important;
}

.dde-accordion .elementor-accordion-item {
  border: 0 !important;
  border-bottom: 1px solid rgba(138, 117, 100, 0.25) !important;
}

.dde-accordion .elementor-tab-title {
  padding: 24px 0 !important;
}

.dde-accordion .elementor-accordion-title {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-size: clamp(1.55rem, 2vw, 2.15rem) !important;
  line-height: 1.12 !important;
  font-weight: 400 !important;
}

.dde-accordion .elementor-tab-content {
  border: 0 !important;
  padding: 0 0 26px !important;
  color: var(--dde-muted) !important;
  font-family: var(--dde-body) !important;
  font-size: 1rem !important;
  line-height: 1.68 !important;
}

.dde-accordion .elementor-accordion-icon svg {
  width: 0.78em !important;
  height: 0.78em !important;
  fill: var(--dde-green) !important;
}

/* Juliette : section différente, plus éditoriale */
.dde-projects + .dde-inspiration {
  background: var(--dde-ivory) !important;
  color: var(--dde-green-deep) !important;
  text-align: left !important;
}

.dde-projects + .dde-inspiration .dde-shell {
  display: grid !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
  gap: clamp(34px, 6vw, 86px) !important;
  align-items: center !important;
}

.dde-projects + .dde-inspiration .dde-h3 {
  grid-column: 1;
  grid-row: 1 / span 3;
  align-self: stretch;
  display: flex;
  align-items: center;
  padding: clamp(34px, 4vw, 56px) !important;
  background: var(--dde-green-deep) !important;
}

.dde-projects + .dde-inspiration .dde-h3 .elementor-heading-title {
  color: var(--dde-white) !important;
  font-size: clamp(1.85rem, 2.8vw, 3.1rem) !important;
  line-height: 1.16 !important;
  letter-spacing: -0.03em !important;
  font-style: italic;
}

.dde-projects + .dde-inspiration .dde-eyebrow,
.dde-projects + .dde-inspiration .dde-h2,
.dde-projects + .dde-inspiration .elementor-widget-text-editor {
  grid-column: 2;
}

.dde-projects + .dde-inspiration .dde-h2 .elementor-heading-title {
  color: var(--dde-green-deep) !important;
  font-size: clamp(2.8rem, 4.1vw, 4.65rem) !important;
  max-width: 650px !important;
  margin-inline: 0 !important;
}

.dde-projects + .dde-inspiration p {
  color: var(--dde-muted) !important;
  max-width: 650px !important;
  margin-top: 20px !important;
}

/* Esprit du lieu : vrai bandeau vert, distinct de Juliette */
.dde-projects + .dde-inspiration + .dde-inspiration,
.dde-final {
  background: var(--dde-green) !important;
  color: var(--dde-white) !important;
  text-align: center !important;
}

.dde-projects + .dde-inspiration + .dde-inspiration .elementor-heading-title,
.dde-projects + .dde-inspiration + .dde-inspiration p,
.dde-final .elementor-heading-title,
.dde-final p {
  color: var(--dde-white) !important;
}

.dde-projects + .dde-inspiration + .dde-inspiration .dde-h2 .elementor-heading-title {
  max-width: 960px !important;
  margin-inline: auto !important;
  font-size: clamp(2.85rem, 4.7vw, 5rem) !important;
}

.dde-projects + .dde-inspiration + .dde-inspiration p {
  max-width: 820px !important;
  margin: 24px auto 0 !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

/* Facilités */
.dde-facility-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  margin-top: clamp(42px, 6vw, 72px) !important;
}

.dde-facility-card {
  min-height: 220px !important;
  padding: 36px 24px !important;
  border: 0 !important;
  background: var(--dde-white) !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  box-shadow: none !important;
  transition: background 0.22s ease, transform 0.22s ease;
}

.dde-facility-card:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.68) !important;
}

.dde-facility-card .elementor-image-box-wrapper {
  display: grid !important;
  justify-items: center !important;
  gap: 22px !important;
}

.dde-facility-card .elementor-image-box-img {
  margin: 0 !important;
}

.dde-facility-card img {
  width: 108px !important;
  height: 108px !important;
  object-fit: contain !important;
  margin: 0 auto !important;
  display: block !important;
  opacity: 0.96;
  transition: filter 0.22s ease, transform 0.22s ease;
}

.dde-facility-card:hover img {
  filter: brightness(0) saturate(100%) invert(14%) sepia(11%) saturate(1033%) hue-rotate(66deg) brightness(88%) contrast(90%);
  transform: translateY(-1px);
}

.dde-facility-card .elementor-image-box-title {
  color: var(--dde-green-deep) !important;
  font-family: var(--dde-body) !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  word-spacing: 0.16em !important;
  line-height: 1.3 !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

/* Bande points forts */
.dde-ticks {
  background: var(--dde-green) !important;
  padding: 28px 0 !important;
}

.dde-ticks .dde-shell {
  display: flex !important;
  justify-content: center;
  flex-wrap: wrap;
  gap: 18px 38px !important;
  text-align: center;
}

.dde-ticks p {
  color: var(--dde-white) !important;
  font-size: 0.9rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.18em !important;
  word-spacing: 0.2em !important;
  text-transform: uppercase !important;
}

/* Tarifs */
.dde-pricing .dde-shell {
  width: min(1360px, calc(100% - 96px)) !important;
  max-width: 1360px !important;
}

.dde-pricing-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  margin-top: clamp(42px, 6vw, 72px) !important;
  background: transparent !important;
  border: 0 !important;
}

.dde-price-card {
  min-height: 258px !important;
  padding: 34px 28px !important;
  background: var(--dde-white) !important;
  border: 0 !important;
  box-shadow: none !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  transition: background 0.22s ease, transform 0.22s ease;
}

.dde-price-card:hover {
  background: var(--dde-blue) !important;
  transform: translateY(-2px);
}

.dde-price-card .elementor-heading-title {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-size: clamp(1.52rem, 1.7vw, 2.1rem) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.032em !important;
  max-width: 260px;
  margin: 0 auto !important;
}

.dde-price-card p {
  color: var(--dde-muted) !important;
  font-size: 0.98rem !important;
  line-height: 1.58 !important;
  max-width: 270px;
  margin: 22px auto 0 !important;
}

/* Réservation */
.dde-steps-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  margin-top: clamp(42px, 6vw, 72px) !important;
  background: transparent !important;
  border: 0 !important;
}

.dde-step {
  min-height: 225px !important;
  padding: 36px 28px !important;
  display: grid !important;
  place-items: center !important;
  background: var(--dde-white) !important;
  border: 0 !important;
  text-align: center !important;
}

.dde-step-number .elementor-heading-title {
       font-family: 'Marcellus', serif!important;
    font-size: 54px!important;
      color: #859679 !important;
    line-height: 1!important;
    margin-bottom: 14px!important;
    opacity: 0.85!important;
}

.dde-step p {
  color: var(--dde-green-deep) !important;
  font-size: 1.05rem !important;
  line-height: 1.5 !important;
  margin-top: 24px !important;
  text-align: center !important;
}

/* Carte / accès */
.dde-map {
  margin-top: clamp(42px, 6vw, 72px) !important;
  border: 0 !important;
  background: var(--dde-ivory) !important;
  box-shadow: none !important;
  overflow: hidden;
}

.dde-map iframe {
  width: 100% !important;
  height: min(56vw, 560px) !important;
  min-height: 360px !important;
  filter: saturate(0.82) contrast(0.92);
}

.dde-access-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0 !important;
  background: var(--dde-white) !important;
  border: 0 !important;
}

.dde-access-card {
  position: relative !important;
  padding: 36px 28px !important;
  background: var(--dde-white) !important;
  text-align: center !important;
}

.dde-access-card:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 24%;
  right: 0;
  bottom: 24%;
  width: 1px;
  background: var(--dde-line);
}

.dde-access-card .elementor-heading-title,
.dde-access-card p {
  text-align: center !important;
  margin-inline: auto !important;
}

.dde-access-card .elementor-heading-title {
  font-size: clamp(1.35rem, 1.7vw, 1.9rem) !important;
}

/* CTA final */
.dde-final {
  padding: clamp(78px, 8vw, 126px) 0 !important;
}

.dde-final .dde-h2 .elementor-heading-title {
  max-width: 980px !important;
  margin-inline: auto !important;
}

.dde-final .elementor-widget-button {
  margin-top: 34px;
}

/* Responsive */
@media (max-width: 1180px) {
  .dde-facility-grid,
  .dde-pricing-grid,
  .dde-steps-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .dde-exteriors .gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 940px) {
  .dde-space-layout,
  .dde-space-layout.reverse,
  .dde-projects + .dde-inspiration .dde-shell {
    grid-template-columns: 1fr !important;
  }

  .dde-space-layout.reverse .dde-space-copy,
  .dde-space-layout.reverse .dde-slider-col {
    order: initial;
  }

  .dde-space-copy {
    max-width: none !important;
  }

  .dde-space-copy .dde-h2 .elementor-heading-title {
    max-width: 760px !important;
  }

  .dde-key-grid,
  .dde-access-grid {
    grid-template-columns: 1fr !important;
  }

  .dde-key-grid {
    margin-top: 0 !important;
    width: 100% !important;
  }

  .dde-key-grid::before,
  .dde-key-grid::after {
    display: none !important;
  }

  .dde-key-card:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.65) !important;
  }

  .dde-slider .swiper,
  .dde-slider .elementor-image-carousel-wrapper,
  .dde-slider .elementor-image-carousel,
  .dde-slider .swiper-wrapper,
  .dde-slider .swiper-slide,
  .dde-slider img,
  .dde-slider .swiper-slide-image {
    height: 450px !important;
    min-height: 450px !important;
  }

  .dde-projects + .dde-inspiration .dde-h3,
  .dde-projects + .dde-inspiration .dde-eyebrow,
  .dde-projects + .dde-inspiration .dde-h2,
  .dde-projects + .dde-inspiration .elementor-widget-text-editor {
    grid-column: auto;
    grid-row: auto;
  }

  .dde-access-card:not(:last-child)::after {
    top: auto;
    right: 18%;
    bottom: 0;
    left: 18%;
    width: auto;
    height: 1px;
  }
}

@media (max-width: 760px) {
  .dde-shell,
  .dde-space-layout,
  .dde-pricing .dde-shell {
    width: calc(100% - 34px) !important;
  }

  .dde-hero {
    min-height: 700px !important;
    height: auto;
    padding: 175px 17px 94px !important;
  }

  .dde-hero-content {
    width: 100% !important;
    padding-top: 0 !important;
  }

  .dde-hero-title .elementor-heading-title {
    font-size: clamp(2.45rem, 12vw, 3.55rem) !important;
  }

  .dde-hero-text br {
    display: none;
  }

  .dde-section {
    padding: 64px 0 !important;
  }

  .dde-section-head,
  .dde-spaces-intro,
  .dde-intro-card,
  .dde-projects + .dde-inspiration,
  .dde-projects + .dde-inspiration + .dde-inspiration,
  .dde-final {
    text-align: left !important;
  }

  .dde-h2 .elementor-heading-title,
  .dde-spaces-intro .dde-h2 .elementor-heading-title,
  .dde-space-copy .dde-h2 .elementor-heading-title,
  .dde-projects + .dde-inspiration .dde-h2 .elementor-heading-title,
  .dde-projects + .dde-inspiration + .dde-inspiration .dde-h2 .elementor-heading-title {
    font-size: clamp(2.25rem, 11.2vw, 3.25rem) !important;
    line-height: 1.04 !important;
  }

  .dde-facility-grid,
  .dde-pricing-grid,
  .dde-steps-grid,
  .dde-exteriors .gallery {
    grid-template-columns: 1fr !important;
  }

  .dde-slider .swiper,
  .dde-slider .elementor-image-carousel-wrapper,
  .dde-slider .elementor-image-carousel,
  .dde-slider .swiper-wrapper,
  .dde-slider .swiper-slide,
  .dde-slider img,
  .dde-slider .swiper-slide-image {
    height: 360px !important;
    min-height: 360px !important;
  }

  .dde-exteriors .gallery img {
    height: 330px !important;
  }

  .dde-facility-card,
  .dde-price-card,
  .dde-step {
    min-height: auto !important;
  }

  .dde-projects + .dde-inspiration .dde-h3 {
    padding: 30px !important;
  }

  .dde-ticks .dde-shell {
    justify-content: flex-start;
    text-align: left;
  }

  .dde-map iframe {
    height: 380px !important;
  }

  .dde-final .elementor-button {
    width: 100% !important;
  }
}


/* =========================================================
   Domaine des Evis - thème custom WordPress + ACF
   ========================================================= */
body.dde-site { margin:0; background:var(--dde-ivory); color:var(--dde-text); font-family:var(--dde-body); }
body.dde-site.admin-bar .dde-site-head { top:32px; }
.dde-site-main { overflow:hidden; }
.dde-site-head{position:fixed;top:0;left:0;right:0;z-index:999;background:transparent;transition:background .25s ease, box-shadow .25s ease;}
.dde-head-inner{width:min(1280px,calc(100% - 48px));margin:0 auto;display:grid;grid-template-columns:13% 1fr auto;align-items:center;gap:28px;padding:22px 0;}
.dde-brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:var(--dde-title);font-size:0;}
.dde-brand img{display:block;width:100%;max-width:138px;height:auto;object-fit:contain;}
.dde-menu{display:flex;justify-content:flex-end;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.dde-menu a{font-family:var(--dde-body);font-size:14px;font-weight:700;text-transform:uppercase;color:#fff;letter-spacing:.04em;transition:color .2s ease;}
.dde-menu a:hover{color:var(--dde-green);}
.dde-header-cta{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:15px 20px;background:var(--dde-green);color:#fff;font-family:var(--dde-body);font-size:14px;font-weight:700;text-transform:uppercase;white-space:nowrap;transition:background .2s ease;}
.dde-header-cta:hover{background:#000;color:#fff;}
.dde-menu-toggle{display:none;width:44px;height:42px;border:1px solid rgba(255,255,255,.62);background:rgba(255,255,255,.08);color:#fff;border-radius:0;align-items:center;justify-content:center;cursor:pointer;}
.dde-menu-toggle span,.dde-menu-toggle span:before,.dde-menu-toggle span:after{display:block;width:20px;height:1px;background:currentColor;content:"";position:relative;}
.dde-menu-toggle span:before{position:absolute;top:-7px;left:0}.dde-menu-toggle span:after{position:absolute;top:7px;left:0}
.dde-mobile-panel{display:none;}
.dde-site-head.is-scrolled{background:#ffffff;box-shadow:0 1px 0 var(--dde-line),0 18px 45px -35px rgba(31,45,30,.4);}
.dde-site-head.is-scrolled .dde-brand,.dde-site-head.is-scrolled .dde-menu a{color:var(--dde-green-deep);}
.dde-site-head.is-scrolled .dde-head-inner{padding:14px 0;}
.dde-site-head.is-scrolled .dde-menu-toggle{color:var(--dde-green-deep);border-color:var(--dde-line);background:transparent;}
.dde-page .elementor-heading-title{margin:0;}
.dde-page .elementor-widget-text-editor p:first-child{margin-top:0;}
.dde-page .elementor-widget-text-editor p:last-child{margin-bottom:0;}
.dde-hero{margin-top:0!important;}
.dde-section-head{text-align:center;max-width:960px;margin:0 auto;}
.dde-section-head .elementor-widget-text-editor{max-width:850px;margin:24px auto 0!important;}
.dde-slider .swiper{position:relative;overflow:hidden;height:520px;min-height:520px;}
.dde-slider .swiper-wrapper{height:100%;display:flex;transition:transform .45s ease;}
.dde-slider .swiper-slide{min-width:100%;height:100%;}
.dde-slider .swiper-slide img{width:100%;height:100%;object-fit:cover;display:block;}
.dde-slider .elementor-swiper-button{position:absolute;top:50%;transform:translateY(-50%);z-index:4;border:0;cursor:pointer;}
.dde-slider .elementor-swiper-button-prev{left:18px;}.dde-slider .elementor-swiper-button-next{right:18px;}
.dde-slider .swiper-pagination{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:7px;z-index:4;}
.dde-slider .swiper-pagination-bullet{display:block;}
.dde-space-copy .space-note{margin-top:18px;font-weight:800;color:var(--dde-green-deep)!important;}
.dde-key-card .elementor-widget-text-editor{margin-top:18px!important;}
.dde-exteriors .gallery{list-style:none;}
.dde-exteriors .gallery-item{list-style:none;}
.dde-accordion details{display:block;}
.dde-accordion summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;gap:24px;}
.dde-accordion summary::-webkit-details-marker{display:none;}
.dde-accordion summary::after{content:"+";font-family:var(--dde-body);font-weight:700;color:var(--dde-green);}
.dde-accordion details[open] summary::after{content:"−";}
.dde-pricing-grid,.dde-steps-grid,.dde-facility-grid{align-items:stretch;}
.dde-facility-card a{display:grid;justify-items:center;color:inherit;}
.dde-facility-card .elementor-image-box-content{display:grid;gap:0;}
.dde-ticks .elementor-widget-text-editor p{margin:0!important;}
.dde-hostess{background:var(--dde-ivory)!important;}
.dde-hostess-shell{display:grid!important;grid-template-columns:.85fr 1.15fr;gap:clamp(38px,6vw,86px);align-items:center;}
.dde-hostess-media img{width:100%;height:560px;object-fit:cover;display:block;filter:saturate(.96) contrast(.96);}
.dde-hostess-copy .dde-hostess-quote p{font-family:var(--dde-title)!important;font-size:clamp(1.45rem,2.3vw,2.35rem)!important;line-height:1.18!important;color:var(--dde-green-deep)!important;margin:24px 0!important;}
.dde-tarif-html{margin-top:42px;}
.dde-tarif-html table{width:100%;border-collapse:collapse;background:#fff;}
.dde-tarif-html td,.dde-tarif-html th{border:1px solid var(--dde-line);padding:18px;text-align:left;}
.dde-tarif-html th{background:var(--dde-green);color:#fff;font-family:var(--dde-body);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;}
.dde-final .elementor-widget-button{margin-top:34px;}
.dde-site-footer{background:var(--dde-green);color:#fff;}
.dde-footer-main{width:min(1280px,calc(100% - 48px));margin:0 auto;padding:100px 0 110px;display:grid;grid-template-columns:repeat(4,1fr);gap:56px;}
.dde-footer-logo img{width: min(210px,80%);height:auto;display:block;}
.dde-footer-col{font-family:var(--dde-body);color:#fff;font-size:16px;line-height:1.65;}
.dde-footer-col a{color:#fff;text-decoration:none;display:block;margin-bottom:14px;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;}
.dde-footer-bottom{background:var(--dde-ivory);color:var(--dde-green);font-weight:800;font-family:var(--dde-body);}
.dde-footer-bottom-inner{width:min(1280px,calc(100% - 48px));margin:0 auto;display:grid;grid-template-columns:1fr 2fr 1fr;gap:24px;align-items:center;padding:18px 0;font-size:14px;}
.dde-footer-bottom-inner span:nth-child(2){text-align:center}.dde-footer-bottom-inner span:nth-child(3){text-align:right}
.dde-placeholder{padding:180px 0 90px;background:var(--dde-ivory);}
.dde-placeholder .dde-shell{max-width:760px!important;}
.dde-placeholder h1{font-family:var(--dde-title);font-size:clamp(2.6rem,5vw,5rem);color:var(--dde-green-deep);line-height:1.05;margin:0 0 22px;}
@media(max-width:980px){body.dde-site.admin-bar .dde-site-head{top:46px}.dde-head-inner{grid-template-columns:1fr auto; width:calc(100% - 34px); padding:16px 0}.dde-brand img{max-width:104px}.dde-menu,.dde-header-cta{display:none}.dde-menu-toggle{display:flex}.dde-mobile-panel{position:fixed;top:84px;left:17px;right:17px;background:var(--dde-ivory);border:1px solid var(--dde-line);box-shadow:0 22px 58px -32px rgba(31,45,30,.55);padding:20px;z-index:998}.admin-bar .dde-mobile-panel{top:130px}.dde-mobile-panel.is-open{display:block}.dde-mobile-panel ul{display:grid;gap:14px;list-style:none;margin:0 0 18px;padding:0}.dde-mobile-panel a{color:var(--dde-green-deep);font-family:var(--dde-body);font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:.1em}.dde-mobile-panel .dde-mobile-cta{display:flex;justify-content:center;background:var(--dde-green);color:#fff;border-radius:999px;padding:13px 18px}.dde-site-head.is-scrolled .dde-brand img{max-width:96px}.dde-hostess-shell{grid-template-columns:1fr!important}.dde-hostess-media{order:-1}.dde-hostess-media img{height:420px}.dde-footer-main{grid-template-columns:1fr;gap:36px;padding:72px 0}.dde-footer-bottom-inner{grid-template-columns:1fr;text-align:left}.dde-footer-bottom-inner span:nth-child(2),.dde-footer-bottom-inner span:nth-child(3){text-align:left}}
@media(max-width:760px){.dde-site-head:not(.is-scrolled){background:linear-gradient(to bottom,rgba(31,45,30,.42),rgba(31,45,30,0));}.dde-brand img{max-width:92px}.dde-hero{min-height:700px!important;height:auto!important;padding-top:175px!important}.dde-hero-content{padding-top:0!important}.dde-key-grid{width:100%!important}.dde-slider .swiper{height:360px;min-height:360px}.dde-hostess-media img{height:360px}.dde-footer-main,.dde-footer-bottom-inner{width:calc(100% - 34px)}}

/* =========================================================
   Correctifs v0.2 - fidélité Elementor / retours QA
   ========================================================= */

/* Hero : le voile doit rester derrière le texte, jamais au-dessus. */
.dde-hero {
  position: relative !important;
  isolation: isolate;
}
.dde-hero::before {
  z-index: 0 !important;
  background:
    linear-gradient(180deg, rgba(16,25,15,.34) 0%, rgba(16,25,15,.08) 42%, rgba(16,25,15,.38) 100%),
    radial-gradient(circle at center, rgba(0,0,0,0) 0 34%, rgba(0,0,0,.28) 100%) !important;
}
.dde-hero-content {
  position: relative !important;
  z-index: 2 !important;
}
.dde-hero-title,
.dde-hero-text,
.dde-hero-cta {
  position: relative !important;
  z-index: 3 !important;
}

/* Les images doivent reprendre le rendu source, sans filtre global ajouté par erreur. */
.dde-aerial-img img,
.dde-slider img,
.dde-slider .swiper-slide-image,
.dde-exteriors .gallery img,
.dde-map iframe {
  filter: none !important;
}

/* Alternance gauche/droite : sécurisation, même si d'anciens styles Elementor restent en cache. */
.dde-space-layout.reverse .dde-space-copy {
  order: 2 !important;
}
.dde-space-layout.reverse .dde-slider-col {
  order: 1 !important;
}
.dde-space-layout:not(.reverse) .dde-space-copy {
  order: 1 !important;
}
.dde-space-layout:not(.reverse) .dde-slider-col {
  order: 2 !important;
}

/* Slider custom : même comportement visuel qu'un carousel Elementor basique. */
.dde-slider .swiper {
  position: relative !important;
  overflow: hidden !important;
}
.dde-slider .swiper-wrapper {
  display: flex !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform .55s ease !important;
  will-change: transform;
}
.dde-slider .swiper-slide {
  flex: 0 0 100% !important;
  width: 100% !important;
  min-width: 100% !important;
}
.dde-slider .elementor-swiper-button {
  font-size: 0 !important;
  line-height: 0 !important;
}
.dde-slider .elementor-swiper-button::before {
  font-size: 26px;
  line-height: 1;
  color: var(--dde-green-deep);
}
.dde-slider .elementor-swiper-button-prev::before { content: "‹"; }
.dde-slider .elementor-swiper-button-next::before { content: "›"; }

/* Footer : reprise plus fidèle de l'export Elementor. */
.dde-site-footer {
  background: var(--dde-green) !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
}
.dde-footer-main {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 100px max(40px, calc((100vw - 1280px) / 2)) 120px !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  align-items: start !important;
  background: var(--dde-green) !important;
}
.dde-footer-logo,
.dde-footer-col {
  padding: 0 28px !important;
}
.dde-footer-logo img {
  width: min(190px, 60%) !important;
  max-width: 190px !important;
  height: auto !important;
  margin: 0 auto !important;
  display: block !important;
}
.dde-footer-col {
  color: #fff !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  font-weight: 400 !important;
}
.dde-footer-col p {
  color: #fff !important;
  margin: 0 !important;
}
.dde-footer-col a {
  display: block !important;
  color: #fff !important;
  text-decoration: none !important;
  margin: 0 0 14px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}
.dde-footer-bottom {
  display: block !important;
  background: var(--dde-ivory) !important;
  color: var(--dde-green) !important;
}
.dde-footer-bottom-inner {
  width: min(1280px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  padding: 18px 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 2fr 1fr !important;
  align-items: center !important;
  gap: 20px !important;
  font-family: var(--dde-body) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

@media (max-width: 980px) {
  .dde-space-layout.reverse .dde-space-copy,
  .dde-space-layout.reverse .dde-slider-col,
  .dde-space-layout:not(.reverse) .dde-space-copy,
  .dde-space-layout:not(.reverse) .dde-slider-col {
    order: initial !important;
  }
  .dde-footer-main {
    grid-template-columns: 1fr !important;
    padding: 72px 26px !important;
    gap: 42px !important;
  }
  .dde-footer-logo,
  .dde-footer-col {
    padding: 0 !important;
  }
  .dde-footer-logo img {
    margin: 0 !important;
    width: min(180px, 60%) !important;
  }
  .dde-footer-bottom-inner {
    grid-template-columns: 1fr !important;
    width: calc(100% - 52px) !important;
    text-align: left !important;
  }
  .dde-footer-bottom-inner span:nth-child(2),
  .dde-footer-bottom-inner span:nth-child(3) {
    text-align: left !important;
  }
}

/* =========================================================
   Correctifs v0.3 - conformité exports Elementor DDE
   ========================================================= */

/* Galerie accueil : reprendre le rendu Elementor masonry, pas une grille carrée. */
.dde-page-home .dde-exteriors .elementor-image-gallery {
  margin-top: clamp(44px, 6vw, 74px) !important;
}
.dde-page-home .dde-exteriors .gallery {
  display: block !important;
  column-count: 3 !important;
  column-gap: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  list-style: none !important;
}
.dde-page-home .dde-exteriors .gallery br { display: none !important; }
.dde-page-home .dde-exteriors .gallery-item {
  display: block !important;
  float: none !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 0 28px !important;
  padding: 0 !important;
  break-inside: avoid !important;
  page-break-inside: avoid !important;
}
.dde-page-home .dde-exteriors .gallery-icon,
.dde-page-home .dde-exteriors .gallery-icon a {
  display: block !important;
  width: 100% !important;
  height: auto !important;
}
.dde-page-home .dde-exteriors .gallery img {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  border: 0 !important;
  object-fit: cover !important;
}
@media (max-width: 1180px) {
  .dde-page-home .dde-exteriors .gallery { column-count: 2 !important; }
}
@media (max-width: 760px) {
  .dde-page-home .dde-exteriors .gallery { column-count: 1 !important; }
  .dde-page-home .dde-exteriors .gallery img { height: auto !important; }
}

/* Inspiration accueil : l'export Elementor est un vrai bandeau vert centré, pas le bloc éditorial Juliette. */
.dde-page-home .dde-projects + .dde-inspiration,
.dde-page-home .dde-inspiration {
  background: var(--dde-green) !important;
  color: var(--dde-white) !important;
  text-align: center !important;
  padding-top: clamp(86px, 8vw, 132px) !important;
  padding-bottom: clamp(86px, 8vw, 132px) !important;
}
.dde-page-home .dde-inspiration .dde-shell,
.dde-page-home .dde-projects + .dde-inspiration .dde-shell {
  display: block !important;
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
}
.dde-page-home .dde-inspiration .elementor-heading-title,
.dde-page-home .dde-inspiration p,
.dde-page-home .dde-inspiration .elementor-widget-text-editor,
.dde-page-home .dde-projects + .dde-inspiration .elementor-heading-title,
.dde-page-home .dde-projects + .dde-inspiration p,
.dde-page-home .dde-projects + .dde-inspiration .elementor-widget-text-editor {
  color: var(--dde-white) !important;
}
.dde-page-home .dde-inspiration .dde-h2 .elementor-heading-title,
.dde-page-home .dde-projects + .dde-inspiration .dde-h2 .elementor-heading-title {
  max-width: 920px !important;
  margin-inline: auto !important;
  font-size: clamp(3rem, 4.35vw, 5rem) !important;
}
.dde-page-home .dde-inspiration .elementor-widget-text-editor,
.dde-page-home .dde-projects + .dde-inspiration .elementor-widget-text-editor {
  max-width: 830px !important;
  margin: 24px auto 0 !important;
}
.dde-page-home .dde-inspiration .elementor-widget-text-editor p,
.dde-page-home .dde-projects + .dde-inspiration .elementor-widget-text-editor p {
  color: rgba(255, 255, 255, 0.9) !important;
  margin: 0 !important;
}
@media (max-width: 760px) {
  .dde-page-home .dde-inspiration,
  .dde-page-home .dde-projects + .dde-inspiration { text-align: center !important; }
}

/* Tarifs accueil : tailles et équilibre de l'export Elementor, sans réécriture de contenu. */
.dde-page-home .dde-pricing .dde-shell {
  width: min(1360px, calc(100% - 96px)) !important;
  max-width: 1360px !important;
}
.dde-page-home .dde-price-card,
.dde-page-home .dde-price-card:nth-child(even) {
  min-height: 270px !important;
  padding: 40px 30px !important;
  background: var(--dde-white) !important;
  border: 0 !important;
  box-shadow: none !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}
.dde-page-home .dde-price-card .elementor-heading-title {
  max-width: 290px !important;
  margin: 0 auto !important;
  font-size: clamp(1.85rem, 2vw, 2.65rem) !important;
  line-height: 1.08 !important;
}
.dde-page-home .dde-price-card p,
.dde-page-home .dde-price-card .elementor-widget-text-editor {
  max-width: 280px !important;
  margin: 24px auto 0 !important;
  color: var(--dde-muted) !important;
  font-size: 1.02rem !important;
  line-height: 1.6 !important;
}

/* Formules mariage : CSS dédié au HTML Elementor conservé dans le champ ACF. */
.dde-page-mariage .dde-wedding-pricing {
  margin-top: clamp(42px, 6vw, 72px) !important;
}
.dde-page-mariage .dde-wedding-pricing__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}
.dde-page-mariage .dde-wedding-card {
  position: relative !important;
  background: var(--dde-white) !important;
  border: 0 !important;
  min-height: 520px !important;
  padding: 40px 34px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: stretch !important;
  box-shadow: none !important;
}
.dde-page-mariage .dde-wedding-card--featured {
  background: var(--dde-lavender) !important;
}
.dde-page-mariage .dde-wedding-card__badge {
  position: absolute !important;
  top: 22px !important;
  right: 22px !important;
  background: var(--dde-green-deep) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 7px 13px !important;
  font: 800 11px/1 var(--dde-body) !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}
.dde-page-mariage .dde-wedding-card__kicker,
.dde-page-mariage .dde-wedding-card__note {
  font-family: var(--dde-body) !important;
  color: var(--dde-brun) !important;
  font-size: 0.78rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}
.dde-page-mariage .dde-wedding-card h3 {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-weight: 400 !important;
  font-size: clamp(2rem, 2.4vw, 2.8rem) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.035em !important;
  margin: 16px 0 22px !important;
}
.dde-page-mariage .dde-wedding-card ul {
  margin: 26px 0 32px !important;
  padding-left: 18px !important;
  color: var(--dde-muted) !important;
  line-height: 1.65 !important;
}
.dde-page-mariage .dde-wedding-card li { margin: 8px 0 !important; }
.dde-page-mariage .dde-wedding-card__button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: auto !important;
  min-height: 48px !important;
  padding: 14px 26px !important;
  border-radius: 999px !important;
  background: var(--dde-green-deep) !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  letter-spacing: .075em !important;
  text-transform: uppercase !important;
}
@media (max-width: 980px) {
  .dde-page-mariage .dde-wedding-pricing__grid { grid-template-columns: 1fr !important; }
  .dde-page-mariage .dde-wedding-card { min-height: auto !important; }
}

/* Footer : structure et espacements calés sur l'export Elementor. */
.dde-site-footer .dde-footer-main {
  background: #859678 !important;
  padding-top: 100px !important;
  padding-bottom: 120px !important;
}
.dde-site-footer .dde-footer-logo img {
  width: 50% !important;
  max-width: 210px !important;
  min-width: 120px !important;
}
.dde-footer-address p,
.dde-footer-address {
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-weight: 400 !important;
}
.dde-footer-bottom {
  background: var(--dde-ivory) !important;
  color: #859678 !important;
}
@media (max-width: 980px) {
  .dde-site-footer .dde-footer-main { padding-top: 72px !important; padding-bottom: 72px !important; }
  .dde-site-footer .dde-footer-logo img { width: 60% !important; margin: 0 !important; }
  .dde-footer-bottom { display: none !important; }
}


/* =========================================================
   Correctifs v0.4 - Footer Elementor exact + RankMath + images locales
   ========================================================= */

/* Footer : on annule les anciens patchs contradictoires et on recolle la structure Elementor. */
.dde-site-footer,
.dde-site-footer * {
  box-sizing: border-box !important;
}
.dde-site-footer {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
  overflow: hidden !important;
}
.dde-footer-top {
  width: 100% !important;
  background: #859678 !important;
  padding: 100px 0 120px !important;
}
.dde-footer-inner {
  width: min(1280px, calc(100% - 48px)) !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  align-items: start !important;
}
.dde-footer-cell {
  min-width: 0 !important;
  padding: 0 28px !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
}
.dde-footer-logo {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
}
.dde-footer-logo img {
  display: block !important;
  width: 50% !important;
  max-width: 210px !important;
  min-width: 120px !important;
  height: auto !important;
  margin: 0 auto !important;
}
.dde-footer-icon-line {
  display: grid !important;
  grid-template-columns: 20px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: start !important;
  padding-top: 8px !important;
}
.dde-footer-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-size: 20px !important;
  line-height: 1 !important;
  margin-top: 4px !important;
}
.dde-footer-address,
.dde-footer-address p {
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.62 !important;
  margin: 0 !important;
}
.dde-footer-actions,
.dde-footer-links {
  padding-top: 8px !important;
}
.dde-footer-actions a,
.dde-footer-links a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-family: var(--dde-body) !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
  font-weight: 500 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}
.dde-footer-actions a span {
  width: 14px !important;
  flex: 0 0 14px !important;
  text-align: center !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}
.dde-footer-bottom {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: var(--dde-ivory) !important;
  color: #859678 !important;
  font-family: var(--dde-body) !important;
}
.dde-footer-bottom-inner {
  width: min(1280px, calc(100% - 48px)) !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 18px 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 2fr 1fr !important;
  gap: 20px !important;
  align-items: center !important;
  color: #859678 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
}
.dde-footer-bottom-inner span:nth-child(1) { text-align: center !important; }
.dde-footer-bottom-inner span:nth-child(2) { text-align: center !important; }
.dde-footer-bottom-inner span:nth-child(3) { text-align: right !important; }

/* Prix accueil : le 4e bloc doit bien être Table d’hôte, pas Option Régie Gourmande. */
.dde-page-home .dde-pricing-grid .dde-price-card:nth-child(4) .elementor-heading-title::after {
  content: none !important;
}
.dde-page-home .dde-pricing-grid .dde-price-card:nth-child(4) .elementor-heading-title {
  font-size: clamp(1.85rem, 2vw, 2.65rem) !important;
  line-height: 1.08 !important;
}

@media (max-width: 980px) {
  .dde-footer-top {
    padding: 72px 0 !important;
  }
  .dde-footer-inner {
    width: calc(100% - 52px) !important;
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }
  .dde-footer-cell {
    padding: 0 !important;
  }
  .dde-footer-logo {
    justify-content: flex-start !important;
  }
  .dde-footer-logo img {
    width: 60% !important;
    max-width: 180px !important;
    min-width: 110px !important;
    margin: 0 !important;
  }
  .dde-footer-bottom {
    display: none !important;
  }
}


/* =========================================================
   Correctifs v0.5 - header/footer/images/cartes
   ========================================================= */

/* Header : aucun soulignement parasite sur le menu ou le CTA */
.dde-site-head a,
.dde-site-head a:visited,
.dde-site-head a:hover,
.dde-site-head a:focus,
.dde-mobile-panel a,
.dde-mobile-panel a:visited,
.dde-mobile-panel a:hover,
.dde-mobile-panel a:focus {
  text-decoration: none !important;
}
.dde-menu a::before,
.dde-menu a::after,
.dde-mobile-menu a::before,
.dde-mobile-menu a::after {
  content: none !important;
  display: none !important;
}

/* Logo header/footer : si l'image n'est pas encore uploadée, le texte fallback reste propre. */
.dde-brand-fallback,
.dde-footer-logo-fallback {
  display: none;
  font-family: var(--dde-body) !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  line-height: 1.15 !important;
}
.dde-brand-fallback { color: var(--dde-white); font-size: 14px; }
.dde-site-head.is-scrolled .dde-brand-fallback { color: var(--dde-green-deep); }
.dde-footer-logo-fallback { color: #fff; font-size: 18px; }
.dde-brand img[src=""],
.dde-footer-logo img[src=""] { display:none !important; }

/* Footer : remise à plat complète, sans anciennes règles contradictoires. */
.dde-site-footer,
.dde-site-footer * {
  box-sizing: border-box !important;
}
.dde-site-footer {
  clear: both !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #859678 !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
}
.dde-footer-top {
  background: #859678 !important;
  padding: 100px 0 120px !important;
}
.dde-footer-inner {
  width: min(1280px, calc(100% - 72px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr 1fr !important;
  gap: 56px !important;
  align-items: start !important;
}
.dde-footer-cell {
  min-width: 0 !important;
  padding: 0 !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
}
.dde-footer-logo {
  display: block !important;
}
.dde-footer-logo img {
  display: block !important;
  width: min(190px, 72%) !important;
  max-width: 190px !important;
  min-width: 0 !important;
  height: auto !important;
  margin: 0 !important;
  object-fit: contain !important;
}
.dde-footer-icon-line {
  display: block !important;
  padding: 8px 0 0 !important;
}
.dde-footer-icon {
  display: none !important;
}
.dde-footer-address,
.dde-footer-address p {
  max-width: 290px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.62 !important;
  text-align: left !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.dde-footer-actions,
.dde-footer-links {
  display: grid !important;
  gap: 14px !important;
  padding-top: 8px !important;
}
.dde-footer-actions a,
.dde-footer-links a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: max-content !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-family: var(--dde-body) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 2px !important;
  line-height: 1.45 !important;
  text-transform: uppercase !important;
}
.dde-footer-actions a:hover,
.dde-footer-links a:hover {
  color: #fff !important;
  opacity: .76 !important;
}
.dde-footer-actions a span {
  display: inline-block !important;
  width: 14px !important;
  min-width: 14px !important;
  text-align: center !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}
.dde-footer-bottom {
  display: block !important;
  width: 100% !important;
  background: var(--dde-ivory) !important;
  color: #859678 !important;
}
.dde-footer-bottom-inner {
  width: min(1280px, calc(100% - 72px)) !important;
  margin: 0 auto !important;
  padding: 18px 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 2fr 1fr !important;
  gap: 24px !important;
  align-items: center !important;
  font-family: var(--dde-body) !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  font-weight: 700 !important;
}
.dde-footer-bottom-inner span:nth-child(1) { text-align: left !important; }
.dde-footer-bottom-inner span:nth-child(2) { text-align: center !important; }
.dde-footer-bottom-inner span:nth-child(3) { text-align: right !important; }

/* Cartes : le hover bleu est volontaire, comme dans la maquette Elementor. */
.dde-price-card:hover,
.dde-facility-card:hover,
.dde-step:hover {
  background: var(--dde-blue) !important;
  transform: translateY(-2px) !important;
}
.dde-price-card:hover p,
.dde-facility-card:hover p,
.dde-step:hover p,
.dde-price-card:hover .elementor-widget-text-editor,
.dde-facility-card:hover .elementor-widget-text-editor,
.dde-step:hover .elementor-widget-text-editor {
  color: rgba(31,45,30,.84) !important;
}

/* Booking : si 4 étapes, on garde une vraie ligne de 4 cartes. */
.dde-steps-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

@media (max-width: 1180px) {
  .dde-footer-inner,
  .dde-footer-bottom-inner { width: min(1080px, calc(100% - 48px)) !important; }
  .dde-footer-inner { gap: 36px !important; }
}
@media (max-width: 980px) {
  .dde-footer-top { padding: 72px 0 !important; }
  .dde-footer-inner {
    width: calc(100% - 52px) !important;
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
  .dde-footer-logo img { width: min(180px, 62%) !important; max-width: 180px !important; }
  .dde-footer-bottom { display: none !important; }
  .dde-steps-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 760px) {
  .dde-footer-inner { width: calc(100% - 34px) !important; }
  .dde-footer-address,
  .dde-footer-address p { max-width: none !important; }
  .dde-footer-actions a,
  .dde-footer-links a { width: auto !important; }
  .dde-steps-grid { grid-template-columns: 1fr !important; }
}

/* =========================================================
   v0.9 - Page Domaine de mariage calée sur export Elementor 722
   ========================================================= */
.dde-page-mariage .dde-hero {
  position: relative !important;
  margin-top: -95px !important;
  background-size: cover !important;
  background-position: center !important;
}
.dde-page-mariage .dde-hero::before {
  z-index: 1 !important;
  pointer-events: none !important;
}
.dde-page-mariage .dde-hero-content {
  position: relative !important;
  z-index: 2 !important;
}
.dde-page-mariage > .dde-key-grid {
  margin: -72px auto 0 !important;
  position: relative !important;
  z-index: 2 !important;
}
.dde-page-mariage .dde-key-card {
  text-align: left !important;
}
.dde-page-mariage .moment-place,
.dde-page-mariage .moment-place-wrap {
  color: var(--dde-green-deep) !important;
  font-weight: 500 !important;
}
.dde-page-mariage .dde-hostess {
  background: var(--dde-ivory) !important;
}
.dde-page-mariage .dde-hostess-shell {
  display: block !important;
}
.dde-page-mariage .dde-hostess-eyebrow {
  text-align: left !important;
}
.dde-page-mariage .dde-hostess-grid {
  display: grid !important;
  grid-template-columns: minmax(0,.9fr) minmax(0,1.1fr) !important;
  gap: clamp(34px,6vw,86px) !important;
  align-items: center !important;
}
.dde-page-mariage .dde-hostess-photo img {
  width: 100% !important;
  height: 560px !important;
  object-fit: cover !important;
  display: block !important;
}
.dde-page-mariage .dde-hostess-photo--empty {
  min-height: 520px !important;
  display: grid !important;
  place-items: center !important;
  background: var(--dde-white) !important;
  color: var(--dde-muted) !important;
  text-align: center !important;
}
.dde-page-mariage .dde-hostess-photo--empty strong {
  display:block !important;
  color: var(--dde-green-deep) !important;
  font-family: var(--dde-title) !important;
  font-size: 2rem !important;
  font-weight: 400 !important;
}
.dde-page-mariage .dde-hostess-photo--empty span {
  display:block !important;
  margin-top: 12px !important;
}
.dde-page-mariage .dde-hostess-content .dde-h2 .elementor-heading-title {
  font-family: var(--dde-title) !important;
  color: var(--dde-green-deep) !important;
  font-size: clamp(2.65rem,4vw,4.65rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
}
.dde-page-mariage .dde-hostess-quote p,
.dde-page-mariage .dde-hostess-quote {
  font-family: var(--dde-title) !important;
  font-size: clamp(1.45rem,2.2vw,2.25rem) !important;
  line-height: 1.2 !important;
  color: var(--dde-green-deep) !important;
  margin-top: 26px !important;
}
.dde-page-mariage .dde-hostess-text {
  margin-top: 24px !important;
}
.dde-page-mariage .dde-pricing-mariage .dde-section-head {
  text-align: center !important;
  max-width: 900px !important;
  margin: 0 auto !important;
}
.dde-page-mariage .dde-pricing-mariage .dde-section-head .elementor-widget-text-editor,
.dde-page-mariage .dde-pricing-mariage .dde-section-head p {
  max-width: 820px !important;
  margin: 24px auto 0 !important;
}
.dde-page-mariage .dde-wedding-pricing__grid {
  margin-top: clamp(42px,6vw,72px) !important;
}
.dde-page-mariage .dde-wedding-card:hover {
  background: var(--dde-blue) !important;
  transform: translateY(-2px) !important;
}
.dde-page-mariage .dde-wedding-card--featured:hover {
  background: var(--dde-lavender) !important;
}
.dde-page-mariage .dde-final .elementor-widget-button {
  margin-top: 34px !important;
}
@media (max-width: 940px) {
  .dde-page-mariage .dde-hostess-grid {
    grid-template-columns: 1fr !important;
  }
  .dde-page-mariage .dde-hostess-photo img,
  .dde-page-mariage .dde-hostess-photo--empty {
    height: auto !important;
    min-height: 420px !important;
  }
}
@media (max-width: 760px) {
  .dde-page-mariage .dde-hero {
    margin-top: -105px !important;
  }
  .dde-page-mariage > .dde-key-grid {
    width: 100% !important;
    margin-top: 0 !important;
  }
  .dde-page-mariage .dde-hostess-photo img,
  .dde-page-mariage .dde-hostess-photo--empty {
    min-height: 360px !important;
  }
}

/* Logo header blanc / couleur : nécessaire avec le header PHP v0.9 */
.dde-brand { display:inline-flex; align-items:center; text-decoration:none!important; }
.dde-brand .dde-logo { display:block; max-width:220px; width:100%; height:auto; object-fit:contain; }
.dde-brand .dde-logo--dark { display:none; }
#dde-head.is-scrolled .dde-brand .dde-logo--white { display:none!important; }
#dde-head.is-scrolled .dde-brand .dde-logo--dark { display:block!important; }
.dde-brand-fallback { display:none; color:currentColor; font-family:var(--dde-title, Georgia, serif); font-size:22px; line-height:1; }
.dde-menu a, .dde-mobile-menu a, .dde-header-cta, .dde-mobile-cta { text-decoration:none!important; }
@media (max-width:980px){ .dde-brand .dde-logo{ max-width:96px; } }


/* =========================================================
   Footer final DDE - taille et grille identiques sur toutes les pages
   ========================================================= */
.dde-site-footer {
  font-family: var(--dde-body) !important;
  background: var(--dde-green) !important;
  color: #fff !important;
}
.dde-site-footer .dde-footer-top {
  background: var(--dde-green) !important;
  padding: clamp(96px, 9vw, 145px) 0 clamp(88px, 8vw, 130px) !important;
}
.dde-site-footer .dde-footer-inner {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: 1.05fr 1.15fr 1fr 1fr !important;
  gap: clamp(54px, 7vw, 110px) !important;

}
.dde-site-footer .dde-footer-logo img {
  display: block !important;
  width: min(210px, 90%) !important;
  max-width: 210px !important;
  height: auto !important;
}
.dde-site-footer .dde-footer-cell,
.dde-site-footer .dde-footer-address,
.dde-site-footer .dde-footer-address p {
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-size: clamp(1rem, 1.08vw, 1.13rem) !important;
  line-height: 1.55 !important;
  font-weight: 500 !important;
}
.dde-site-footer .dde-footer-actions,
.dde-site-footer .dde-footer-links {
  display: grid !important;
  gap: 18px !important;
  align-content: center !important;
}
.dde-site-footer .dde-footer-actions a,
.dde-site-footer .dde-footer-links a {
  color: #fff !important;
  font-family: var(--dde-body) !important;
  font-size: clamp(.88rem, .95vw, 1rem) !important;
  line-height: 1.7 !important;
  font-weight: 300 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.dde-site-footer .dde-footer-actions a:hover,
.dde-site-footer .dde-footer-links a:hover { color: var(--dde-ivory) !important; }
.dde-site-footer .dde-footer-bottom {
  display: block !important;
  background: var(--dde-ivory) !important;
  color: var(--dde-green) !important;
}
.dde-site-footer .dde-footer-bottom-inner {
  width: min(1180px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  padding: 18px 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 2fr 1fr !important;
  gap: 24px !important;
  align-items: center !important;
  font-family: var(--dde-body) !important;
  font-size: clamp(.9rem, .95vw, 1rem) !important;
  font-weight: 800 !important;
}
.dde-site-footer .dde-footer-bottom-inner span:nth-child(1) { text-align: left !important; }
.dde-site-footer .dde-footer-bottom-inner span:nth-child(2) { text-align: center !important; }
.dde-site-footer .dde-footer-bottom-inner span:nth-child(3) { text-align: right !important; }
@media (max-width: 980px) {
  .dde-site-footer .dde-footer-top { padding: 72px 0 !important; }
  .dde-site-footer .dde-footer-inner {
    width: calc(100% - 34px) !important;
    grid-template-columns: 1fr !important;
    gap: 34px !important;
    align-items: start !important;
  }
  .dde-site-footer .dde-footer-logo img { width: min(190px, 72%) !important; }
  .dde-site-footer .dde-footer-bottom { display: none !important; }
}

/* Footer pictos SVG alignés comme le modèle Elementor */
.dde-site-footer .dde-footer-icon {
  width: 18px;
  height: 18px;
  min-width: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: .96;
  line-height: 1;
}

.dde-site-footer .dde-footer-icon svg {
  width: 16px;
  height: 16px;
  display: block;
  fill: currentColor;
}

.dde-site-footer .dde-footer-icon-line,
.dde-site-footer .dde-footer-actions a {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.dde-site-footer .dde-footer-actions {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.dde-site-footer .dde-footer-actions a,
.dde-site-footer .dde-footer-links a {
  color: #fff !important;
  text-decoration: none !important;
  font-family: var(--dde-body, Manrope, Arial, sans-serif);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.dde-site-footer .dde-footer-address p {
  margin: 0;
  color: #fff !important;
  font-family: var(--dde-body, Manrope, Arial, sans-serif);
  font-size: 16px;
  line-height: 1.55;
}

.dde-site-footer .dde-footer-logo img {
  max-width: 170px;
  height: auto;
  display: block;
}

/* =========================================================
   HOTFIX V30 - Corrections globales légères
   ========================================================= */

.dde-static-about .dde-about-timeline__grid,
.dde-about-page .dde-about-timeline__grid {
  grid-template-columns: minmax(460px, .9fr) minmax(0, 1.1fr) !important;
  gap: clamp(48px, 7vw, 108px) !important;
  align-items: start !important;
}
.dde-static-about .dde-about-timeline__grid > div:first-child h2,
.dde-about-page .dde-about-timeline__grid > div:first-child h2 {
  max-width: 760px !important;
  font-size: clamp(3.2rem, 5vw, 5.8rem) !important;
  line-height: 1 !important;
  letter-spacing: -.055em !important;
}
.dde-static-about .dde-about-timeline__items,
.dde-about-page .dde-about-timeline__items { width: 100% !important; }

.dde-site-footer {
  position: relative !important;
  border-top: 1px solid rgba(248, 244, 234, .22) !important;
}
.dde-site-footer::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -1px;
  height: 1px;
  background: rgba(31, 45, 30, .14);
}

@media (max-width: 980px) {
  .dde-static-about .dde-about-timeline__grid,
  .dde-about-page .dde-about-timeline__grid { grid-template-columns: 1fr !important; }
}

/* =========================================================
   V34 — Correctifs présentation finale, sans ACF ni menu WP
   ========================================================= */

/* Header scroll : le texte ne devient plus vert, seul le filet actif/hover est vert. */
.dde-site-head.is-scrolled .dde-menu a,
.dde-site-head.is-scrolled .dde-brand,
.dde-site-head.is-scrolled .dde-brand-fallback {
  color: var(--dde-text, #1f2d1e) !important;
}

.dde-menu a,
.dde-mobile-menu a {
  position: relative !important;
  text-decoration: none !important;
}

.dde-menu a::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -9px !important;
  height: 2px !important;
  background: var(--dde-green, #859679) !important;
  transform: scaleX(0) !important;
  transform-origin: left center !important;
  transition: transform .22s ease !important;
}

.dde-menu a:hover,
.dde-menu .current-menu-item > a,
.dde-menu .current_page_item > a,
.dde-menu .current-menu-ancestor > a {
  color: inherit !important;
}

.dde-menu a:hover::after,
.dde-menu .current-menu-item > a::after,
.dde-menu .current_page_item > a::after,
.dde-menu .current-menu-ancestor > a::after {
  transform: scaleX(1) !important;
}

/* CTA header : feuille stylisée à trois brins, sans modifier le HTML. */
.dde-header-cta {
  gap: 10px !important;
}


.dde-event-hero-cta::after,
.dde-home-btn--light::after,
.dde-static-btn::after {
  content: "" !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  margin-left: 8px !important;
  flex: 0 0 18px !important;

  background-image: url("https://fdvdev.com/domaine-des-evis/wp-content/uploads/2026/05/logo-btn-1-192x192-1.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  background-color: transparent !important;
  -webkit-mask: none !important;
  mask: none !important;

  border-radius: 0 !important;
  transform: none !important;
}

.dde-header-cta::after,
.dde-mobile-cta::after {
  content: "" !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  margin-left: 8px !important;
  flex: 0 0 18px !important;

  background-image: url("https://fdvdev.com/domaine-des-evis/wp-content/uploads/2026/05/cropped-cropped-Fichier-1-192x192.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  background-color: transparent !important;
  -webkit-mask: none !important;
  mask: none !important;

  border-radius: 0 !important;
  transform: none !important;
}
/* H1 : réduction globale d'environ 20 %, par familles de templates. */
.dde-home-hero h1,
.dde-home h1 {
  font-size: clamp(2.9rem, 4.7vw, 5.35rem) !important;
  line-height: 1.02 !important;
}

.dde-static h1,
.dde-about-hero h1,
.dde-static-hero h1 {
  font-size: clamp(2.7rem, 5vw, 5.25rem) !important;
  line-height: 1.02 !important;
}

.dde-event-page .dde-event-hero h1,
.dde-event-page .dde-event-hero .dde-event-h1 {
  font-size: clamp(2.75rem, 4.6vw, 5rem) !important;
  line-height: 1.02 !important;
}

.dde-hero h1,
.dde-hero .dde-hero-title h1,
.dde-page-mariage .dde-hero-title h1,
.dde-page-maison .dde-hero-title h1 {
  font-size: clamp(2.75rem, 4.8vw, 5.15rem) !important;
  line-height: 1.02 !important;
}

@media (max-width: 760px) {
  .dde-home-hero h1,
  .dde-static h1,
  .dde-about-hero h1,
  .dde-static-hero h1,
  .dde-event-page .dde-event-hero h1,
  .dde-event-page .dde-event-hero .dde-event-h1,
  .dde-hero h1,
  .dde-page-mariage .dde-hero-title h1,
  .dde-page-maison .dde-hero-title h1 {
    font-size: clamp(2.15rem, 10vw, 3.45rem) !important;
    line-height: 1.06 !important;
  }
}

/* Accès / maps : style commun des cartes sous carte Google. */
.dde-map iframe,
.dde-home-map iframe,
.dde-event-map iframe,
.dde-about-map iframe {
  width: 100% !important;
  height: clamp(330px, 36vw, 470px) !important;
  border: 0 !important;
  display: block !important;
  filter: grayscale(.12) saturate(.92) contrast(.98) !important;
}

.dde-access-card,
.dde-home-access__grid article,
.dde-event-access-grid article,
.dde-about-access__grid article {
  background: #fff !important;
  border: 1px solid rgba(138,117,100,.24) !important;
  padding: clamp(26px, 3vw, 34px) !important;
}

.dde-access-card h4,
.dde-home-access__grid h3,
.dde-event-access-grid h3,
.dde-about-access__grid h3 {
  margin: 0 0 12px !important;
  color: var(--dde-green-deep, #1f2d1e) !important;
  font-family: var(--dde-title, Marcellus, Georgia, serif) !important;
  font-size: clamp(1.35rem, 1.7vw, 1.8rem) !important;
  line-height: 1.1 !important;
}

.dde-access-card p,
.dde-home-access__grid p,
.dde-event-access-grid p,
.dde-about-access__grid p {
  margin: 0 !important;
  color: var(--dde-muted, #6f675e) !important;
  line-height: 1.65 !important;
}

/* =========================================================
   URGENT HEADER MENU - correction présentation
   Ne touche pas au menu WP, uniquement rendu visuel
   ========================================================= */

/* Structure header plus stable */
.dde-site-head,
#dde-head {
  width: 100%;
  z-index: 9999;
}

.dde-site-head .dde-head-inner,
#dde-head .dde-head-inner {
  width: min(1320px, calc(100% - 56px)) !important;
  max-width: 1320px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 26px !important;
}

/* Logo moins envahissant */
.dde-brand,
.dde-site-head .dde-brand,
#dde-head .dde-brand {
  flex: 0 0 auto !important;
  max-width: 150px !important;
}

.dde-brand img,
.dde-site-head .dde-brand img,
#dde-head .dde-brand img {
  max-width: 145px !important;
  height: auto !important;
}

/* Nav : empêcher les retours à la ligne dégueulasses */
.dde-nav {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.dde-menu,
.dde-nav ul {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(16px, 1.65vw, 30px) !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  flex-wrap: nowrap !important;
}

.dde-menu li,
.dde-nav li {
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Liens menu : une seule ligne, lisible, sans vert en texte */
.dde-menu a,
.dde-nav a {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-height: 1.1 !important;
  color: currentColor !important;
  text-decoration: none !important;
  font-size: 13px!important;
  font-weight: 800 !important;
  letter-spacing: 0.055em !important;
  text-transform: uppercase !important;
}

/* Header transparent sur hero : texte blanc */
body:not(.home) .dde-site-head:not(.is-scrolled),
body:not(.home) #dde-head:not(.is-scrolled),
.dde-site-head:not(.is-scrolled),
#dde-head:not(.is-scrolled) {
  color: #fff !important;
}

/* Header au scroll : texte foncé, PAS vert */
.dde-site-head.is-scrolled,
#dde-head.is-scrolled,
body.scrolled .dde-site-head,
body.scrolled #dde-head {
  color: var(--dde-green-deep, #1f2d1e) !important;
}

/* Active / hover : seulement un soulignement vert, jamais le texte vert */
.dde-menu a::after,
.dde-nav a::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -9px !important;
  height: 2px !important;
  background: var(--dde-green, #859679) !important;
  transform: scaleX(0) !important;
  transform-origin: center !important;
  transition: transform 0.2s ease !important;
}

.dde-menu a:hover::after,
.dde-nav a:hover::after,
.dde-menu .current-menu-item > a::after,
.dde-menu .current_page_item > a::after,
.dde-nav .current-menu-item > a::after,
.dde-nav .current_page_item > a::after {
  transform: scaleX(1) !important;
}

/* Important : l'actif reste visible, pas vert, pas transparent */
.dde-menu .current-menu-item > a,
.dde-menu .current_page_item > a,
.dde-nav .current-menu-item > a,
.dde-nav .current_page_item > a,
.dde-menu a:hover,
.dde-nav a:hover {
  color: currentColor !important;
  opacity: 1 !important;
}

/* CTA header stable */
.dde-header-cta,
.dde-site-head .dde-header-cta,
#dde-head .dde-header-cta {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  min-width: max-content !important;
  color: #fff !important;
  background: var(--dde-green, #859679) !important;
  border: 1px solid var(--dde-green, #859679) !important;
  text-decoration: none !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.06em !important;
  font-weight: 800 !important;
}

/* Évite que le CTA écrase le menu */
@media (max-width: 1180px) {
  .dde-menu,
  .dde-nav ul {
    gap: 14px !important;
  }

  .dde-menu a,
  .dde-nav a {
    font-size: 13px !important;
    letter-spacing: 0.04em !important;
  }

  .dde-brand img,
  .dde-site-head .dde-brand img,
  #dde-head .dde-brand img {
    max-width: 122px !important;
  }
}

/* Mobile : laisser le menu mobile prendre la main */
@media (max-width: 980px) {
  .dde-nav {
    display: none !important;
  }

  .dde-site-head .dde-head-inner,
  #dde-head .dde-head-inner {
    width: calc(100% - 32px) !important;
  }
}


/* =========================================================
   V36 - Correctifs présentation finale, visuels, typo, boutons
   Patch CSS uniquement : pas de menu WP, pas d'ACF, pas d'import.
   ========================================================= */
:root {
  --dde-official-green: #859679;
  --dde-official-green-deep: #1f2d1e;
  --dde-official-ivory: #F8F4EA;
  --dde-official-paper: #FFFDF8;
  --dde-official-blue: #AEB9C1;
  --dde-official-line: rgba(31,45,30,.14);
  --dde-btn-leaf-green: url("https://fdvdev.com/domaine-des-evis/wp-content/uploads/2026/05/logo-btn-1-192x192-1.png");
  --dde-btn-leaf-white: url("https://fdvdev.com/domaine-des-evis/wp-content/uploads/2026/05/cropped-cropped-Fichier-1-192x192.png");
}

/* Header : logo plus présent, menu stable, texte jamais vert au scroll */
.dde-site-head .dde-head-inner,
#dde-head .dde-head-inner {
  min-height: 76px !important;
}
.dde-brand img,
.dde-site-head .dde-brand img,
#dde-head .dde-brand img {
  max-width: 172px !important;
  width: 172px !important;
  height: auto !important;
}
.dde-site-head.is-scrolled .dde-brand img,
#dde-head.is-scrolled .dde-brand img {
  max-width: 168px !important;
  width: 168px !important;
}
.dde-menu a,
.dde-nav a,
.dde-site-head.is-scrolled .dde-menu a,
.dde-site-head.is-scrolled .dde-nav a,
#dde-head.is-scrolled .dde-menu a,
#dde-head.is-scrolled .dde-nav a {
  color: currentColor !important;
  opacity: 1 !important;
  text-decoration: none !important;
}
.dde-menu .current-menu-item > a,
.dde-menu .current_page_item > a,
.dde-nav .current-menu-item > a,
.dde-nav .current_page_item > a,
.dde-menu a:hover,
.dde-nav a:hover {
  color: currentColor !important;
  opacity: 1 !important;
}
.dde-menu a::after,
.dde-nav a::after {
  background: var(--dde-official-green) !important;
}

/* Icônes boutons : feuille officielle trois pétales, suppression de la feuille CSS générique */
.dde-header-cta::after,
.dde-mobile-cta::after,
.dde-event-hero-cta::after,
.dde-home-btn::after,
.dde-static-btn::after,
.dde-v6 .elementor-button .elementor-button-text::after,
.dde-v6 .elementor-button::after {
  content: "" !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  margin-left: 10px !important;
  flex: 0 0 18px !important;
  background-color: transparent !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
  border-radius: 0 !important;
  transform: none !important;
  -webkit-mask: none !important;
  mask: none !important;
  vertical-align: -3px !important;
}
.dde-header-cta::after,
.dde-mobile-cta::after,
.dde-static-btn:not(.dde-static-btn--light)::after,
.dde-v6 .elementor-widget-button:not(.dde-leaf) .elementor-button::after {
  background-image: var(--dde-btn-leaf-white) !important;
}
.dde-home-btn--light::after,
.dde-event-hero-cta::after,
.dde-static-btn--light::after,
.dde-leaf .elementor-button-text::after,
.dde-v6 .elementor-widget-button.dde-leaf .elementor-button::after {
  background-image: var(--dde-btn-leaf-green) !important;
}
.dde-home-btn--ghost::after,
.dde-static-btn--ghost::after {
  background-image: var(--dde-btn-leaf-white) !important;
}
/* Évite double icône Elementor sur certains boutons */
.dde-v6 .elementor-button .elementor-button-text::after { display: none !important; }
.dde-v6 .elementor-widget-button.dde-leaf .elementor-button .elementor-button-text::after { display: none !important; }

/* Photos de header : filtre moins sombre */
.dde-hero::before {
  background:
    linear-gradient(180deg, rgba(16,25,15,.36) 0%, rgba(16,25,15,.10) 42%, rgba(16,25,15,.38) 100%),
    radial-gradient(circle at center, rgba(0,0,0,0) 0 35%, rgba(0,0,0,.25) 100%) !important;
}
.dde-event-page .dde-event-hero::after,
.dde-event-hero::after {
  background:
    linear-gradient(180deg, rgba(16,25,15,.34) 0%, rgba(16,25,15,.08) 42%, rgba(16,25,15,.42) 100%),
    radial-gradient(circle at center, rgba(0,0,0,0) 0 35%, rgba(0,0,0,.24) 100%) !important;
}

/* Tous les headers : texte centré et H1 réduit d'environ 20 % */
.dde-hero,
.dde-event-page .dde-event-hero,
.dde-static-hero,
.dde-about-hero {
  text-align: center !important;
}
.dde-hero-content,
.dde-event-page .dde-event-hero .dde-event-shell,
.dde-static-hero__inner,
.dde-about-hero__inner {
  margin-inline: auto !important;
  text-align: center !important;
  justify-items: center !important;
}
.dde-hero-text p,
.dde-event-page .dde-event-hero-text,
.dde-static-hero .dde-static-rich,
.dde-about-hero .dde-static-rich {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
.dde-hero-title .elementor-heading-title,
.dde-event-page .dde-event-hero h1,
.dde-event-page .dde-event-hero .dde-event-h1,
.dde-static h1,
.dde-about-hero h1 {
  font-size: clamp(2.35rem, 4.2vw, 4.75rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.04em !important;
  max-width: 960px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Petits titres : suppression des grands tirets / traits décoratifs */
.dde-eyebrow .elementor-heading-title::before,
.dde-eyebrow .elementor-heading-title::after,
.section-eyebrow::before,
.section-eyebrow::after,
.dde-event-eyebrow::before,
.dde-event-eyebrow::after,
.dde-home-eyebrow::before,
.dde-home-eyebrow::after,
.dde-static-eyebrow::before,
.dde-static-eyebrow::after,
.dde-legal-eyebrow::before,
.dde-legal-eyebrow::after,
.dde-hostess .dde-hostess-eyebrow .elementor-heading-title::before,
.dde-hostess .dde-hostess-eyebrow .elementor-heading-title::after {
  display: none !important;
  content: none !important;
}

/* Demi-espace systématique entre H2 et paragraphe / texte */
.dde-h2 + .elementor-widget-text-editor,
.dde-h2 + .dde-intro-text,
h2 + p,
h2 + .dde-home-rich,
h2 + .dde-static-rich,
h2 + .elementor-widget-text-editor,
.dde-home h2 + .dde-home-rich,
.dde-static h2 + .dde-static-rich,
.dde-event-h2 + .dde-event-intro-text,
.dde-event-section-head h2 + p {
  margin-top: clamp(14px, 1.4vw, 22px) !important;
}
.dde-section-head .dde-h2,
.dde-home-section-head h2,
.dde-event-section-head h2,
.dde-static h2 {
  margin-bottom: clamp(14px, 1.4vw, 22px) !important;
}

/* Étapes / boîtes : texte centré, style homogène */
.dde-steps-grid,
.dde-event-steps,
.dde-key-grid,
.dde-home-facts__grid {
  align-items: stretch !important;
}
.dde-step,
.dde-event-step,
.dde-key-card,
.dde-home-fact,
.dde-gite-price-card,
.dde-event-price-card {
  text-align: center !important;
  justify-items: center !important;
  align-content: center !important;
  background: var(--dde-official-ivory) !important;
  border: 1px solid rgba(31,45,30,.14) !important;
  box-shadow: none !important;
}
.dde-step p,
.dde-step .elementor-widget-text-editor,
.dde-event-step-text,
.dde-event-step-title,
.dde-key-card p,
.dde-home-fact span,
.dde-gite-price-card p,
.dde-gite-price-card .elementor-widget-text-editor {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Fonds marron foncé : retour vers couleurs de charte */
.dde-home-host,
.dde-hostess {
  background: var(--dde-official-green) !important;
}
.dde-home-host h2,
.dde-home-host blockquote,
.dde-home-host .dde-home-rich p,
.dde-hostess h2,
.dde-hostess p,
.dde-hostess .elementor-heading-title {
  color: var(--dde-official-ivory) !important;
}
.dde-hostess-quote,
.dde-home-host blockquote {
  border-left-color: rgba(248,244,234,.58) !important;
}

/* Cadres blancs autour des photos : suppression home + à propos */
.dde-home figure,
.dde-home img,
.dde-static-about figure,
.dde-static-about img,
.dde-about-card figure,
.dde-about-card img,
.dde-about-gallery figure,
.dde-about-gallery img,
.dde-home-host__media img,
.dde-home-intro__media img,
.dde-home-services__media img {
  border: 0 !important;
  outline: 0 !important;
  outline-offset: 0 !important;
  box-shadow: none !important;
}
.dde-home-host__media img,
.dde-home-intro__media img,
.dde-home-services__media img,
.dde-static figure img {
  background: transparent !important;
}

/* Accueil : le bloc chiffres reste ivoire, le fond en dessous reste blanc */
.dde-home .dde-home-facts {
  background: #fff !important;
  padding: 0 0 clamp(70px, 7vw, 110px) !important;
  position: relative !important;
  z-index: 4 !important;
}
.dde-home .dde-home-facts__grid {
  background: var(--dde-official-ivory) !important;
  margin-top: -48px !important;
  position: relative !important;
  z-index: 5 !important;
}
.dde-home .dde-home-hero + .dde-home-facts {
  background: linear-gradient(to bottom, transparent 0, transparent 48px, #fff 48px, #fff 100%) !important;
}

@media (max-width: 1180px) {
  .dde-brand img,
  .dde-site-head .dde-brand img,
  #dde-head .dde-brand img {
    max-width: 148px !important;
    width: 148px !important;
  }
}
@media (max-width: 760px) {
  .dde-hero-title .elementor-heading-title,
  .dde-event-page .dde-event-hero h1,
  .dde-event-page .dde-event-hero .dde-event-h1,
  .dde-static h1,
  .dde-about-hero h1 {
    font-size: clamp(2.35rem, 10vw, 3.65rem) !important;
  }
  .dde-home .dde-home-facts__grid { margin-top: -28px !important; }
}


/* =========================================================
   V38 - Accès harmonisé partout : modèle Domaine des Evis
   ========================================================= */
.dde-map,
.dde-home-map,
.dde-event-map,
.dde-about-map {
  width: 100% !important;
  margin: clamp(34px, 5vw, 58px) auto 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.dde-map iframe,
.dde-home-map iframe,
.dde-event-map iframe,
.dde-about-map iframe {
  display: block !important;
  width: 100% !important;
  height: clamp(300px, 34vw, 460px) !important;
  min-height: 300px !important;
  border: 0 !important;
  filter: saturate(.92) contrast(.94) !important;
}

.dde-access-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0 !important;
  margin: 0 auto clamp(64px, 7vw, 104px) !important;
  background: #f8f4ea !important;
  border: 1px solid rgba(31, 45, 30, .14) !important;
  box-shadow: none !important;
}

.dde-access-card {
  position: relative !important;
  display: block !important;
  padding: clamp(36px, 4vw, 56px) clamp(28px, 4vw, 48px) !important;
  min-height: 0 !important;
  background: #f8f4ea !important;
  border: 0 !important;
  text-align: left !important;
}

.dde-access-card:not(:last-child)::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 1px !important;
  background: rgba(31, 45, 30, .14) !important;
}

.dde-access-card .dde-h3,
.dde-access-card .elementor-widget-text-editor {
  margin: 0 !important;
  padding: 0 !important;
}

.dde-access-card h4,
.dde-access-card h4.elementor-heading-title,
.dde-access-card .elementor-heading-title {
  margin: 0 0 22px !important;
  color: var(--dde-green-deep, #1f2d1e) !important;
  font-family: var(--dde-title, Marcellus, Georgia, serif) !important;
  font-size: clamp(1.95rem, 2.55vw, 3rem) !important;
  line-height: 1.06 !important;
  font-weight: 400 !important;
  letter-spacing: -.035em !important;
  text-align: left !important;
}

.dde-access-card p,
.dde-access-card .elementor-widget-text-editor p {
  margin: 0 !important;
  color: var(--dde-muted, #6f675e) !important;
  font-family: var(--dde-body, Manrope, Arial, sans-serif) !important;
  font-size: clamp(1.02rem, 1.18vw, 1.22rem) !important;
  line-height: 1.56 !important;
  text-align: left !important;
}

/* Neutralise les anciennes variantes avec icônes/cartes blanches */
.dde-home-access__grid,
.dde-event-access-grid,
.dde-about-access__grid {
  display: none !important;
}

.dde-home-access .dde-access-grid,
.dde-event-access .dde-access-grid,
.dde-about-access .dde-access-grid,
.dde-map-section .dde-access-grid {
  display: grid !important;
}

@media (max-width: 860px) {
  .dde-access-grid {
    grid-template-columns: 1fr !important;
  }

  .dde-access-card:not(:last-child)::after {
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: auto !important;
    height: 1px !important;
  }

  .dde-access-card {
    padding: 34px 26px !important;
  }
}

/* =========================================================
   DDE v39 - Accès unifié EXACT sous toutes les Google Maps
   Design : fond ivoire, cartes blanches, pictos, titres contenus.
   ========================================================= */
.dde-map-section,
.dde-event-access,
.dde-about-access,
.dde-home-access {
  background: var(--dde-ivory, #f8f4ea) !important;
}

.dde-map-section .dde-map,
.dde-event-access .dde-map,
.dde-about-access .dde-map,
.dde-home-access .dde-map {
  margin-bottom: 0 !important;
}

.dde-access-grid.dde-access-grid--unified,
.dde-map-section .dde-access-grid.dde-access-grid--unified,
.dde-event-access .dde-access-grid.dde-access-grid--unified,
.dde-about-access .dde-access-grid.dde-access-grid--unified,
.dde-home-access .dde-access-grid.dde-access-grid--unified {
  background:none!important;
  margin: 0 auto !important;
  padding: clamp(24px, 2.2vw, 34px) 0 clamp(28px, 2.4vw, 38px) !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(24px, 2.6vw, 46px) !important;
  border: 0 !important;
  box-shadow: none !important;
}

.dde-access-grid.dde-access-grid--unified .dde-access-card,
.dde-access-grid.dde-access-grid--unified .dde-access-card--unified {
  position: relative !important;
  display: block !important;
  min-height: clamp(210px, 16vw, 255px) !important;
  padding: clamp(38px, 3.5vw, 54px) clamp(34px, 3vw, 48px) !important;
  background: #fff !important;
  border: 1px solid rgba(129, 121, 104, 0.24) !important;
  box-shadow: none !important;
  text-align: left !important;
  overflow: visible !important;
}

.dde-access-grid.dde-access-grid--unified .dde-access-card::before,
.dde-access-grid.dde-access-grid--unified .dde-access-card::after {
  content: none !important;
  display: none !important;
}

.dde-access-grid.dde-access-grid--unified .dde-access-card__head {
  display: flex !important;
  align-items: center !important;
  gap: clamp(18px, 1.6vw, 26px) !important;
  margin: 0 0 clamp(26px, 2.4vw, 34px) !important;
}

.dde-access-grid.dde-access-grid--unified .dde-access-icon {
  flex: 0 0 28px !important;
  width: 28px !important;
  height: 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--dde-green, #859679) !important;
}

.dde-access-grid.dde-access-grid--unified .dde-access-icon svg {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.8 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.dde-access-grid.dde-access-grid--unified .dde-h3,
.dde-access-grid.dde-access-grid--unified .dde-h3 h4,
.dde-access-grid.dde-access-grid--unified h4,
.dde-access-grid.dde-access-grid--unified h4.elementor-heading-title,
.dde-access-grid.dde-access-grid--unified .elementor-heading-title {
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--dde-body, Manrope, Arial, sans-serif) !important;
  font-size: clamp(1.35rem, 1.45vw, 1.75rem) !important;
  line-height: 1.18 !important;
  font-weight: 400 !important;
  letter-spacing: -0.025em !important;
  color: var(--dde-ink, #1f2d1e) !important;
  text-align: left !important;
  text-transform: none !important;
}

.dde-access-grid.dde-access-grid--unified .elementor-widget-text-editor,
.dde-access-grid.dde-access-grid--unified .elementor-widget-text-editor p,
.dde-access-grid.dde-access-grid--unified p {
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  font-family: var(--dde-body, Manrope, Arial, sans-serif) !important;
  font-size: 18px !important;
  line-height: 1.48 !important;
  font-weight: 300 !important;
  color: #736e68 !important;
  text-align: left !important;
}

@media (max-width: 980px) {
  .dde-access-grid.dde-access-grid--unified,
  .dde-map-section .dde-access-grid.dde-access-grid--unified,
  .dde-event-access .dde-access-grid.dde-access-grid--unified,
  .dde-about-access .dde-access-grid.dde-access-grid--unified,
  .dde-home-access .dde-access-grid.dde-access-grid--unified {
    grid-template-columns: 1fr !important;
    width: min(680px, calc(100% - 32px)) !important;
    gap: 18px !important;
  }

  .dde-access-grid.dde-access-grid--unified .dde-access-card {
    min-height: 0 !important;
    padding: 30px 28px !important;
  }
}


/* =========================================================
   DDE v40 - corrections finales présentation client
   Aucun ACF/menu/page modifié : uniquement rendu visuel.
   ========================================================= */
:root {
  --dde-green: #859679 !important;
  --dde-green-deep: #202B1D !important;
  --dde-brun: #8A7564 !important;
  --dde-ivory: #F8F4EA !important;
  --dde-blue-grey: #AEB9C1 !important;
  --dde-lavender: #C8C1D4 !important;
  --dde-line-soft: rgba(32,43,29,.14) !important;
}

/* 1) Header / menu */
.dde-site-head .dde-head-inner,
#dde-head .dde-head-inner {
  width: min(1360px, calc(100% - 56px)) !important;
  gap: clamp(18px, 2vw, 34px) !important;
}
.dde-brand,
.dde-site-head .dde-brand,
#dde-head .dde-brand {
  max-width: 180px !important;
}
.dde-brand img,
.dde-logo,
.dde-site-head .dde-brand img,
#dde-head .dde-brand img {
  max-width: 175px !important;
  width: auto !important;
  height: clamp(42px, 3.6vw, 58px) !important;
  object-fit: contain !important;
}
.dde-menu,
.dde-nav ul {
  gap: clamp(15px, 1.55vw, 28px) !important;
}
.dde-menu a,
.dde-nav a,
.dde-mobile-menu a {
  color: currentColor !important;
  opacity: 1 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
.dde-menu a::after,
.dde-nav a::after {
  background: #fff !important;
  height: 2px !important;
  bottom: -9px !important;
}
.dde-site-head.is-scrolled .dde-menu a::after,
.dde-site-head.is-scrolled .dde-nav a::after,
#dde-head.is-scrolled .dde-menu a::after,
#dde-head.is-scrolled .dde-nav a::after {
  background: #fff !important;
}
.dde-menu .current-menu-item > a,
.dde-menu .current_page_item > a,
.dde-nav .current-menu-item > a,
.dde-nav .current_page_item > a,
.dde-menu a:hover,
.dde-nav a:hover {
  color: currentColor !important;
}
.dde-header-cta,
.dde-mobile-cta {
  background: #fff !important;
  color: var(--dde-green, #859679) !important;
  border-color: #fff !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  min-height: 52px !important;
  padding: 14px 28px !important;
}
.dde-site-head.is-scrolled .dde-header-cta,
#dde-head.is-scrolled .dde-header-cta {
  background: #fff !important;
  color: var(--dde-green, #859679) !important;
  border-color: rgba(32,43,29,.1) !important;
}

/* 2) Supprimer toutes les feuilles / pictos dans les boutons + centrage */
.dde-header-cta::after,
.dde-mobile-cta::after,
.dde-home-btn::after,
.dde-static-btn::after,
.dde-button::after,
.dde-leaf::after,
.dde-hero-cta::after,
.dde-event-hero-cta::after,
.dde-event-final-cta::after,
.elementor-button::after,
.wp-block-button__link::after,
a[class*="btn"]::after,
a[class*="cta"]::after,
button[class*="btn"]::after {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  background: none !important;
  -webkit-mask: none !important;
  mask: none !important;
}
.dde-home-btn,
.dde-static-btn,
.dde-button,
.dde-leaf,
.dde-hero-cta,
.dde-event-hero-cta,
.dde-event-final-cta,
.elementor-button,
.wp-block-button__link,
a[class*="btn"],
a[class*="cta"],
button[class*="btn"] {
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 0 !important;
}

/* 3) Headers : filtres moins sombres, texte centré, sous-titres plus lisibles */
.dde-home-hero__veil,
.dde-about-hero__veil,
.dde-static-hero__veil {
  background: linear-gradient(180deg, rgba(18,25,17,.30), rgba(18,25,17,.18) 42%, rgba(18,25,17,.46)) !important;
}
.dde-hero::before,
.dde-maison-hero::before {
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.36)) !important;
}
.dde-event-hero::after,
.dde-event-page .dde-event-hero::after {
  background: linear-gradient(180deg, rgba(16,22,15,.22), rgba(16,22,15,.38)) !important;
}
.dde-home-hero__inner,
.dde-about-hero__inner,
.dde-static-hero__inner,
.dde-hero-content,
.dde-event-hero .dde-event-shell,
.dde-event-page .dde-event-hero .dde-event-shell {
  text-align: center !important;
  align-items: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.dde-home-hero h1,
.dde-about-hero h1,
.dde-static-hero h1,
.dde-hero h1,
.dde-event-hero h1,
.dde-event-hero .dde-event-h1 {
  max-width: 980px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  font-size: clamp(2.7rem, 5.35vw, 5.75rem) !important;
  line-height: .98 !important;
}
.dde-home-hero__text,
.dde-home-hero__text p,
.dde-about-hero .dde-static-rich,
.dde-static-hero .dde-static-rich,
.dde-hero-text,
.dde-hero-text p,
.dde-event-hero-text,
.dde-event-hero-text p {
  max-width: 740px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  color: rgba(255,255,255,.98) !important;
  text-shadow: 0 3px 18px rgba(0,0,0,.35) !important;
}
.dde-home-actions,
.dde-about-actions {
  justify-content: center !important;
}

/* 4) Supprimer les petits tirets décoratifs avant les sur-titres */
.dde-eyebrow::before,
.dde-static-eyebrow::before,
.dde-home-eyebrow::before,
.dde-event-eyebrow::before,
.dde-event-hero-eyebrow::before,
.dde-kicker::before,
[class*="eyebrow"]::before {
  content: none !important;
  display: none !important;
}
.dde-eyebrow,
.dde-static-eyebrow,
.dde-home-eyebrow,
.dde-event-eyebrow,
.dde-event-hero-eyebrow {
  padding-left: 0 !important;
  text-align: inherit !important;
}

/* 5) Espacement H2 / paragraphes */
.dde-h2,
.dde-section-head h2,
.dde-home-section-head h2,
.dde-static h2,
.dde-event-h2,
h2.elementor-heading-title {
  margin-bottom: clamp(18px, 2vw, 30px) !important;
}
h2 + p,
h2 + .dde-home-rich,
h2 + .dde-static-rich,
.dde-h2 + .elementor-widget-text-editor,
.dde-h2 + p,
.dde-section-head .elementor-widget-text-editor,
.dde-home-section-head .dde-home-rich {
  margin-top: clamp(12px, 1.2vw, 20px) !important;
}

/* 6) Étapes / boîtes : centrées, homogènes, pas de mélange de styles */
.dde-steps-grid {
  gap: 24px !important;
}
.dde-step,
.dde-step .elementor-widget-text-editor,
.dde-step p,
.dde-event-booking-step,
.dde-event-booking-step p,
.dde-home-service-list article,
.dde-home-services__list article {
  text-align: center !important;
}
.dde-step,
.dde-event-booking-step {
  background: #fff !important;
  border: 1px solid rgba(32,43,29,.14) !important;
  box-shadow: none !important;
}
.dde-step-number .elementor-heading-title,
.dde-about-timeline__items span {
  letter-spacing: -.035em !important;
}

/* 7) Couleurs charte : plus de marron foncé en fond, CTA final en bleu grisé */
.dde-home-host,
.dde-about-story,
.dde-event-inspiration,
.dde-hostess,
.dde-hostess-section,
.dde-page-mariage .dde-hostess {
  background: var(--dde-green, #859679) !important;
}
.dde-final,
.dde-home-final,
.dde-event-final,
.dde-static-final {
  background: var(--dde-blue-grey, #AEB9C1) !important;
  color: #fff !important;
  border-top: 1px solid rgba(255,255,255,.4) !important;
}
.dde-final h2,
.dde-home-final h2,
.dde-event-final h2,
.dde-static-final h2,
.dde-final .elementor-heading-title,
.dde-home-final .dde-home-rich p,
.dde-static-final .dde-static-rich,
.dde-static-final p {
  color: #fff !important;
}
.dde-final .elementor-button,
.dde-home-final .dde-home-btn,
.dde-event-final-cta,
.dde-static-final .dde-static-btn {
  background: var(--dde-brun, #8A7564) !important;
  color: #fff !important;
  border-color: var(--dde-brun, #8A7564) !important;
}

/* 8) Home facts : dernier bloc scindé 22 couchages | 10 chambres */
.dde-home-fact--split {
  display: grid !important;
  grid-template-columns: minmax(0,1fr) auto minmax(0,1fr) !important;
  align-items: center !important;
  gap: 18px !important;
  text-align: center !important;
}
.dde-home-fact--split .dde-home-fact__part {
  display: grid !important;
  gap: 8px !important;
  justify-items: center !important;
}
.dde-home-fact--split .dde-home-fact__divider {
  width: 1px !important;
  height: 58% !important;
  min-height: 56px !important;
  background: rgba(32,43,29,.18) !important;
  display: block !important;
}
.dde-home-fact--split strong { font-size: clamp(2.05rem, 2.45vw, 3.2rem) !important; }
.dde-home-fact--split span:not(.dde-home-fact__divider) { text-align: center !important; }

/* 9) À propos : paragraphes des timelines alignés en haut + 01. 02. 03. */
.dde-about-timeline__items article {
  align-items: start !important;
}
.dde-about-timeline__items article p {
  align-self: start !important;
  margin-top: 0 !important;
}
.dde-about-timeline__items span {
  min-width: 72px !important;
  text-align: left !important;
}

/* 10) Maison d'Hôtes : Conditions & Tarifs Gîte lisible en beige */
.dde-page-maison .dde-gite-pricing {
  background: var(--dde-green, #859679) !important;
}
.dde-page-maison .dde-gite-pricing .dde-eyebrow .elementor-heading-title,
.dde-page-maison .dde-gite-pricing .dde-h2 .elementor-heading-title,
.dde-page-maison .dde-gite-pricing > .dde-shell > .dde-eyebrow,
.dde-page-maison .dde-gite-pricing > .dde-shell > .dde-h2 h2 {
  color: var(--dde-ivory, #F8F4EA) !important;
  -webkit-text-fill-color: var(--dde-ivory, #F8F4EA) !important;
}
.dde-page-maison .dde-gite-price-card {
  background: var(--dde-ivory, #F8F4EA) !important;
}

/* 11) Accès : revenir au design sobre de la maquette, sans pictos */
.dde-access-grid,
.dde-access-grid.dde-access-grid--clean,
.dde-map-section .dde-access-grid,
.dde-event-access .dde-access-grid,
.dde-about-access .dde-access-grid,
.dde-home-access .dde-access-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0 !important;
  background: var(--dde-ivory, #F8F4EA) !important;
  border: 1px solid rgba(32,43,29,.14) !important;
  box-shadow: none !important;
  margin: 0 auto clamp(64px,7vw,104px) !important;
  padding: 0 !important;
}
.dde-access-card,
.dde-access-grid.dde-access-grid--clean .dde-access-card {
  background: var(--dde-ivory, #F8F4EA) !important;
  border: 0 !important;
  padding: clamp(34px, 4vw, 54px) clamp(26px, 4vw, 46px) !important;
  min-height: 0 !important;
  text-align: center !important;
}
.dde-access-card:not(:last-child)::after {
  content: "" !important;
  position: absolute !important;
  top: 18% !important;
  right: 0 !important;
  bottom: 18% !important;
  width: 1px !important;
  background: rgba(32,43,29,.14) !important;
  display: block !important;
}
.dde-access-icon,
.dde-access-card__head .dde-access-icon { display: none !important; }
.dde-access-card__head { display: block !important; margin: 0 !important; }
.dde-access-card h4,
.dde-access-card h4.elementor-heading-title,
.dde-access-card .elementor-heading-title {
  font-family: var(--dde-title, Marcellus, Georgia, serif) !important;
  font-size: clamp(2rem, 2.7vw, 3.15rem) !important;
  line-height: 1.06 !important;
  font-weight: 400 !important;
  color: var(--dde-green-deep, #202B1D) !important;
  margin: 0 0 18px !important;
  text-align: center !important;
  letter-spacing: -.035em !important;
  text-transform: none !important;
}
.dde-access-card p,
.dde-access-card .elementor-widget-text-editor p {
  color: #6F675E !important;
  font-size: clamp(1rem, 1.2vw, 1.2rem) !important;
  line-height: 1.52 !important;
  text-align: center !important;
  margin: 0 !important;
}

@media (max-width: 980px) {
  .dde-home-hero h1,
  .dde-about-hero h1,
  .dde-static-hero h1,
  .dde-hero h1,
  .dde-event-hero h1,
  .dde-event-hero .dde-event-h1 { font-size: clamp(2.35rem, 10vw, 3.8rem) !important; }
  .dde-access-grid,
  .dde-access-grid.dde-access-grid--clean { grid-template-columns: 1fr !important; }
  .dde-access-card:not(:last-child)::after { top:auto!important; bottom:0!important; left:10%!important; right:10%!important; width:auto!important; height:1px!important; }
}
