:root {
  --gold: #c2ad6a;
  --blue: #0f2440;
  --blue_berkeley: #1C3661;
  --blue_maurice: #17B6C5;
  --orange_portugal: #F1C172;
}


html {
scroll-behavior: auto !important;
}

.position_relative .e-con-inner {
position: relative !important;
}

.titre_villes h1 {
color: #fff;
text-shadow:
  0 4px 16px rgba(0,0,0,0.7),
  0 2px 4px rgba(0,0,0,0.5),
  0 1px 1.5px rgba(0,0,0,0.4);
}

.btn_nos_biens {
background-color: var(--e-global-color-892c46c);
font-family: "Raleway", Sans-serif;
font-size: 18px;
font-weight: 500;
color: var(--e-global-color-98e7680);
fill: var(--e-global-color-98e7680);
border-style: solid;
border-width: 1px 1px 1px 1px;
border-color: var(--e-global-color-892c46c);
border-radius: 99px 99px 99px 99px;
--btn-pt: 6px;
--btn-pe: 24px;
--btn-pb: 6px;
--btn-ps: 24px;
padding: 10px 24px 10px 24px;
transition: all 0.3s ease-in-out;
white-space: nowrap;
}

.btn_nos_biens:hover {
background-color: transparent;
color: var(--e-global-color-98e7680) !important;
border: 1px solid var(--e-global-color-98e7680);
box-shadow: none;
transform: none;
transition: all 0.3s ease-in-out;
}

@media (max-width: 800px) {
  .btn_nos_biens {
    font-size: 16px !important;
    padding: 8px 20px !important;
    white-space: nowrap;
  }
}

.twb {
text-wrap: balance;
& a {
  text-wrap: balance;
}
}

.twp {
text-wrap: pretty;
& a {
  text-wrap: pretty;
  &:not(.btn) {
    line-height: 1.2;
  }
}
}

.navbar-brand img {
width: 100%;
}

@media (width <= 1199px) {
.elementor .elementor-hidden-mobile {
  display: none;
}

.lqd-mobile-sec {
  padding: 20px;
  .navbar-header {
    border-radius: 20px;
  }
}
}

@media (width <= 768px) {
.lqd-mobile-sec {
  padding: 14px;
  .navbar-header {
    border-radius: 10px;
  }
}
}

#wrap {
overflow-x: clip; 
}

#lqd-contents-wrap .line {
position: relative;
:is(h1, h2, h3, h4, h5, h6) {
  margin-bottom: calc(36px * 2);
  &::before {
    content: "";
    position: absolute;
    bottom: -36px;
    width: 150px;
    height: 3px;
    background-color: #749DB4;
  }
}
&.--center {
  :is(h1, h2, h3, h4, h5, h6) {
    &::before {
      left: 50%;
      transform: translateX(-50%);
    }
  }
}
&.--blue {
  :is(h1, h2, h3, h4, h5, h6) {
    &::before {
      background-color: var(--blue);
    }
  }
  }
  &.--blue_berkeley {
    :is(h1, h2, h3, h4, h5, h6) {
      &::before {
        background-color: var(--blue_berkeley);
      }
    }
    }
  &.blue_maurice {
    :is(h1, h2, h3, h4, h5, h6) {
      &::before {
        background-color: var(--blue_maurice);
      }
    }
  }
  &.orange_portugal {
    :is(h1, h2, h3, h4, h5, h6) {
      &::before {
        background-color: var(--orange_portugal);
      }
    }
  } 
}

