/* =========================================================
   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
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Marcellus&family=Manrope:wght@300;400;500;600;700;800;900&display=swap');

: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;
  }
}

/* =========================================================
   Compatibilité thème custom sans DOM Elementor complet
   ========================================================= */
body .dde-page-mariage .dde-hero::before {
  z-index: 1 !important;
}

body .dde-page-mariage .dde-hero-content {
  position: relative !important;
  z-index: 2 !important;
}

body .dde-page-mariage .dde-hero-title,
body .dde-page-mariage .dde-hero-text,
body .dde-page-mariage .dde-hero-cta {
  position: relative !important;
  z-index: 3 !important;
}

body .dde-page-mariage .dde-space-layout.reverse .dde-space-copy {
  order: 2 !important;
}

body .dde-page-mariage .dde-space-layout.reverse .dde-slider-col {
  order: 1 !important;
}

body .dde-page-mariage .dde-slider .dde-carousel,
body .dde-page-mariage .dde-slider .dde-carousel-track,
body .dde-page-mariage .dde-slider .dde-slide {
  height: 520px !important;
  min-height: 520px !important;
}

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

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

@media (max-width: 940px) {
  body .dde-page-mariage .dde-space-layout.reverse .dde-space-copy,
  body .dde-page-mariage .dde-space-layout.reverse .dde-slider-col {
    order: initial !important;
  }

  body .dde-page-mariage .dde-slider .dde-carousel,
  body .dde-page-mariage .dde-slider .dde-carousel-track,
  body .dde-page-mariage .dde-slider .dde-slide,
  body .dde-page-mariage .dde-slider img {
    height: 450px !important;
    min-height: 450px !important;
  }
}

@media (max-width: 760px) {
  body .dde-page-mariage .dde-slider .dde-carousel,
  body .dde-page-mariage .dde-slider .dde-carousel-track,
  body .dde-page-mariage .dde-slider .dde-slide,
  body .dde-page-mariage .dde-slider img {
    height: 360px !important;
    min-height: 360px !important;
  }
}


/* =========================================================
   V0.13 - Alignement formules mariage sur la maquette Elementor
   ========================================================= */
body .dde-page-mariage .dde-pricing-mariage {
  background: var(--dde-white) !important;
  padding-top: clamp(84px, 8vw, 132px) !important;
  padding-bottom: clamp(92px, 9vw, 150px) !important;
}

body .dde-page-mariage .dde-pricing-mariage > .dde-shell {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
}

body .dde-page-mariage .dde-pricing-mariage .dde-section-head {
  text-align: center !important;
  max-width: 940px !important;
  margin: 0 auto clamp(46px, 5vw, 72px) !important;
}

body .dde-page-mariage .dde-tarif-html,
body .dde-page-mariage .dde-wedding-pricing,
body .dde-page-mariage .dde-wedding-pricing__shell {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

body .dde-page-mariage .dde-wedding-pricing__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(26px, 3vw, 42px) !important;
  align-items: stretch !important;
  width: min(1080px, 100%) !important;
  margin: 0 auto !important;
}

body .dde-page-mariage .dde-wedding-card {
  position: relative !important;
  min-height: 650px !important;
  padding: clamp(42px, 4.2vw, 58px) clamp(34px, 3.5vw, 48px) 38px !important;
  background: var(--dde-white) !important;
  border: 1px solid rgba(138, 117, 100, 0.22) !important;
  box-shadow: none !important;
  display: flex !important;
  flex-direction: column !important;
  transition: background .22s ease, transform .22s ease !important;
}

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

body .dde-page-mariage .dde-wedding-card--featured {
  background: var(--dde-green) !important;
  border-color: var(--dde-green) !important;
  color: var(--dde-white) !important;
  transform: translateY(-22px) !important;
}

body .dde-page-mariage .dde-wedding-card--featured:hover {
  background: var(--dde-green) !important;
  transform: translateY(-24px) !important;
}

body .dde-page-mariage .dde-wedding-card__badge {
  position: absolute !important;
  top: -18px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  border-radius: 0 !important;
  background: var(--dde-ivory) !important;
  color: var(--dde-brun) !important;
  padding: 12px 28px !important;
  font-family: var(--dde-body) !important;
  font-size: .72rem !important;
  font-weight: 900 !important;
  letter-spacing: .22em !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  text-transform: uppercase !important;
}

body .dde-page-mariage .dde-wedding-card__content {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
  height: 100% !important;
}

