/* ════════════════════════════════════════════════════════════════════════
   Hostome UI — styles SPÉCIFIQUES à la page Logements (properties.html)
   ------------------------------------------------------------------------
   Nouvelle couche propre. Chargé APRÈS app.css (legacy) → surcharge maîtrisée.
   Ne remplace rien : ajoute uniquement ce qui est propre à cette page.
   ════════════════════════════════════════════════════════════════════════ */

@media (max-width: 760px) {
  /* #1 — léger espace entre le bouton de filtre (Trier / Grouper) et son menu */
  .prop-list-group .prop-list-group-menu.property-sort-menu,
  .prop-list-sort .prop-list-sort-menu.property-sort-menu {
    margin-top: 10px !important;
  }

  /* #2 — espace entre l'en-tête du logement et le contenu */
  .page-split.prop-mode .pg-prop-header.ms-prop-card {
    margin-bottom: 14px !important;
  }
}

/* ─── Styles SPÉCIFIQUES properties copiés depuis app.css (l.30818–31069) ─── */
/* Copie verbatim. app.css conserve la même définition (doublon temporaire accepté). */

/* ══════════════════════════════════════════════════════════════════════════
   GABARIT CANONIQUE — Page liste (mockup validé : header + recherche + filtres
   + blocs). S'applique à properties (.prop-mode). Couleurs = variables du site
   → clair/sombre automatiques. Classes legacy conservées (hooks JS).
   ══════════════════════════════════════════════════════════════════════════ */

