@charset "UTF-8";
/* Variables de couleurs */
:root {
  --catalog-primary: #12AA77;
  --catalog-secondary: #EFF8F5;
  --catalog-tertiary: #495965;
  --catalog-grey: #959EA2;
  --catalog-black: #0F1113;
  --catalog-white: #FFFFFF;
  --catalog-border-light: #CADFD7;
  --catalog-text-grey: #616161;
  --catalog-bg-light: #FFF9F5;
  --catalog-light-grey: #D9E1DE;
  --catalog-light-grey2: #D9E1DE;
  --catalog-agent-bg: #EFF8F5;
  --catalog-agent-text: #0F1113;
  --catalog-agent-link: #12AA77;
  --catalog-border-radius-listing: 8px;
  --catalog-border-radius-detail: 8px;
  --catalog-border-radius-tags: 20px;
  --catalog-tag-listing-bg: #12AA77;
  --catalog-tag-listing-color: #FFFFFF;
  --catalog-tag-detail-bg: #EFF8F5;
  --catalog-tag-detail-color: #0F1113;
}

/* ================================
 * @CONSTANTS
 * ================================
 * Liste des variables dont la valeur
 * ne changera jamais au fil du projet.
 * ================================ */
/* ================================
 * @CONSTANTS
 * ================================
 * Liste des variables dont la valeur
 * ne changera jamais au fil du projet.
 * ================================ */
/* ================================
 * @MIXINS
 * ================================
 * Permet de créer des fonctions.
 * Si leur condition est vraie, elles
 * incluent ce qui se trouve entre { }.
 * Usage: @include mymixin($param) { ... }
 *        ou $mystring : mymixin($param);
 * ================================ */
/* ================================
 * @PLACEHOLDERS
 * ================================
 * Permet de prédéfinir des blocs de styles
 * et de les inclure dans des selecteurs avec @extend.
 * Usage: @extend %myplaceholder;
 *
 * Documentation: http://thesassway.com/intermediate/understanding-placeholder-selectors
 * ================================ */
/**
 * Styles pour le module catalogue immobilier
 * Basé sur le design Figma
 */
/* Components */
/**
 * Styles globaux pour le module catalogue immobilier
 * Breadcrumbs, filtres, pagination, modale de contact
 */
/* Breadcrumbs */
.catalog-immo-breadcrumbs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
  margin-bottom: 20px;
  font-family: "Inter", sans-serif;
  font-size: 14px;
}
.catalog-immo-breadcrumbs-item {
  color: var(--catalog-tertiary);
  text-decoration: none;
}
.catalog-immo-breadcrumbs-item-active {
  color: var(--catalog-black);
  font-weight: 600;
}
.catalog-immo-breadcrumbs-separator {
  color: var(--catalog-tertiary);
  font-size: 18px;
}

/* Filtres */
.catalog-immo-filters {
  margin-bottom: 48px;
}
.catalog-immo-filters-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .catalog-immo-filters-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
}
.catalog-immo-filters .uk-select:not([multiple]):not([size]):invalid {
  color: rgba(var(--c-text-input-focus), 0.5) !important;
}

.catalog-immo-filter-label {
  font-family: var(--paragraphtyponame), sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--catalog-black);
  line-height: 1.3;
}
.catalog-immo-filter-label.tags {
  opacity: 0.4;
}

.catalog-immo-filter-input-wrapper,
.catalog-immo-filter-select-wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.catalog-immo-filter-input-wrapper-autocomplete {
  position: relative;
}

.catalog-immo-filter-input,
.catalog-immo-filter-select {
  display: block;
}

.catalog-immo-filter-input-autocomplete {
  padding-right: 40px;
}

.catalog-immo-filter-icon,
.catalog-immo-filter-arrow {
  position: absolute;
  right: 12px;
  pointer-events: none;
}

.catalog-immo-filter-icon {
  width: 18px;
  height: 18px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.catalog-immo-filter-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding-right: 40px;
}