.multi-lines {
.elementor-widget-hub_fancy_heading {
  &::before {
    content: "";
    position: absolute;
    background-image: url(../images/icons/multi-lines.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    display: block;
    width: 100px;
    height: 100%;
    top: -100%;
    left: 50%;
    transform: translateX(-50%);
  }
}
.elementor-widget-text-editor {
  &::after {
    content: "";
    position: absolute;
    background-image: url(../images/icons/multi-lines.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    display: block;
    width: 100px;
    height: 100%;
    transform: translateX(-50%) rotate(180deg);
    bottom: -100%;
    left: 50%;
  }
}
}


header#header {
  & .menu-item {
      & a {
          position: relative;
          padding: 7px 20px !important;
          background: #749db4;
          color: #fff;
          border-radius: 30px !important;
      }
  }
} */



body .btn-solid:hover {
transform: unset;
box-shadow: unset;
}

.btn-fw {
a {
  width: 100%;
}

&.sb a {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
}

.highlight {
img {
  aspect-ratio: 4/3;
  object-fit: cover;
}

.card-content {
  .elementor-widget-ld_button {
    margin-top: auto;
  }

  .title {
    h3 {
      line-height: 1.2;
      text-wrap: pretty;
    }
  }

  .description-excerpt {
    font-family: "Raleway";
    text-align: center;
    font-size: 1rem;
    line-height: 1.2;
    color: black;
    margin-bottom: 20px;
    font-weight: 500;
  }

  .price {
    font-family: "Raleway";
    text-align: center;
    font-size: 1.5rem;
    font-weight: 500;
    color: black;
    margin-bottom: 20px;
  }
}
}

#lqd-site-content .btn-animate {
.btn-fw {
  width: 100%;
}
& div:hover {
  .btn-fw {
    animation: btn-animate 1.5s ease-out;
  }
}
}

@keyframes btn-animate {
0% {
  width: 0%;
}
100% {
  width: 100%;
}
}

.mobile-nav-activated
header#header.main-header
.lqd-mobile-sec-inner.navbar-header {
border-radius: 10px 10px 0 0;
}

[data-overlay-onmobile="false"] header#header.main-header:not(.is-stuck) {
position: absolute;
width: 100%;
}

header#header.main-header .lqd-mobile-sec {
padding-bottom: 0;
}

header#header.main-header .lqd-mobile-sec-nav {
padding-inline: 14px;

.mobile-navbar-collapse {
  padding: 10px;
  background-color: #f5f5f5;
  border-radius: 0 0 10px 10px;
  box-shadow: none;
}

#mobile-primary-nav {
  padding: 0;
  a {
    padding: 6px 10px;
    text-wrap: pretty;
  }
}
}

@media (width >= 768px) {
header#header.main-header .lqd-mobile-sec-nav {
  padding-inline: 20px;
}
}

#primary-nav {
align-items: center;
}

header#header {
.submenu-expander {
  display: flex;
  left: unset;
  right: 0;
  width: 8px;
  background-color: transparent;
  height: fit-content;
  top: 0 !important;
}
.menu-item {
  padding: 0 13px;
  @media (width <= 1200px) {
    padding: 0 16px 0 4px;
  }
  height: fit-content;

  a {
    position: relative;
    padding: 0;
    &:hover {
      &::before {
        width: 100%;
      }
    }
  }
}
}

.elementor-kit-7 label,
.elementor-kit-7 a {
font-family: "Raleway";
}

/* List style */