/* En-tête : carte blanche, bord, eyebrow + titre + pastille compteur */
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-head {
  background: var(--surface) !important;
  border: 1.5px solid var(--line) !important;
  border-radius: 16px !important;
  padding: 16px 18px !important;
  margin: 6px 0 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title {
  flex: 1 !important;
  min-width: 0 !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title .experience-eyebrow {
  color: var(--accent) !important;
  font-size: 11.5px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  margin: 0 0 2px !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title h1 {
  font-size: 23px !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  line-height: 1.08 !important;
  margin: 0 !important;
}
.prop-mode .prop-picker-count {
  flex: 0 0 auto !important;
  background: var(--surface) !important;
  border: 1px solid var(--line-strong) !important;
  color: var(--t3) !important;
  border-radius: 999px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  padding: 6px 13px !important;
}

/* Barre de recherche : pilule */
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search {
  background: var(--surface) !important;
  border: 1.5px solid var(--line-strong) !important;
  border-radius: 999px !important;
  height: 46px !important;
  padding: 0 16px !important;
  margin: 0 0 14px !important;
  gap: 10px !important;
  max-width: none !important;
  box-shadow: none !important;
}

/* Boutons de filtres : ghost bien visibles */
.prop-mode .pg-list-tools .prop-sort-control {
  background: var(--surface) !important;
  border: 1.5px solid var(--line-strong) !important;
  color: var(--t1) !important;
  border-radius: 12px !important;
  min-height: 40px !important;
  height: 40px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.prop-mode .pg-list-tools .prop-sort-control small { color: var(--t3) !important; font-weight: 600 !important; }
.prop-mode .pg-list-tools .prop-sort-control:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

/* Grille de blocs */
.prop-mode .pg-prop-list .prop-group-section-list {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 16px !important;
}

/* Carte logement : bord 1.5px */
.prop-mode .pg-prop-list .pg-prop-row {
  border: 1.5px solid var(--line) !important;
  background: var(--surface) !important;
}
.prop-mode .pg-prop-row:hover {
  border-color: var(--line-strong) !important;
  box-shadow: 0 10px 26px -16px rgba(0,0,0,.22) !important;
  transform: translateY(-2px);
}
.prop-mode .pg-prop-row.is-active { border-color: var(--accent) !important; box-shadow: 0 0 0 1px var(--accent) !important; }

.prop-mode .pg-prop-list .pg-prop-row.pg-property-card--disabled {
  background: var(--surface-2) !important;
  border-color: var(--line-strong) !important;
}
.prop-mode .pg-prop-list .pg-prop-row.pg-property-card--disabled .pg-photo {
  background: #eef0f3 !important;
}
.prop-mode .pg-prop-list .pg-prop-row.pg-property-card--disabled .pg-photo img {
  filter: grayscale(.35);
  opacity: .72;
}
.prop-mode .pg-prop-list .pg-property-card--disabled .pg-prop-name-row {
  align-items: center !important;
  display: flex !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.prop-mode .pg-prop-list .pg-property-card--disabled .pg-property-disabled-badge {
  background: #f1f3f5;
  border: 1px solid #d7dce1;
  border-radius: 999px;
  color: var(--t3);
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  padding: 5px 8px;
}

/* Carte « Ajouter » : vignette + grand +, libellé centré dans la partie basse */
.prop-mode .prop-create-card {
  border: 1.5px solid var(--line) !important;
  flex-direction: column !important;
  padding: 0 !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-create-card .prop-create-card-icon {
  display: flex !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 4 / 3 !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--surface-2) !important;
  color: var(--accent) !important;
  font-size: 40px !important;
  border-radius: 0 !important;
}
.prop-mode .prop-create-card .pg-prop-main {
  align-items: center !important;
  text-align: center !important;
  padding: 14px 15px 16px !important;
}
.prop-mode .prop-create-card .pg-prop-name { display: none !important; }
.prop-mode .prop-create-card .pg-prop-city {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}
.prop-mode .prop-create-card .pg-prop-city i { display: none !important; }

/* Carte « Ajouter » isolée sur sa propre ligne + séparateur de groupe symétrique */
.prop-mode .prop-create-section {
  border-bottom: 1px solid var(--line) !important;
  padding: 0 0 22px !important;
  margin: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section {
  border-bottom: 1px solid var(--line) !important;
  padding: 22px 0 !important;
  margin: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section:last-child {
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section-title {
  margin: 0 0 14px !important;
  padding: 0 2px !important;
}

/* Menu « Grouper » : largeur identique à calendar (sinon le texte passe sur 2 lignes) */
.prop-list-group-menu.property-sort-menu {
  left: 0 !important;
  right: auto !important;
  width: min(430px, calc(100vw - 48px)) !important;
  padding: 12px !important;
  border-radius: 16px !important;
}

/* Cartes logement VERTICALES aussi en tablette/mobile (gabarit validé) */
@media (max-width: 1080px) {
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
  }
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card .prop-create-card-icon {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
    border-radius: 0 !important;
  }
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-main {
    padding: 13px 15px 15px !important;
  }
}

/* ───── Parité stricte avec calendar.html (menu Grouper + boutons outils) ───── */
/* 1. Menu « Grouper » : mêmes couleurs que calendar (gris neutre, icône active orange) */
.prop-list-group-menu .property-sort-option {
  background: transparent !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
  min-height: 32px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
}
.prop-list-group-menu .property-sort-option i { color: var(--t3) !important; font-size: 12px !important; width: 14px !important; }
.prop-list-group-menu .property-sort-option:hover { background: var(--surface-2) !important; color: var(--t1) !important; }
.prop-list-group-menu .property-sort-option:hover i { color: var(--t1) !important; }
.prop-list-group-menu .property-sort-option.active { background: var(--surface-3, var(--surface-2)) !important; color: var(--t1) !important; font-weight: 600 !important; }
.prop-list-group-menu .property-sort-option.active i { color: var(--accent) !important; }
.prop-list-group-menu .calendar-filter-panel-head strong { color: var(--t1) !important; font-size: 13px !important; font-weight: 700 !important; }
.prop-list-group-menu .calendar-filter-panel-head span { color: var(--t3) !important; font-size: 11.5px !important; font-weight: 500 !important; margin-top: 2px !important; display: block !important; }
.prop-list-group-menu .property-sort-options { padding-top: 6px !important; border-top: 1px solid var(--line) !important; gap: 2px !important; }

/* 3. Boutons Trier / Grouper : rendu strictement identique à .tool-btn (calendar = 38px) */
.prop-mode .pg-list-tools .prop-sort-control {
  height: 38px !important;
  min-height: 38px !important;
  padding: 0 12px !important;
  border: 1px solid var(--line) !important;
  border-radius: 9px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--t2) !important;
  background: var(--surface) !important;
  box-shadow: var(--shadow-1) !important;
  width: auto !important;
  gap: 7px !important;
}
.prop-mode .pg-list-tools .prop-sort-control span { font-weight: 600 !important; }
.prop-mode .pg-list-tools .prop-sort-control small { font-weight: 600 !important; color: var(--t3) !important; }
.prop-mode .pg-list-tools .prop-sort-control:hover { background: var(--surface-2) !important; color: var(--t1) !important; border-color: var(--line) !important; }

/* 5. Boutons de filtres alignés à gauche avec le header et la recherche */
.prop-mode .pg-list-tools.prop-list-tools { padding-left: 0 !important; padding-right: 0 !important; margin-left: 0 !important; }
.prop-mode .pg-list-tools.prop-list-tools > * { margin-left: 0 !important; }

/* 4. Carte « Ajouter » : corps de même hauteur que les logements */
.page-split.prop-mode:not([data-prop-panel]) .prop-create-card .pg-prop-main {
  min-height: 96px !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* 2. Menu déroulant qui ne sort plus du cadre sur mobile */
@media (max-width: 760px) {
  .prop-list-group .prop-list-group-menu.property-sort-menu,
  .prop-list-sort .prop-list-sort-menu.property-sort-menu {
    position: fixed !important;
    left: 14px !important;
    right: 14px !important;
    top: auto !important;
    width: auto !important;
    max-width: none !important;
  }
}

/* Menu « Trier » : même largeur que le menu « Grouper » (et que calendar) */
.prop-list-sort-menu.property-sort-menu {
  left: 0 !important;
  right: auto !important;
  width: min(430px, calc(100vw - 48px)) !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 12px !important;
  border-radius: 16px !important;
}


/* ════════════════════════════════════════════════════════════════════════
   Écran 2 — Sélection d'une rubrique (panneau .page-split-tabs, mobile)
   Patch visuel uniquement. N'affecte PAS l'écran 3 (.page-split-detail).
   ════════════════════════════════════════════════════════════════════════ */

/* #1 — Retirer le grand fond blanc autour du menu : les rubriques sont posées
   sur le fond de page, chaque rubrique devient une carte (cartes internes conservées). */
.page-split.prop-mode[data-prop-panel="tabs"] > .page-split-tabs {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}
.page-split.prop-mode .page-split-tabs .property-mobile-menu {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.page-split.prop-mode .page-split-tabs .property-mobile-menu-item {
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: 12px !important;
  box-shadow: var(--shadow-1) !important;
}

/* #2 — Carte logement en haut : photo + texte EN LIGNE, comme l'écran intérieur. */
.page-split.prop-mode .page-split-tabs .pg-prop-header-mobile {
  flex-direction: row !important;
  align-items: center !important;
  gap: 14px !important;
}

/* #3 — En-tête logement unifié entre le menu mobile et l'écran intérieur. */
@media (max-width: 760px) {
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header.ms-prop-card,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header.ms-prop-card {
  display: grid !important;
  align-items: center !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 12px !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-left,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-left {
  display: flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  gap: 12px !important;
  max-width: none !important;
  min-width: 0 !important;
  width: auto !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-copy,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-copy {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  flex: 1 1 auto !important;
  align-items: flex-start !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-align: left !important;
  width: 100% !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-chip,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-chip {
  flex: 0 0 58px !important;
  height: 58px !important;
  width: 58px !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-name,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-name {
  margin: 0 !important;
  text-align: left !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-city,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-city {
  margin-top: 0 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-align: left !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .prop-location-only,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .prop-location-only {
  max-width: 17.5ch !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-city i,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-city i {
  display: none !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-right,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-right {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 5px !important;
  margin-left: auto !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-prop-header-id,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-prop-header-id {
  color: var(--t3) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  line-height: 1.1 !important;
}
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs .pg-prop-header .pg-status-pill,
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form .pg-prop-header .pg-status-pill {
  height: 24px !important;
  padding: 0 10px !important;
}
  .page-split.prop-mode[data-prop-panel="detail"] .page-split-detail {
    box-sizing: border-box !important;
    padding: 0 0 36px !important;
    width: 100% !important;
  }
  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form.ms-detail-content {
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: none !important;
    width: 100% !important;
  }
}

/* ── Autocomplétion ville (API GeoNames) ─────────────────────────────────────
   Complète app.css (qui gère menu/positions/largeur/overflow/z-index) SANS le
   modifier : on ajoute uniquement l'état actif clavier et les messages d'état. */
.city-autocomplete-menu .city-result.is-active {
  background: var(--ms-blue-bg);
}
.city-autocomplete-menu .city-result-status {
  color: var(--ms-text-2);
  font-size: 13px;
  padding: 10px 11px;
}


/* ── Sélecteur Pays Hostome hors formulaire ─────────────────────────────── */
.country-picker-trigger { align-items:center; appearance:none; cursor:pointer; display:flex; justify-content:space-between; text-align:left; width:100%; }
.country-picker-trigger.is-placeholder [data-country-trigger-label] { color:var(--ms-text-3); font-weight:400; }
.country-picker-trigger > i { color:var(--ms-text-3); flex:0 0 auto; font-size:11px; margin-left:10px; }
.country-picker-trigger:focus-visible, .country-picker-trigger[aria-expanded="true"] { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); outline:none; }
.country-picker-trigger[aria-invalid="true"] { border-color:var(--danger, #d14343); }
.country-picker-panel { background:var(--surface, #fff); border:1px solid var(--ms-border); border-radius:12px; box-shadow:0 18px 44px rgba(20,28,36,.2); box-sizing:border-box; display:flex; flex-direction:column; gap:6px; max-height:min(420px, calc(100vh - 16px)); overflow:hidden; padding:7px; position:fixed; z-index:900; }
.country-picker-panel[hidden] { display:none !important; }
.country-picker-search { box-sizing:border-box; flex:0 0 auto; width:100%; }
.country-picker-results { max-height:320px; overflow-x:hidden; overflow-y:auto; overscroll-behavior:contain; }
.country-picker-results .city-result.is-active { background:var(--ms-blue-bg); }
.country-picker-empty { color:var(--ms-text-2); font-size:13px; padding:10px 11px; }
@media (max-width:640px) { .country-picker-panel { max-height:min(360px, calc(100vh - 16px)); } .country-picker-results { max-height:260px; } }


/* ── Navigation interne Logements sticky desktop ───────────────────────── */
@media (min-width: 981px) {
  .page-split.prop-mode[data-prop-panel="detail"] > .page-split-detail {
    overflow: visible;
  }

  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form.ms-detail-content > .property-tabs {
    align-self: start;
    max-height: calc(100vh - 92px);
    overflow-x: hidden;
    overflow-y: auto;
    position: sticky;
    scrollbar-color: var(--line-strong) transparent;
    scrollbar-width: thin;
    top: 18px;
  }

  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form.ms-detail-content > .property-tabs::-webkit-scrollbar {
    width: 6px;
  }

  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form.ms-detail-content > .property-tabs::-webkit-scrollbar-thumb {
    background: var(--line-strong);
    border-radius: 999px;
  }

  .page-split.prop-mode[data-prop-panel="detail"] .property-detail-form.ms-detail-content > .property-tabs::-webkit-scrollbar-track {
    background: transparent;
  }
}