/* Autocomplete suggestions */
.catalog-immo-autocomplete-suggestions {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--catalog-white);
  border: 1px solid var(--catalog-grey);
  border-top: none;
  max-height: 300px;
  overflow-y: auto;
  z-index: 1000;
  margin-top: -1px;
  -webkit-box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.catalog-immo-autocomplete-suggestions-item {
  padding: 10px 12px;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  color: var(--catalog-black);
  cursor: pointer;
  border-bottom: 1px solid var(--catalog-light-grey);
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.catalog-immo-autocomplete-suggestions-item:hover {
  background-color: var(--catalog-secondary);
}
.catalog-immo-autocomplete-suggestions-item:last-child {
  border-bottom: none;
}

/* Boutons vue liste/carte */
.catalog-immo-view-toggle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0;
}
@media screen and (max-width: 768px) {
  .catalog-immo-view-toggle {
    width: 100%;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

.catalog-immo-view-button {
  width: 42px;
  height: 42px;
  border: 2px solid var(--catalog-primary);
  background: var(--catalog-white);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  padding: 9px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.catalog-immo-view-button:first-child {
  border-right: none;
}
.catalog-immo-view-button:hover {
  background: var(--catalog-secondary);
}
.catalog-immo-view-button-active {
  background: var(--catalog-primary);
  border-color: var(--catalog-primary);
}
.catalog-immo-view-button-active:hover {
  background: var(--catalog-primary);
}

/* Couleur du bouton carte (modificateur sur le parent) */
.catalog-immo-view-toggle--primary .catalog-immo-view-button:not(.catalog-immo-view-button-active) svg {
  fill: var(--catalog-primary, #12aa77);
}

.catalog-immo-view-toggle--secondary .catalog-immo-view-button:not(.catalog-immo-view-button-active) {
  border-color: var(--catalog-secondary-color, #666);
}
.catalog-immo-view-toggle--secondary .catalog-immo-view-button:not(.catalog-immo-view-button-active) svg {
  fill: var(--catalog-secondary-color, #666);
}

.catalog-immo-view-toggle--default .catalog-immo-view-button:not(.catalog-immo-view-button-active) {
  border-color: var(--catalog-tertiary, #333);
}
.catalog-immo-view-toggle--default .catalog-immo-view-button:not(.catalog-immo-view-button-active) svg {
  fill: var(--catalog-tertiary, #333);
}

.catalog-immo-filter-reset-wrapper {
  margin-top: 10px !important;
  font-size: 14px;
}

/* Tags des filtres sélectionnés */
.catalog-immo-filter-tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-top: 0px;
}

.catalog-immo-filter-tag {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 6px 12px;
  background: var(--catalog-tag-listing-bg, var(--catalog-primary));
  color: var(--catalog-tag-listing-color, var(--catalog-white));
  border-radius: var(--catalog-border-radius-tags, 20px);
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
  position: relative;
  margin-right: 8px;
}
@media screen and (max-width: 1199px) {
  .catalog-immo-filter-tag {
    margin-top: 8px;
    margin-bottom: 0px;
  }
}
.catalog-immo-filter-tag::after {
  content: "×";
  margin-left: 6px;
  font-size: 18px;
  font-weight: bold;
  opacity: 0.8;
}
.catalog-immo-filter-tag:hover {
  -webkit-filter: brightness(0.9);
          filter: brightness(0.9);
}
.catalog-immo-filter-tag:hover::before {
  opacity: 1;
}

/* Pagination */
.catalog-immo-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
  margin-top: 32px;
  font-family: "Inter", sans-serif;
  font-size: 14px;
}
.catalog-immo-pagination-link {
  color: var(--catalog-primary);
  text-decoration: none;
  font-weight: 600;
}
.catalog-immo-pagination-link:hover {
  text-decoration: underline;
}
.catalog-immo-pagination-info {
  color: var(--catalog-tertiary);
}

/* ============================================
   Modale de contact
   ============================================ */
#estate-contact-modal .uk-modal-dialog {
  max-width: 600px;
  padding: 44px 32px;
  -webkit-box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.25);
          box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 768px) {
  #estate-contact-modal .uk-modal-dialog {
    padding: 32px 20px;
  }
}
#estate-contact-modal .uk-modal-title {
  font-family: "Inter", sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.2;
  color: #111111;
  margin-bottom: 32px;
  padding-right: 40px;
  position: relative;
}

.estate-contact-summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid #CADFD7;
}
@media screen and (max-width: 768px) {
  .estate-contact-summary {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.estate-contact-summary-image {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 127.811px;
  height: 96px;
  overflow: hidden;
  border-radius: 4px;
}
@media screen and (max-width: 768px) {
  .estate-contact-summary-image {
    width: 100%;
    height: 200px;
  }
}
.estate-contact-summary-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.estate-contact-summary-info {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2px;
  padding-left: 10px;
  padding-right: 24px;
}
.estate-contact-summary-title {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  color: #0F1113;
}
.estate-contact-summary-price {
  font-family: "Inter", sans-serif;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.3;
  color: #0F1113;
}
.estate-contact-summary-location {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: #0F1113;
}

.estate-contact-form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 15px;
}
.estate-contact-form-label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  color: #0F1113;
  margin-bottom: 4px;
}
.estate-contact-form-required {
  color: #FF3153;
}
.estate-contact-form .uk-input,
.estate-contact-form .uk-textarea {
  border: 1px solid #959EA2;
  border-radius: 4px;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  color: #0F1113;
  padding: 12px;
  height: 42px;
}
.estate-contact-form .uk-input::-webkit-input-placeholder, .estate-contact-form .uk-textarea::-webkit-input-placeholder {
  color: #959EA2;
}
.estate-contact-form .uk-input::-moz-placeholder, .estate-contact-form .uk-textarea::-moz-placeholder {
  color: #959EA2;
}
.estate-contact-form .uk-input:-ms-input-placeholder, .estate-contact-form .uk-textarea:-ms-input-placeholder {
  color: #959EA2;
}
.estate-contact-form .uk-input::-ms-input-placeholder, .estate-contact-form .uk-textarea::-ms-input-placeholder {
  color: #959EA2;
}
.estate-contact-form .uk-input::placeholder,
.estate-contact-form .uk-textarea::placeholder {
  color: #959EA2;
}
.estate-contact-form .uk-textarea {
  height: 214px;
  resize: none;
}
.estate-contact-form-char-count {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: #495965;
  margin-top: 6px;
}
.estate-contact-form-checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  color: #0F1113;
  cursor: pointer;
}
.estate-contact-form-checkbox .uk-checkbox {
  border-radius: 0;
  margin-top: 4px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.estate-contact-form-submit {
  background: var(--catalog-primary);
  color: var(--catalog-white);
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.28px;
  text-transform: uppercase;
  padding: 16px 24px;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  -ms-flex-item-align: start;
      align-self: flex-start;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
}
.estate-contact-form-success {
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .estate-contact-form .uk-grid-small {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .estate-contact-form .uk-grid-small > * {
    width: 100% !important;
  }
}

a[show-hidden] {
  text-decoration: underline;
}

/* Pages */
/**
 * Styles pour la page de listing du catalogue immobilier
 * Grille des biens, cartes de biens, filtres (barre ou modal selon breakpoint)
 */
/* Filtres : barre (>= l) vs modal full width (max-screen l) */
.catalog-immo-filters-modal-trigger-wrapper {
  display: none;
}

@media screen and (max-width: 1199px) {
  .catalog-immo-filters-form-slot {
    display: none !important;
  }
  .catalog-immo-filters-modal-trigger-wrapper {
    display: block !important;
  }
}
@media screen and (min-width: 1200px) {
  .catalog-immo-filters-modal-trigger-wrapper {
    display: none !important;
  }
}
/* Tags : sous Commune (< 1200px) ou en fin de barre (>= 1200px) */
@media screen and (max-width: 1199px) {
  .catalog-immo-filter-tags-slot-end {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .catalog-immo-filter-tags-slot-below-commune {
    display: none;
  }
}
.catalog-immo-filter-tags {
  display: none;
}
.catalog-immo-filter-tags:has(*) {
  display: block;
}

.catalog-immo-listing-result {
  position: relative;
  min-height: 80px;
}
.catalog-immo-listing-result.catalog-immo-listing-loading {
  opacity: 0.6;
  pointer-events: none;
}

.catalog-immo-estates-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 30px 1fr 30px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 32px;
}
@media screen and (max-width: 1199px) {
  .catalog-immo-estates-grid {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .catalog-immo-estates-grid {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}

.catalog-immo-no-results {
  grid-column: 1/-1;
  text-align: center;
  padding: 40px 20px;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  color: var(--catalog-tertiary);
}

/* Card de bien */
.estate-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background: var(--catalog-white);
  border: 1px solid var(--catalog-border-light);
  border-radius: var(--catalog-border-radius-listing, 8px);
  text-decoration: none;
  color: inherit;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  overflow: hidden;
}
.estate-card:hover {
  -webkit-box-shadow: 0px 6px 4px 0px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 6px 4px 0px rgba(0, 0, 0, 0.1);
  position: relative;
  z-index: 1;
  -webkit-transform: scale(1.01);
          transform: scale(1.01);
  border-color: var(--catalog-primary);
}
.estate-card-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 328/246;
  overflow: hidden;
}
.estate-card-image {
  height: 100%;
}
.estate-card-image-placeholder {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.estate-card-image-placeholder-icon {
  opacity: 0.5;
}
.estate-card-badge {
  position: absolute;
  left: 12px;
  height: 20px;
  padding: 6px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "Inter", sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.24px;
  line-height: 1.3;
}
.estate-card-badge-new {
  top: 16px;
  background: var(--catalog-tag-listing-bg, var(--catalog-primary));
  color: var(--catalog-tag-listing-color, var(--catalog-white));
  width: 75px;
}
.estate-card-badge-status {
  top: 16px;
  background: var(--catalog-tag-listing-bg, var(--catalog-primary));
  color: var(--catalog-tag-listing-color, var(--catalog-white));
  min-width: 75px;
  padding-left: 10px;
  padding-right: 10px;
  width: auto;
  border-radius: var(--catalog-border-radius-tags, 20px);
}
.estate-card-badge-peb {
  bottom: 16px;
  width: 72px;
}
.estate-card-badge-peb .estate-card-peb-img {
  display: block;
  height: 26px;
  width: auto;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.estate-card-badges-status {
  position: absolute;
  top: 16px;
  left: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 6px;
}
.estate-card-badges-status .estate-card-badge-status {
  position: static;
  top: auto;
  left: auto;
}
.estate-card-favorite {
  position: absolute;
  top: 16px;
  right: 12px;
  width: 32px;
  height: 32px;
  background: var(--catalog-secondary);
  border-radius: var(--catalog-border-radius-tags, 20px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 4px;
  cursor: pointer;
}
.estate-card-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px;
  padding: 10px;
  padding-bottom: 10px;
}
.estate-card-header {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 10px;
}
.estate-card-title {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-family: "Inter", sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--catalog-black);
  line-height: 1.3;
  margin: 0;
}
.estate-card-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
  font-family: "Inter", sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--catalog-black);
}
.estate-card-price-value {
  font-weight: 600;
}
.estate-card-price-currency {
  font-weight: 400;
}
.estate-card-features {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.estate-card-feature {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
}
.estate-card-feature-icon-wrapper {
  color: var(--catalog-black);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.estate-card-feature-icon {
  width: 20px;
  height: 20px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: block;
}
.estate-card-feature-icon-svg {
  width: 20px;
  height: 20px;
  display: block;
}
.estate-card-feature-icon-svg svg {
  width: 100%;
  height: 100%;
  display: block;
}
.estate-card-feature-value {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: var(--catalog-black);
  line-height: 1.3;
}
.estate-card-location {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: var(--catalog-black);
  line-height: 1.3;
}
.estate-card {
  /* Card grisée : bien vendu/loué sans accès à la page détail */
}
.estate-card--no-detail {
  opacity: 0.78;
  -webkit-filter: grayscale(0.35);
  filter: grayscale(0.35);
  cursor: default;
}
.estate-card--no-detail:hover {
  -webkit-transform: none;
  transform: none;
  border-color: var(--catalog-border-light);
  -webkit-box-shadow: none;
  box-shadow: none;
}

.este-card-link {
  text-decoration: underline;
}

#catalog-immo-filters-modal .uk-modal-dialog {
  overflow-y: auto;
}
#catalog-immo-filters-modal.uk-modal-full .uk-modal-dialog {
  height: 100%;
  background-color: var(--backgroundbody);
}
#catalog-immo-filters-modal .catalog-immo-filters-modal-count {
  background: var(--buttonprimarycolor);
  color: var(--buttonprimarytextcolor);
  margin-bottom: 20px;
  padding: 10px;
}

