/**
 * 🗺️ Carte proéminente style Leboncoin
 * Vue carte = liste de résultats (gauche) + carte interactive (droite, sticky).
 * Les vues Liste/Mosaïque restent inchangées (toggle préservé).
 */

/* ============================================
   Layout split en vue carte
   ============================================ */
.search-results-container[data-view="map"] {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4, 16px) var(--space-5, 24px);
  align-items: flex-start;
}

/* Éléments pleine largeur (en-tête, filtres actifs, toggle, pagination) */
.search-results-container[data-view="map"] > .results-header,
.search-results-container[data-view="map"] > .results-overview,
.search-results-container[data-view="map"] > .active-filters,
.search-results-container[data-view="map"] > .search-feedback,
.search-results-container[data-view="map"] > .view-toggle,
.search-results-container[data-view="map"] > .results-actions {
  flex: 0 0 100%;
  width: 100%;
}

.search-results-container[data-view="map"] > .results-header { order: 1; }
.search-results-container[data-view="map"] > .results-overview { order: 2; }
.search-results-container[data-view="map"] > .active-filters { order: 3; }
.search-results-container[data-view="map"] > .search-feedback { order: 4; }
.search-results-container[data-view="map"] > .view-toggle { order: 5; }
.search-results-container[data-view="map"] > .search-results { order: 6; }
.search-results-container[data-view="map"] > .map-view { order: 7; }
.search-results-container[data-view="map"] > .results-actions { order: 8; }

/* Colonne gauche : liste des résultats */
.search-results-container[data-view="map"] > .search-results {
  flex: 1 1 52%;
  min-width: 300px;
}

/* Colonne droite : carte sticky */
.search-results-container[data-view="map"] > .map-view {
  display: flex;
  flex-direction: column;
  gap: var(--space-2, 8px);
  flex: 1 1 42%;
  min-width: 300px;
  position: sticky;
  top: 84px;
  height: calc(100vh - 110px);
  min-height: 480px;
  margin: 0;
}

/* La carte remplit la colonne, le panneau résumé reste compact au-dessus */
.search-results-container[data-view="map"] > .map-view .search-map-panel {
  flex: 0 0 auto;
  max-height: 116px;
  overflow-y: auto;
}

.search-results-container[data-view="map"] > .map-view #search-map,
.search-results-container[data-view="map"] > .map-view .search-map {
  flex: 1 1 auto;
  height: auto;
  min-height: 320px;
  border-radius: var(--radius-2xl, 16px);
  overflow: hidden;
  border: 2px solid var(--card-border, #e2e8f0);
}

/* Panneau résumé */
.search-map-panel {
  background: var(--bg-elevated, #fff);
  border: 1px solid var(--card-border, #e2e8f0);
  border-radius: var(--radius-2xl, 16px);
  padding: var(--space-3, 12px) var(--space-4, 16px);
}

/* ============================================
   Responsive : empilement sur tablette/mobile
   ============================================ */
@media (max-width: 1023px) {
  .search-results-container[data-view="map"] > .map-view {
    order: 6;
    position: static;
    height: 52vh;
    min-height: 320px;
    flex: 0 0 100%;
    width: 100%;
  }
  .search-results-container[data-view="map"] > .search-results {
    order: 7;
    flex: 0 0 100%;
    width: 100%;
  }
}

/* Style des marqueurs amélioré */
.search-map-marker {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50%;
  border: 3px solid white;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 14px;
  color: white;
  background: var(--accent, #45818e);
  cursor: pointer;
  transition: transform 0.2s ease;
}

.search-map-marker:hover {
  transform: scale(1.2);
}

.search-map-marker--offer {
  background: linear-gradient(135deg, #45818e, #74aeb6);
}

.search-map-marker--request {
  background: linear-gradient(135deg, #8B4513, #CD853F);
}

/* Synchronisation carte <-> liste : marqueur mis en valeur au survol d'une carte */
.search-map-marker--hover {
  transform: scale(1.4) !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.45) !important;
  z-index: 1000 !important;
}

/* Carte-résultat surlignée au clic d'un marqueur */
.result-card--map-active {
  outline: 2px solid var(--accent, #45818e);
  outline-offset: 2px;
  box-shadow: 0 10px 26px rgba(69, 129, 142, 0.28);
  transition: outline-color 0.2s ease, box-shadow 0.2s ease;
}

/* Popup amélioré */
.search-map-popup {
  padding: var(--space-3);
  min-width: 200px;
}

.search-map-popup strong {
  display: block;
  margin-bottom: var(--space-2);
  color: var(--text-primary);
  font-size: 14px;
}

.search-map-popup span {
  display: block;
  color: var(--text-secondary);
  font-size: 12px;
  margin-bottom: var(--space-1);
}

/* Bouton vue carte mis en avant */
.view-btn.map-view-btn {
  background: var(--accent, #45818e);
  color: white;
  border-color: var(--accent, #45818e);
}

.view-btn.map-view-btn.active {
  background: var(--accent-dark, #34495e);
  color: white;
}

/* Sur mobile, la carte en haut */
@media (max-width: 1023px) {
  .map-view {
    grid-template-columns: 1fr;
    height: auto;
  }
  
  #search-map,
  .search-map {
    height: 50vh !important;
    min-height: 300px;
  }
  
  .search-map-panel {
    max-height: 40vh;
  }
}