.list-custom {
list-style: none;
padding-left: 0;
ul {
  padding-left: 0px;
  margin: 0;
}
li {
  position: relative;
  padding-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 28px;
  gap: 12px;
  &::before {
    content: "";
    background-image: url(../images/icons/li-icon.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    top: 3px;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    display: block;
  }
  &:last-child {
    padding-bottom: 0;
  }
}
}



.list-custom-blue {
list-style: none;
padding-left: 0;
ul {
  padding-left: 0px;
  margin: 0;
}
li {
  position: relative;
  padding-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 28px;
  gap: 12px;
  &::before {
    content: "";
    background-image: url(../images/icons/li-icon-blue.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    top: 3px;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    display: block;
  }
  &:last-child {
    padding-bottom: 0;
  }
}
}



.list-custom-orange {
list-style: none;
padding-left: 0;
ul {
  padding-left: 0px;
  margin: 0;
}
li {
  position: relative;
  padding-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 28px;
  gap: 12px;
  &::before {
    content: "";
    background-image: url(../images/icons/li-icon-orange.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    top: 3px;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    display: block;
  }
  &:last-child {
    padding-bottom: 0;
  }
}
}

/* CAROUSEL */

.carousel-centered-slide {
.swiper .swiper-wrapper {
  .swiper-slide {
    transition: scale 0.3s ease-in-out;

    .e-con-inner,
    .elementor-widget-shortcode,
    .elementor-shortcode {
      height: 100%;
    }
  }
  & > :not(.swiper-slide-next) {
    scale: 0.92;
  }
}
}

.single-property-card {
position: relative;
border-radius: 20px;
overflow: hidden;
background-color: white;
height: 100%;

.property-image {
  position: relative;
  .property-status,
  .property-country {
    position: absolute;
    background-color: #ffffff80;
    padding: 2px 14px;
    border-radius: 99px;
    z-index: 1000;
    font-size: clamp(0.75rem, 0.9375vw, 0.9375rem);
  }
  .property-country {
    top: 20px;
    left: 20px;
    padding: 8px;
    svg {
      width: 20px;
      height: 20px;
      justify-content: center;
    }
  }
  .property-status {
    top: 20px;
    right: 20px;
    display: none;
  }

  img {
    max-height: 240px;
    min-height: 240px;
    width: 100%;
  }
}

.icon {
  display: flex;
  svg {
    width: 1.4em;
  }
}

.property-content {
  padding: 20px;
  display: flex;
  flex-direction: column;

  .location {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--gold);
    font-size: clamp(0.875rem, 1vw, 1.2rem);
    font-weight: 500;
    svg {
      width: 0.8em;
    }
  }

  .property-title,
  .property-price {
    font-family: "Marcellus";
    font-size: clamp(1rem, 2vw, 1.5rem);
    font-weight: 400;
    color: var(--blue);
    margin: 20px 0 10px 0;
    text-transform: uppercase;
  }

  .property-information {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;

    .property-rooms,
    .property-surface {
      color: var(--blue);
      display: flex;
      flex-direction: row;
      align-items: center;
      flex-wrap: nowrap;
      gap: 10px;
      border: 1px solid #c3c7ce;
      border-radius: 99px;
      padding: 4px 12px;
      font-size: clamp(0.875rem, 0.9375vw, 1rem);
      font-family: "Raleway";
      font-weight: 300;
    }
  }

  .property-price {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0;

    &::after {
      content: "";
      background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCA1MCA1MCI+PGNpcmNsZSBjeD0iMjUiIGN5PSIyNSIgcj0iMjUiIGZpbGw9IiNjMmFlNmIiLz48cGF0aCBmaWxsPSIjZmZmIiBkPSJNMTMgMjQuN2EuNi42IDAgMSAwIDAgMS4yem0xMyAxMC41YS42LjYgMCAwIDAgLjguOWwtLjQtLjV6bTEwLjUtOS45LjUuNC40LS40LS40LS40em0tOS43LTEwLjdhLjYuNiAwIDEgMC0uOC44bC40LS40ek0xMyAyNS4zdi42aDIzLjd2LTEuMkgxM3ptMTMuNCAxMC4zLjQuNUwzNyAyNS43bC0uNS0uNC0uNC0uNEwyNiAzNS4yem0xMC4xLTEwLjMuNS0uNC0xMC4yLTEwLjMtLjQuNC0uNC40IDEwIDEwLjN6Ii8+PC9zdmc+);
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center;
      width: 1.85em;
      height: 1.85em;
      margin-left: 10px;
      display: block;
      transition: transform 0.3s ease-in-out;
    }
  }
}
.absolute-link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
}
}


.single-property-card:hover {
& .property-content {
    & .property-price {
        &::after {
            content: "";
            transform: rotate(-45deg);
            transition: transform 0.3s ease-in-out;
        }
    }
}
}

.form_maurice .submit-wrap {
text-align: center;

& .wpcf7-submit {
  background-color: #133564 !important;
  &:hover {
      background-color: #133564 !important;
      color: #F1C172 !important;
      border: 1px solid #F1C172 !important;
  }
}
}

.form_portugal .submit-wrap {
text-align: center;

& .wpcf7-submit {
  &:hover {
      background-color: #fff !important;
      color: #F1C172 !important;
      border: 1px solid #fff !important;
  }
}
}


.scroll-padding-top .e-con-inner div {
scroll-margin-top: 116px;
}

.card-anchor {
.elementor-widget-heading {
  display: flex;
  height: 100%;
}
img {
  height: unset;
  aspect-ratio: 386/362;
  object-fit: cover;
}
}

.scroll-padding-top .elementor-widget-ld_fancy_image.h-100 {
height: 100%;
* {
  height: 100%;
}
img {
  object-fit: cover;
}
}

.carousel-anchor .arrow-icon {
p {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  position: relative;
  width: 100%;
}
p::after {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCA1MCA1MCI+PGNpcmNsZSBjeD0iMjUiIGN5PSIyNSIgcj0iMjUiIGZpbGw9IiNjMmFlNmIiLz48cGF0aCBmaWxsPSIjZmZmIiBkPSJNMTMgMjQuN2EuNi42IDAgMSAwIDAgMS4yem0xMyAxMC41YS42LjYgMCAwIDAgLjguOWwtLjQtLjV6bTEwLjUtOS45LjUuNC40LS40LS40LS40em0tOS43LTEwLjdhLjYuNiAwIDEgMC0uOC44bC40LS40ek0xMyAyNS4zdi42aDIzLjd2LTEuMkgxM3ptMTMuNCAxMC4zLjQuNUwzNyAyNS43bC0uNS0uNC0uNC0uNEwyNiAzNS4yem0xMC4xLTEwLjMuNS0uNC0xMC4yLTEwLjMtLjQuNC0uNC40IDEwIDEwLjN6Ii8+PC9zdmc+);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 1.6em;
  height: 1.6em;
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
}
}