body .dde-page-mariage .dde-wedding-card__kicker,
body .dde-page-mariage .dde-wedding-card__note {
  margin: 0 0 28px !important;
  padding: 0 0 28px !important;
  color: var(--dde-brun) !important;
  border-bottom: 1px solid rgba(138, 117, 100, .22) !important;
  font-family: var(--dde-body) !important;
  font-size: .72rem !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

body .dde-page-mariage .dde-wedding-card--featured .dde-wedding-card__kicker,
body .dde-page-mariage .dde-wedding-card--featured .dde-wedding-card__note {
  color: rgba(255,255,255,.88) !important;
  border-bottom-color: rgba(255,255,255,.28) !important;
}

body .dde-page-mariage .dde-wedding-card h3 {
  margin: 0 0 30px !important;
  max-width: 340px !important;
  color: var(--dde-green-deep) !important;
  font-family: var(--dde-title) !important;
  font-size: clamp(2.15rem, 3vw, 3.1rem) !important;
  font-weight: 400 !important;
  line-height: 1.08 !important;
  letter-spacing: -.04em !important;
}

body .dde-page-mariage .dde-wedding-card--featured h3,
body .dde-page-mariage .dde-wedding-card--featured li,
body .dde-page-mariage .dde-wedding-card--featured p {
  color: var(--dde-white) !important;
}

body .dde-page-mariage .dde-wedding-card ul {
  flex: 1 1 auto !important;
  margin: 0 0 34px !important;
  padding: 0 !important;
  list-style: none !important;
}

body .dde-page-mariage .dde-wedding-card li {
  position: relative !important;
  margin: 0 0 16px !important;
  padding-left: 30px !important;
  color: var(--dde-muted);
  font-family: var(--dde-body) !important;
  font-size: 1rem !important;
  line-height: 1.45 !important;
}

body .dde-page-mariage .dde-wedding-card li::before {
  content: '✓' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  color: var(--dde-green) !important;
  font-weight: 900 !important;
}

body .dde-page-mariage .dde-wedding-card--featured li::before {
  color: var(--dde-white) !important;
}

body .dde-page-mariage .dde-wedding-card__button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: auto !important;
  min-height: 48px !important;
  padding: 14px 20px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--dde-green) !important;
  color: var(--dde-white) !important;
  font-family: var(--dde-body) !important;
  font-size: .76rem !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

body .dde-page-mariage .dde-wedding-card--featured .dde-wedding-card__button {
  background: var(--dde-ivory) !important;
  color: var(--dde-green-deep) !important;
}

body .dde-page-mariage .dde-booking .dde-steps-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

@media (max-width: 980px) {
  body .dde-page-mariage .dde-wedding-pricing__grid {
    grid-template-columns: 1fr !important;
    max-width: 560px !important;
  }
  body .dde-page-mariage .dde-wedding-card,
  body .dde-page-mariage .dde-wedding-card--featured {
    min-height: auto !important;
    transform: none !important;
  }
  body .dde-page-mariage .dde-booking .dde-steps-grid {
    grid-template-columns: 1fr !important;
  }
}
/* Carte mariage mise en avant : textes ivoire doux */

.dde-wedding-card.dde-wedding-card--featured .dde-wedding-card__kicker,
.dde-wedding-card.dde-wedding-card--featured .dde-wedding-card__content,
.dde-wedding-card.dde-wedding-card--featured .dde-wedding-card__content p,
.dde-wedding-card.dde-wedding-card--featured .dde-wedding-card__content h3,
.dde-wedding-card.dde-wedding-card--featured .dde-wedding-card__note,
.dde-wedding-card.dde-wedding-card--featured ul,
.dde-wedding-card.dde-wedding-card--featured li,
.dde-wedding-card.dde-wedding-card--featured li::before,
.dde-wedding-card.dde-wedding-card--featured strong {
  color: rgba(248, 244, 234, 0.88) !important;
}


/* V36 - Mariage : hero moins sombre, étapes homogènes et centrées */
.dde-page-mariage .dde-hero::before {
  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;
}
.dde-page-mariage .dde-hero-title .elementor-heading-title {
  font-size: clamp(2.35rem,4.2vw,4.75rem) !important;
}
.dde-page-mariage .dde-step,
.dde-page-mariage .dde-step p,
.dde-page-mariage .dde-step .elementor-widget-text-editor {
  text-align:center !important;
}
.dde-page-mariage .dde-step {
  background: var(--dde-ivory,#F8F4EA) !important;
  border:1px solid rgba(31,45,30,.14) !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; }
}