@media screen and (min-width: 960px) {
  .featured-estates-block--etendu .estate-card {
    margin: 10px !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .featured-estates-block--etendu .estate-card > * {
    width: 50%;
  }
  .featured-estates-block--etendu .estate-card-content {
    width: auto !important;
    gap: 15px;
    padding-left: 40px;
  }
  .featured-estates-block--etendu .estate-card-price {
    font-size: 24px;
    padding-left: 30px;
  }
  .featured-estates-block--etendu .estate-card .estate-card-title {
    font-size: 22px;
  }
  .featured-estates-block--etendu .estate-card-image {
    aspect-ratio: inherit;
  }
}

/**
 * Styles pour la page de détail du catalogue immobilier
 * Galerie, sidebar, résumé, attributs, etc.
 */
.catalog-immo-detail-title-section {
  margin-bottom: 20px;
}

.catalog-immo-detail-badges-status {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.catalog-immo-detail-status-badge {
  display: inline-block;
  padding: 10px 20px;
  margin-bottom: 0;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.24px;
  line-height: 1.3;
  border-radius: var(--catalog-border-radius-tags, 20px);
  background: var(--catalog-tag-detail-bg, var(--catalog-secondary));
  color: var(--catalog-tag-detail-color, var(--catalog-black));
}

.catalog-immo-detail-title {
  font-family: "Inter", sans-serif;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--catalog-black);
  margin: 0;
}

/* Section principale : Layout - Images à gauche, Sidebar à droite */
.catalog-immo-detail-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 48px;
  margin-bottom: 80px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 768px) {
  .catalog-immo-detail-main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 32px;
  }
}