.swiper-pagination-bullet:not(.swiper-pagination-bullet-active) {
opacity: 1;
background-color: white;
}
.swiper-pagination-bullet {
transition: background-color 0.3s ease-in-out;

&:hover {
  background-color: var(--gold) !important;
  opacity: 0.5;
}
}

footer {
.separeted .reset-ul .menu-item:not(:last-child) {
  border-right: 1px solid white;
  padding-right: 14px;
}

.separator p {
  border-right: 1px solid white;
  border-left: 1px solid white;
  padding: 0 14px;
}

.wrapper-newsletter {
  * {
    font-size: 1.25rem;
    line-height: 1.2;
  }

  .wpcf7-checkbox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    .wpcf7-list-item {
      margin: 0;

      label {
        display: flex;
        align-items: center;
        gap: 6px;

        input[type="checkbox"] {
          zoom: 1.7;
          border: none !important;
          background-color: transparent !important;

          &:checked {
            &[value="Île Maurice"] {
              accent-color: turquoise;
            }

            &[value="Portugal"] {
              accent-color: orange;
            }
          }
        }

        span {
          padding-left: 0;
        }
      }
    }
  }
  .wpcf7-list-item {
    margin: 0;
  }

  .wpcf7-acceptance .wpcf7-list-item-label:before,
  .wpcf7-acceptance .wpcf7-list-item-label:after {
    width: 1.2rem;
    height: 1.2rem;
    top: 0;
    margin-top: 4px;
  }

  .wpcf7-acceptance {
    .wpcf7-list-item-label {
      padding-inline-start: 2rem;
    }
  }

  .container-newsletter {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 8px;

    input {
      border-radius: 99px;
      padding-inline: 24px;
      color: var(--blue);
      font-family: "Raleway";
    }

    .wpcf7-form-control-wrap {
      margin-bottom: 0;
    }
  }
}
}

.check-list {
ul {
  display: flex;
  flex-direction: column;
  padding: 0;
  padding-left: 20px;
  margin-top: 20px !important;
  li {
    padding-left: 8px;
    width: fit-content;
    margin-bottom: 16px;
  }
  li::marker {
    content: "✓";
    color: var(--gold);
    font-size: 1.2em;
    font-weight: 600;
  }
}
}

.persta-number {
width: 70px;
height: 70px;
display: flex;
align-items: center;
justify-content: center;
}

/* FROM */

.form_maurice .lqd-contact-form {
label {
    color:#fff;
}

span.wpcf7-list-item-label {
  flex: 1 1 100%;
  width: 100%;
}
}

.form_portugal .lqd-contact-form {
label {
    color:#0F2440;
}

span.wpcf7-list-item-label {
  flex: 1 1 100%;
  width: 100%;
}
}

#lqd-site-content .lqd-contact-form {
.form-wrapper{
  display: flex;
  flex-direction: column;
  gap: 12px;
}
br {
  display: none;
}
.one-line{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  p {
    flex:1;
  }
}

input, .ui-selectmenu-button {
  height: unset;
  padding: 8px 14px;
}

label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0;
  @media (width <= 768px) {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 4px;
  }

  .wpcf7-checkbox{
    .first{
      margin-right: 30px;
    }
  }

  input[type="checkbox"]{
    width: 20px;
    height: 20px;
    margin: 0;
  }

  span {
    flex: 0 1 74%;
    margin: 0;
    
    @media (width <= 768px) {
      flex: 1 1 100%;
      width: 100%;
      & .ui-selectmenu-icon:after{
        justify-content: flex-end;
      }
    }
  }
}

label span.wpcf7-checkbox label{
  @media (width <= 768px) {
    flex-direction: row;
  
  }
}
.checkbox-wrap {
  flex: 0 1 100% !important;

  span, .wpcf7-form-control-wrap {  
    flex: 0 1 100% !important;
  }

  label {
    justify-content: flex-start;
    gap: 10px;
  }
}
.wpcf7-form-control-wrap {
  margin-bottom: 0;
}

