/* Modal (léger, sans dépendances) */
.ib-modal{ position:fixed; inset:0; z-index:9999;
  opacity:0; visibility:hidden; pointer-events:none;
  /* transition: opacity .22s cubic-bezier(.2,.8,.2,1), visibility 0s linear .22s;  */
  transition: opacity 1s cubic-bezier(.2,.8,.2,1), visibility 0s linear 1s;
}
.ib-modal.is-open{ opacity:1; visibility:visible; pointer-events:auto; transition-delay:0s; }
.ib-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.45); ; opacity:0; /* transition: opacity .22s cubic-bezier(.2,.8,.2,1); */ ; 
transition: opacity 1s cubic-bezier(.2,.8,.2,1);}
.ib-modal__panel{
  position:relative;
  max-width: 980px;
  margin: 70px auto;
  background:#fff;
  border-radius:10px;
  padding:18px 18px 14px;
  box-shadow:0 12px 40px rgba(0,0,0,.25);
}
.ib-modal__close{ position:absolute; top:10px; right:12px; border:0; background:transparent; font-size:28px; line-height:1; cursor:pointer; }
.ib-modal__title{ margin:0 0 14px; font-size:20px; }
.ib-modal__grid{ display:grid; grid-template-columns: 1fr 1fr 1fr; gap:14px; }
.ib-field span{ display:block; font-size:13px; opacity:.85; margin:0 0 6px; }
.ib-field select,.ib-field input{
  width:100%;
  height:40px;
  border:1px solid rgba(0,0,0,.2);
  border-radius:4px;
  padding:0 10px;
  background:#fff;
}
.ib-modal__actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:14px; flex-wrap:wrap; }
.ib-btn--primary{ background:#398784; color:#fff; border:1px solid #315e5e8a; }

.ib-btn--primary:hover{
  background: #39878482;
  border-color: #39878482;
}


.ib-btn--ghost{ background:transparent; border:1px solid rgba(0,0,0,.25); border-color: #398784;
    color: #005f6b;}
	
.ib-btn--ghost:hover {
    background: #39878469;
    border-color: #398784;
    color: #004c56;
}
	
	
	
@media (max-width: 780px){
  .ib-modal__grid{ grid-template-columns: 1fr; }
  .ib-modal__panel{ margin: 18px; }
}
/* Animation */
.ib-modal__panel{
  transform: translateY(-24px);
  opacity: 0;
  /* transition: transform .22s cubic-bezier(.2,.8,.2,1), opacity .22s cubic-bezier(.2,.8,.2,1);  */
  transition: transform 1s cubic-bezier(.2,.8,.2,1), opacity 1s cubic-bezier(.2,.8,.2,1);
  will-change: transform, opacity;
}

/* Quand ouvert : le panneau descend */
.ib-modal.is-open .ib-modal__backdrop{opacity:1;}
.ib-modal.is-open .ib-modal__panel{
  transform: translateY(0);
  opacity: 1;
  width: 90vw;
}

/* Quand on ferme : il remonte */
.ib-modal.is-closing .ib-modal__panel{
  transform: translateY(-24px);
  opacity: 0;
}

/* Zone prix / visuel flouté : hauteur homogène sur toutes les cards */
.ib-price-slot{
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
}
.ib-price-slot .ib-price{
  width: 100%;
  margin: 0;
}
.ib-price-blur{
  display: block;
  max-width: 100%;
  max-height: 72px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.ib-share-btn{
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.ib-share-btn img{
  display:block;
  width:44px;
  height:44px;
}
.ib-share-modal__panel{
  max-width:640px;
}
.ib-share-modal__intro{
  margin:0 0 14px;
  color:rgba(0,0,0,.75);
  line-height:1.5;
}
.ib-share-form textarea{
  width:100%;
  min-height:150px;
  border:1px solid rgba(0,0,0,.2);
  border-radius:4px;
  padding:10px;
  background:#fff;
  font:inherit;
  resize:vertical;
}
.ib-share-consent{
  display:flex;
  gap:8px;
  align-items:flex-start;
  margin-top:10px;
  font-size:14px;
}


.ib-nav-block{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.25rem;
}


/* ================================================
   Barre de filtre inline  —  à ajouter dans les-biens.css
   ================================================ */

.ib-filterbar {
  margin: 18px 0 24px;
  background: var(--color-surface, #f7f7f5);
  border: 1px solid var(--color-border, #e2e2dd);
  border-radius: 10px;
  padding: 18px 20px;
}

.ib-filterbar__form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 14px;
}

.ib-filterbar__fields {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  flex: 1 1 0;
}

.ib-filterbar__field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1 1 160px;
  min-width: 140px;
}

/* Le champ localisation prend plus de place */
.ib-filterbar__field--loc {
  flex: 2 1 220px;
}

.ib-filterbar__field span {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--color-muted, #888);
}

.ib-filterbar__field select,
.ib-filterbar__field input[type="text"] {
  height: 40px;
  padding: 0 10px;
  border: 1px solid var(--color-border, #d5d5ce);
  border-radius: 6px;
  background: #fff;
  font-size: .93rem;
  color: inherit;
  width: 100%;
  box-sizing: border-box;
}

.ib-filterbar__field select:focus,
.ib-filterbar__field input[type="text"]:focus {
  outline: 2px solid var(--color-primary, #b89b6a);
  outline-offset: 1px;
}

.ib-filterbar__actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  align-items: flex-end;
  padding-bottom: 1px;   /* alignement visuel avec les inputs */
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .ib-filterbar__form {
    flex-direction: column;
  }

  .ib-filterbar__actions {
    width: 100%;
    justify-content: stretch;
  }

  .ib-filterbar__actions .ib-btn {
    flex: 1;
    text-align: center;
  }
}





@media (max-width: 768px) {
  body .page-hero {
    min-height: 130px !important;
    padding: 1rem 1rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  body .page-hero h1 {
    margin: 0 !important;
    line-height: 1.1 !important;
  }
}