.catalog-immo-detail-category {
  font-size: 24px;
}

.catalog-immo-detail-left-column {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}
@media screen and (min-width: 640px) {
  .catalog-immo-detail-left-column {
    gap: 80px;
  }
}

/* Galerie d'images */
.catalog-immo-detail-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .catalog-immo-detail-gallery {
    max-width: 100%;
  }
}
.catalog-immo-detail-gallery-main {
  width: 100%;
  height: 300px;
  overflow: hidden;
  position: relative;
  border-radius: var(--catalog-border-radius-detail, 8px);
}
@media screen and (min-width: 640px) {
  .catalog-immo-detail-gallery-main {
    height: 600px;
  }
}
.catalog-immo-detail-gallery-main img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.catalog-immo-detail-gallery-placeholder {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  background: var(--catalog-secondary);
}
.catalog-immo-detail-gallery-thumbnail {
  width: 99px;
  height: 74px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: var(--catalog-border-radius-detail, 8px);
  -webkit-transition: border-color 0.2s;
  transition: border-color 0.2s;
}
.catalog-immo-detail-gallery-thumbnail:hover, .catalog-immo-detail-gallery-thumbnail.wf-clicked {
  border-color: var(--catalog-primary);
}
.catalog-immo-detail-gallery-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.catalog-immo-detail-gallery [uk-slider-item] {
  color: var(--textbody);
}