.wpcf7-submit{
  border-radius: 99px;
  padding: 10px 20px;
  background-color: var(--gold);
  color: white;
  text-transform: none;
  font-family: "Raleway";
  font-size: 1.2rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--gold);
  &:hover{
    background-color: transparent;
    color: var(--gold);
    border: 1px solid var(--gold);
    box-shadow: none;
    transform: none;
}
}
}


/* ============================================
 FORMULAIRE CONTACT
 ============================================ */

/* --- Champs : fond blanc, texte noir, bordure grise --- */
#lqd-site-content .lqd-contact-form input[type="text"],
#lqd-site-content .lqd-contact-form input[type="email"],
#lqd-site-content .lqd-contact-form input[type="tel"],
#lqd-site-content .lqd-contact-form textarea,
#lqd-site-content .lqd-contact-form select,
#lqd-site-content .lqd-contact-form .ui-selectmenu-button {
background-color: #ffffff !important;
color: #111111 !important;
border: 1px solid #d0d0d0 !important;
border-radius: 8px !important;
}

#lqd-site-content .lqd-contact-form input::placeholder,
#lqd-site-content .lqd-contact-form textarea::placeholder {
color: #888888 !important;
}

/* --- Select natif : chevron doré + options lisibles --- */
#lqd-site-content .lqd-contact-form select {
appearance: none;
-webkit-appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23c2ae6b' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") !important;
background-repeat: no-repeat !important;
background-position: right 14px center !important;
padding-right: 36px !important;
cursor: pointer;
width: 100%;
}

#lqd-site-content .lqd-contact-form select option {
background-color: #ffffff !important;
color: #111111 !important;
}

/* --- CF7 : masque les messages d'erreur pendant la saisie,
 les affiche uniquement après une tentative d'envoi échouée --- */
#lqd-site-content .lqd-contact-form .wpcf7-not-valid-tip {
display: none !important;
}

#lqd-site-content .lqd-contact-form .wpcf7-form.invalid .wpcf7-not-valid-tip,
#lqd-site-content .lqd-contact-form .wpcf7-form.unaccepted .wpcf7-not-valid-tip {
display: block !important;
}

/* --- Checkboxes --- */
#lqd-site-content .lqd-contact-form input[type="checkbox"] {
width: 20px !important;
height: 20px !important;
min-width: 20px;
cursor: pointer;
}

#lqd-site-content .lqd-contact-form .wpcf7-checkbox input[type="checkbox"][value="Ile Maurice"]:checked,
#lqd-site-content .lqd-contact-form .wpcf7-checkbox input[type="checkbox"][value="Île Maurice"]:checked {
accent-color: var(--blue_maurice, #17B6C5) !important;
}

#lqd-site-content .lqd-contact-form .wpcf7-checkbox input[type="checkbox"][value="Portugal"]:checked {
accent-color: var(--orange_portugal, #F1C172) !important;
}

/* --- Région grisée (activée via JS si pays = France) --- */
#lqd-site-content .lqd-contact-form #select-region,
#lqd-site-content .lqd-contact-form #select-region-button {
opacity: 0.4;
pointer-events: none !important;
cursor: not-allowed !important;
transition: opacity 0.2s;
}

#lqd-site-content .lqd-contact-form #select-region.region-active,
#lqd-site-content .lqd-contact-form #select-region.region-active ~ div .ui-selectmenu-button,
#lqd-site-content .lqd-contact-form #select-region-button.region-active {
opacity: 1;
pointer-events: auto !important;
cursor: pointer !important;
background-color: #ffffff !important;
}

/* --- Plugin téléphone (intl-tel-input) --- */
#lqd-site-content .lqd-contact-form .intl-tel-input {
display: block !important;
width: 100% !important;
position: relative !important;
}

#lqd-site-content .lqd-contact-form .intl-tel-input input[type="text"] {
padding-left: 90px !important;
width: 100% !important;
}

#lqd-site-content .lqd-contact-form .intl-tel-input .selected-flag {
background-color: #ffffff !important;
border-right: 1px solid #d0d0d0;
}

/* Dropdown liste pays téléphone — doit passer au-dessus de tout */
#lqd-site-content .lqd-contact-form .intl-tel-input .country-list {
z-index: 9999 !important;
position: absolute !important;
background-color: #ffffff !important;
color: #111111 !important;
max-height: 200px;
overflow-y: auto;
}

/* --- Plugin pays (country-select) --- */
#lqd-site-content .lqd-contact-form .country-select {
display: block !important;
width: 100% !important;
}

#lqd-site-content .lqd-contact-form .country-select input[type="text"] {
padding-left: 50px !important;
width: 100% !important;
}

#lqd-site-content .lqd-contact-form .country-select .flag-dropdown {
background-color: #ffffff !important;
}

/* --- Groupes checkbox (Projet d'achat / Objectif) --- */
#lqd-site-content .lqd-contact-form .label-group {
display: flex;
flex-direction: column;
gap: 6px;
margin: 0;
}

#lqd-site-content .lqd-contact-form .label-group > p {
display: flex;
flex-direction: column;
gap: 6px;
width: 100%;
margin: 0;
}

#lqd-site-content .lqd-contact-form .label-group > p > span:first-child {
color: #ffffff !important;
font-family: "Raleway";
font-size: 1rem;
font-weight: 500;
}

/* Projet d'achat + Objectif d'achat côte à côte */
#lqd-site-content .lqd-contact-form .label-groups-line {
display: flex;
gap: 10px;
width: 100%;
}

#lqd-site-content .lqd-contact-form .label-groups-line .label-group {
flex: 1;
}

/* --- one-line : 2 champs côte à côte
   CF7 génère un <p> englobant → c'est lui qu'on passe en flex --- */
#lqd-site-content .lqd-contact-form .one-line > p {
display: flex;
gap: 10px;
width: 100%;
margin: 0;
}

#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap {
flex: 1;
min-width: 0;
}

#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap input,
#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap .ui-selectmenu-button,
#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap .country-select,
#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap .intl-tel-input {
width: 100% !important;
}

/* CF7 insère un <br> entre les champs — on le masque */
#lqd-site-content .lqd-contact-form .one-line > p > br {
display: none !important;
}

/* --- Responsive --- */
@media (width <= 768px) {
#lqd-site-content .lqd-contact-form .one-line > p,
#lqd-site-content .lqd-contact-form .label-groups-line {
  flex-direction: column;
}

#lqd-site-content .lqd-contact-form .one-line > p > .wpcf7-form-control-wrap {
  width: 100%;
}
}

/* MAPPLIC */

.mapplic-shape .mapplic-highlight {
path{
  fill: var(--blue);
}
}


/* ============================================
   CF7 — MESSAGES DE RÉPONSE
   ============================================ */

   .wpcf7-response-output {
    margin: 16px 0 0 !important;
    padding: 14px 20px !important;
    border-radius: 10px !important;
    font-family: "Raleway", sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    border: none !important;
  }
  
  /* ✅ Succès */
  .wpcf7-form.sent .wpcf7-response-output {
    background-color: #e8f5e9 !important;
    color: #2e7d32 !important;
    border-left: 4px solid #2e7d32 !important;
  }
  
  /* ❌ Erreur de validation */
  .wpcf7-form.invalid .wpcf7-response-output,
  .wpcf7-form.unaccepted .wpcf7-response-output {
    background-color: #fff5f5 !important;
    color: #c0392b !important;
    border-left: 4px solid #c0392b !important;
  }
  
  /* ⚠️ Spam / échec envoi */
  .wpcf7-form.spam .wpcf7-response-output,
  .wpcf7-form.failed .wpcf7-response-output {
    background-color: #fff8e1 !important;
    color: #856404 !important;
    border-left: 4px solid var(--gold) !important;
  }
  
  /* Champs invalides — tip sous le champ */
  .wpcf7-not-valid-tip {
    color: #c0392b !important;
    font-size: 12px !important;
    font-family: "Raleway", sans-serif !important;
    margin-top: 4px !important;
  }





/* Liste actualites */

.post_domidylle {
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
}





/* ============================================
 FILTRES
 ============================================ */

 .domidylle_filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 20px 0 30px;
}

.domidylle_filter .facet-wrap {
  flex: 1;
  min-width: 160px;
}