/* Sidebar droite (sticky) */
.catalog-immo-detail-sidebar {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 447px;
          flex: 0 0 447px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 32px;
  position: sticky;
  top: 0;
  -ms-flex-item-align: start;
      align-self: flex-start;
}
@media screen and (max-width: 768px) {
  .catalog-immo-detail-sidebar {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: 100%;
  }
}

.catalog-immo-detail-price-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0;
}

.catalog-immo-detail-price {
  font-family: "Inter", sans-serif;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--catalog-black);
}

.catalog-immo-detail-favorite {
  width: 42px;
  height: 42px;
  border: 1px solid var(--catalog-primary);
  border-radius: var(--catalog-border-radius-tags, 20px);
  background: white;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  padding: 4px;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
}
.catalog-immo-detail-favorite:hover {
  background: var(--catalog-secondary);
}

/* Résumé */
.catalog-immo-detail-summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 12px;
  width: 100%;
}
.catalog-immo-detail-summary-title {
  font-family: "Inter", sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--catalog-black);
  margin: 0;
}
.catalog-immo-detail-summary-badges {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.catalog-immo-detail-summary-badge {
  background: var(--catalog-tag-detail-bg, var(--catalog-secondary));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 8px;
  border-radius: var(--catalog-border-radius-detail, 8px);
}
.catalog-immo-detail-summary-badge span {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--catalog-tag-detail-color, var(--catalog-black));
}
.catalog-immo-detail-summary-badge-icon {
  width: 24px;
  height: 24px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.catalog-immo-detail-summary-badge-icon-wrapper {
  width: 24px;
  height: 24px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.catalog-immo-detail-summary-badge-icon-wrapper svg {
  width: 24px;
  height: 24px;
  display: block;
}
.catalog-immo-detail-summary-badge-icon-wrapper img {
  width: 24px;
  height: 24px;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
.catalog-immo-detail-summary-badge-icon-svg {
  width: 24px;
  height: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.catalog-immo-detail-summary-badge-icon-svg svg {
  width: 24px;
  height: 24px;
  display: block;
}

/* Description */
.catalog-immo-detail-description {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4px;
}
.catalog-immo-detail-description-text {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--catalog-black);
  max-height: 250px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: pre-wrap;
}
.catalog-immo-detail-description-text.expanded {
  max-height: none;
  overflow: visible;
}
.catalog-immo-detail-description-more {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--catalog-primary);
  text-decoration: underline;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-align: left;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

/* Agent */
.catalog-immo-detail-agent {
  background: var(--catalog-agent-bg, var(--catalog-secondary));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 18px 20px;
}
.catalog-immo-detail-agent-photo {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  overflow: hidden;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: var(--catalog-agent-bg, var(--catalog-secondary));
}
.catalog-immo-detail-agent-photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.catalog-immo-detail-agent-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.catalog-immo-detail-agent-name {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--catalog-agent-text, var(--catalog-black));
}
.catalog-immo-detail-agent-link {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--catalog-agent-link, var(--catalog-primary));
  text-decoration: underline;
}

/* Boutons d'action */
.catalog-immo-detail-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 100%;
}