.domidylle_filter .facetwp-dropdown {
  width: 100%;
  padding: 10px 36px 10px 16px;
  border: 1.5px solid #c2ae6b;
  border-radius: 30px;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23c2ae6b' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  appearance: none;
  -webkit-appearance: none;
  font-size: 14px;
  color: #333;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}

.domidylle_filter .facetwp-dropdown:hover,
.domidylle_filter .facetwp-dropdown:focus {
  border-color: #a8943d;
  box-shadow: 0 0 0 3px rgba(194, 174, 107, 0.15);
}

.domidylle_filter .elementor-button {
  padding: 10px 24px;
  background-color: #c2ae6b;
  color: #fff !important;
  border: none;
  border-radius: 30px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s, transform 0.1s;
  white-space: nowrap;
  text-decoration: none;
}

.domidylle_filter .elementor-button:hover {
  background-color: #a8943d;
  transform: translateY(-1px);
}


/* ============================================
 GRILLE DES CARDS  (listing uniquement)
 ============================================ */

.domidylle_listing .row {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 0 -12px;
}

.domidylle_listing .col-xs-6.col-md-3 {
  padding: 12px;
  display: flex;
}


/* ============================================
 CARD — tous les styles scopés sous .domidylle_listing
 ============================================ */

.domidylle_listing .single-property-card {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.08);
  transition: box-shadow 0.25s, transform 0.25s;
}

.domidylle_listing .single-property-card:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.14);
  transform: translateY(-4px);
}

/* Image */
.domidylle_listing .single-property-card .property-image {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f0ece0;
}

.domidylle_listing .single-property-card .property-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}

.domidylle_listing .single-property-card:hover .property-image img {
  transform: scale(1.04);
}

/* Badge statut */
.domidylle_listing .single-property-card .property-status {
  position: absolute;
  top: 12px;
  right: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(4px);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  color: #333;
}

.domidylle_listing .single-property-card .property-status .icon {
  font-size: 11px;
  color: #c2ae6b;
}


/* Contenu */
.domidylle_listing .single-property-card .property-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 16px;
  gap: 10px;
}

/* Localisation */
.domidylle_listing .single-property-card .location {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #c2ae6b;
  font-size: clamp(0.875rem, 1vw, 1.2rem);
}

.domidylle_listing .single-property-card .location svg {
  width: 13px;
  height: 17px;
  flex-shrink: 0;
}

/* Titre */
.domidylle_listing .single-property-card .property-title {
font-family: "Marcellus";
font-size: clamp(1rem, 2vw, 1.3rem);
font-weight: 400;
color: var(--blue);
margin: 20px 0 10px 0;
text-transform: uppercase;
}

/* Informations (chambres + surface) */
.domidylle_listing .single-property-card .property-information {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

.domidylle_listing .single-property-card .property-rooms,
.domidylle_listing .single-property-card .property-surface {
  display: flex;
  align-items: center;
  gap: 6px;
  border: 1.5px solid #e0d9c8;
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 13px;
  color: var(--blue);
}

.domidylle_listing .single-property-card .property-rooms svg,
.domidylle_listing .single-property-card .property-surface svg {
  width: 16px;
  height: 16px;
  color: var(--blue);
  flex-shrink: 0;
}

/* Prix + flèche */
.domidylle_listing .single-property-card .property-price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 10px;
  border-top: 1px solid #f0ece0;
}

.domidylle_listing .single-property-card .property-price .text {
font-family: "Marcellus";
font-size: clamp(1rem, 2vw, 1.5rem);
font-weight: 400;
color: var(--blue);
margin: 20px 0 10px 0;
text-transform: uppercase;
}

/* Flèche */
.domidylle_listing .single-property-card .property-price::after {
content: "";
background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCA1MCA1MCI+PGNpcmNsZSBjeD0iMjUiIGN5PSIyNSIgcj0iMjUiIGZpbGw9IiNjMmFlNmIiLz48cGF0aCBmaWxsPSIjZmZmIiBkPSJNMTMgMjQuN2EuNi42IDAgMSAwIDAgMS4yem0xMyAxMC41YS42LjYgMCAwIDAgLjguOWwtLjQtLjV6bTEwLjUtOS45LjUuNC40LS40LS40LS40em0tOS43LTEwLjdhLjYuNiAwIDEgMC0uOC44bC40LS40ek0xMyAyNS4zdi42aDIzLjd2LTEuMkgxM3ptMTMuNCAxMC4zLjQuNUwzNyAyNS43bC0uNS0uNC0uNC0uNEwyNiAzNS4yem0xMC4xLTEwLjMuNS0uNC0xMC4yLTEwLjMtLjQuNC0uNC40IDEwIDEwLjN6Ii8+PC9zdmc+);
background-size: contain;
background-repeat: no-repeat;
background-position: center;
width: 1.85em;
height: 1.85em;
margin-left: 10px;
display: block;
transition: transform 0.3s ease-in-out;
}