.catalog-immo-detail-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.catalog-immo-detail-button svg {
  fill: currentColor;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.catalog-immo-detail-actions-primary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

/* Section Détails du bien */
.catalog-immo-detail-attributes-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px;
  margin-bottom: 80px;
  width: 100%;
  max-width: 923px;
}

.catalog-immo-detail-attributes-title {
  font-family: "Inter", sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--catalog-black);
  margin: 0;
}

/* Accordéons (mode config « accordions ») */
.catalog-immo-detail-attributes-accordion {
  margin: 0;
  padding: 0;
  list-style: none;
}
.catalog-immo-detail-attributes-accordion .uk-accordion-title {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--catalog-black);
  padding: 12px 0;
  border-bottom: 1px solid var(--catalog-light-grey);
}
.catalog-immo-detail-attributes-accordion li.uk-open > .uk-accordion-title {
  font-weight: 600;
  color: var(--catalog-secondary);
}
.catalog-immo-detail-attributes-accordion .uk-accordion-content {
  padding: 16px 0 24px;
}

.catalog-immo-detail-attributes-tabs.uk-tab {
  padding: 0;
  margin-bottom: 0px;
}
@media screen and (max-width: 1199px) {
  .catalog-immo-detail-attributes-tabs.uk-tab {
    display: block !important;
  }
}
.catalog-immo-detail-attributes-tabs.uk-tab > li > a {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: var(--catalog-black);
  padding: 10px 4px;
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  text-transform: initial;
  padding-left: 0px;
}
.catalog-immo-detail-attributes-tabs.uk-tab > li > a:hover {
  color: var(--catalog-secondary);
}
.catalog-immo-detail-attributes-tabs.uk-tab > li.uk-active > a {
  font-weight: 600;
  color: var(--catalog-secondary);
  border-bottom-color: var(--catalog-secondary);
}

.catalog-immo-detail-attributes-content.uk-switcher {
  position: relative;
  min-height: 200px;
  padding-top: 0px;
}
.catalog-immo-detail-attributes-content.uk-switcher > li {
  margin-left: 15px;
}

.catalog-immo-detail-attributes-table {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2px;
}
.catalog-immo-detail-attributes-table-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 8px 0;
}
.catalog-immo-detail-attributes-table-row:last-child {
  border-bottom: none;
  padding-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .catalog-immo-detail-attributes-table-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 4px;
  }
}
.catalog-immo-detail-attributes-table-label {
  width: 389px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.2;
  color: var(--catalog-black);
}
@media screen and (max-width: 768px) {
  .catalog-immo-detail-attributes-table-label {
    width: 100%;
  }
}
.catalog-immo-detail-attributes-table-value {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--catalog-black);
}

/* Référence du bien */
.catalog-immo-detail-reference {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 5px 0;
  margin-top: 10px;
}
.catalog-immo-detail-reference p {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-style: italic;
  line-height: 1.2;
  color: var(--catalog-black);
  margin: 0;
}

.catalog-immo-detail-peb-badge {
  display: inline-block;
  line-height: 0;
}
.catalog-immo-detail-peb-badge .catalog-immo-detail-peb-img {
  display: block;
  height: 26px;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

/* Section biens similaires — slider UIkit */
.catalog-immo-detail-similar-estates {
  padding: 50px 0px;
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider {
  margin-top: 20px;
}
@media screen and (min-width: 960px) {
  .catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider {
    margin-left: 40px;
    margin-right: 40px;
  }
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-estates-title {
  margin-bottom: 1rem;
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider [uk-slider-item] {
  color: var(--textbody);
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider .uk-slider-container {
  overflow: hidden;
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider .estate-card {
  margin: 3px;
}
.catalog-immo-detail-similar-estates .catalog-immo-detail-similar-slider .uk-slider-item {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
/*# sourceMappingURL=catalog-immo.css.map */