/* Lien absolu */
.domidylle_listing .single-property-card .property-link.absolute-link {
  position: absolute;
  inset: 0;
  z-index: 10;
}

.facetwp-facet-pagination a {
  color: #0f2440;
}

.facetwp-facet-pagination a.active {
  color: #0f2440;
}


/* ============================================
 RESPONSIVE
 ============================================ */

@media (max-width: 991px) {
  .domidylle_filter .facet-wrap {
      min-width: 140px;
  }
}

@media (max-width: 767px) {
  .domidylle_filter {
      flex-direction: column;
      align-items: stretch;
  }

  .domidylle_filter .facet-wrap {
      width: 100%;
  }

  .domidylle_filter .elementor-button {
      width: 100%;
      text-align: center;
  }

  .domidylle_listing .col-xs-6.col-md-3 {
      width: 50%;
  }

  .domidylle_listing .single-property-card .property-title {
      font-size: 13px;
  }

  .domidylle_listing .single-property-card .property-price .text {
      font-size: 16px;
  }
}

@media (max-width: 480px) {
  .domidylle_listing .col-xs-6.col-md-3 {
      width: 100%;
  }
}


/* ============================================
 PAGE IMMOBILIER - PAGE SINGLE
 ============================================ */

 .single-immobilier .di-split__txt .btn {
  background-color: var(--e-global-color-892c46c);
  font-family: "Raleway", Sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: #FFFFFF;
  fill: #FFFFFF;
  border-style: solid;
  border-width: 1px 1px 1px 1px;
  border-color: var(--e-global-color-892c46c);
  border-radius: 99px 99px 99px 99px;
  --btn-pt: 6px;
  --btn-pe: 24px;
  --btn-pb: 6px;
  --btn-ps: 24px;
  padding: 6px 24px 6px 24px;
}
.single-immobilier .di-split__txt .btn .btn-txt {
  margin-left: 10px;
}
.single-immobilier .di-split__txt .btn:hover,
.single-immobilier .di-split__txt .btn:focus {
  background-color: #fff;
  color: var(--e-global-color-892c46c);
  border-color: var(--e-global-color-892c46c);
  fill: var(--e-global-color-892c46c);
  transition: background 0.2s, color 0.2s;
}





/* ============================================
   FORMULES — HAUTEURS ÉGALES
   ============================================ */

/* Conteneur parent : colonnes à hauteur égale */
.elementor-element-07c63a5 > .e-con-inner {
  align-items: stretch !important;
}

/* Les 2 colonnes principales en flex-column */
.elementor-element-2be71bc,
.elementor-element-4bffee4 {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

.elementor-element-2be71bc > .e-con-inner,
.elementor-element-4bffee4 > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

/* GAUCHE — formule-col s'étire */
.elementor-element-20be1be {
  flex: 1 !important;
}

.elementor-element-20be1be > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

/* DROITE — niveaux intermédiaires */
.elementor-element-87bfe95,
.elementor-element-fcc229e {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

.elementor-element-87bfe95 > .e-con-inner,
.elementor-element-fcc229e > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

/* Les 2 blocs blancs s'étirent */
.elementor-element-424370a,
.elementor-element-8d8e68b {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

.elementor-element-424370a > .e-con-inner,
.elementor-element-8d8e68b > .e-con-inner {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Liste check-list flexible → bouton poussé en bas */
.elementor-element-39c5a8a,
.elementor-element-64a00cf {
  flex: 1 !important;
}

.elementor-element-684fdd6,
.elementor-element-08b5e7c {
  margin-top: auto !important;
}

/* Mobile : tout revient à la normale */
@media (max-width: 768px) {
  .elementor-element-2be71bc,
  .elementor-element-4bffee4,
  .elementor-element-20be1be,
  .elementor-element-87bfe95,
  .elementor-element-fcc229e,
  .elementor-element-424370a,
  .elementor-element-8d8e68b {
    height: auto !important;
    flex: unset !important;
  }

  .elementor-element-684fdd6,
  .elementor-element-08b5e7c {
    margin-top: 24px !important;
  }
}





/* ============================================
  PAGE SECONDAIRE
   ============================================ */


   @media (max-width: 767px) {
     .background_mobile {
       background-image: none !important;

       .background_mobile_content {
         background: none !important;

         h1, p {
          color: #fff !important;
         }
       }
     }
   }
