/* =============================================
   RFMF Carte — carte.css v3
   Override Enfold avec sélecteurs renforcés
   ============================================= */

#rfmf-app,
#rfmf-app * {
  box-sizing: border-box;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

#rfmf-app {
  color: #1a1a2e;
  border: 1px solid #e0e4ef;
  border-radius: 14px;
  overflow: visible;
  position: relative;
  background: #fff;
  max-width: 100%;
  margin: 0 0 30px 0;
}

/* ======================================================
   TOOLBAR — forcer flex horizontal même sous Enfold
   ====================================================== */
#rfmf-app #rfmf-toolbar {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: row !important;
  flex-direction: row !important;
  -webkit-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  -webkit-align-items: flex-end !important;
  align-items: flex-end !important;
  gap: 8px !important;
  padding: 14px 16px !important;
  background: #f0f4ff !important;
  border-bottom: 1px solid #dde5ff !important;
  border-radius: 14px 14px 0 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

/* Chaque groupe filtre */
#rfmf-app .rfmf-dd-wrap {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
  gap: 3px !important;
  position: relative !important;
  -webkit-flex: 1 1 120px !important;
  flex: 1 1 120px !important;
  max-width: 160px !important;
  min-width: 100px !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

#rfmf-app .rfmf-dd-wrap label {
  display: block !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: #4b5580 !important;
  margin: 0 0 3px 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  float: none !important;
}

/* Champ recherche ville */
#rfmf-app .rfmf-search-wrap {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
  gap: 3px !important;
  position: relative !important;
  -webkit-flex: 1 1 150px !important;
  flex: 1 1 150px !important;
  max-width: 180px !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

#rfmf-app .rfmf-search-wrap label {
  display: block !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: #4b5580 !important;
  margin: 0 0 3px 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
  float: none !important;
}

#rfmf-app #rfmf-geo-input {
  display: block !important;
  width: 100% !important;
  height: 36px !important;
  font-size: 12px !important;
  padding: 0 10px !important;
  border: 1.5px solid #c7d2fe !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: #1a1a2e !important;
  outline: none !important;
  margin: 0 !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
}
#rfmf-app #rfmf-geo-input:focus {
  border-color: #4f46e5 !important;
  box-shadow: 0 0 0 3px rgba(79,70,229,.12) !important;
}

/* Suggestions geo */
#rfmf-app #rfmf-geo-suggestions {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  right: 0 !important;
  background: #fff !important;
  border: 1.5px solid #4f46e5 !important;
  border-radius: 8px !important;
  z-index: 99999 !important;
  display: none;
  max-height: 200px !important;
  overflow-y: auto !important;
  margin-top: 3px !important;
  box-shadow: 0 8px 24px rgba(79,70,229,.15) !important;
}
#rfmf-app .rfmf-geo-item {
  padding: 8px 12px !important;
  font-size: 12px !important;
  cursor: pointer !important;
  border-bottom: 1px solid #f0f4ff !important;
  color: #374151 !important;
  display: block !important;
}
#rfmf-app .rfmf-geo-item:last-child { border-bottom: none !important; }
#rfmf-app .rfmf-geo-item:hover { background: #eef2ff !important; }

/* ======== BOUTONS DROPDOWN ======== */
#rfmf-app .rfmf-dd-btn {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  -webkit-justify-content: space-between !important;
  justify-content: space-between !important;
  width: 100% !important;
  height: 36px !important;
  padding: 0 10px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  border: 1.5px solid #c7d2fe !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: #374151 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  margin: 0 !important;
  box-shadow: none !important;
  text-align: left !important;
  line-height: 1 !important;
  transition: border-color .15s, background .15s !important;
  float: none !important;
}
#rfmf-app .rfmf-dd-btn:hover {
  border-color: #818cf8 !important;
  background: #f5f3ff !important;
}
#rfmf-app .rfmf-dd-btn.active {
  border-color: #4f46e5 !important;
  background: #eef2ff !important;
  color: #3730a3 !important;
  font-weight: 700 !important;
}
#rfmf-app .rfmf-dd-btn .chev {
  font-size: 9px !important;
  opacity: .5 !important;
  transition: transform .2s !important;
  flex-shrink: 0 !important;
  margin-left: 4px !important;
}
#rfmf-app .rfmf-dd-btn.open .chev {
  transform: rotate(180deg) !important;
  opacity: 1 !important;
}

/* Panneaux dropdown */
#rfmf-app .rfmf-dd-panel {
  position: absolute !important;
  top: calc(100% + 4px) !important;
  left: 0 !important;
  min-width: 220px !important;
  background: #fff !important;
  border: 1.5px solid #c7d2fe !important;
  border-radius: 10px !important;
  z-index: 99999 !important;
  display: none;
  max-height: 280px !important;
  overflow-y: auto !important;
  box-shadow: 0 8px 24px rgba(79,70,229,.15) !important;
  margin: 0 !important;
  padding: 0 !important;
}
#rfmf-app .rfmf-dd-panel.show { display: block !important; }

#rfmf-app .rfmf-dd-search {
  padding: 8px 10px !important;
  border-bottom: 1px solid #e0e7ff !important;
  position: sticky !important;
  top: 0 !important;
  background: #fff !important;
  z-index: 1 !important;
}
#rfmf-app .rfmf-dd-search input {
  width: 100% !important;
  font-size: 12px !important;
  padding: 5px 8px !important;
  border: 1px solid #c7d2fe !important;
  border-radius: 6px !important;
  background: #f5f3ff !important;
  color: #374151 !important;
  outline: none !important;
  margin: 0 !important;
  box-shadow: none !important;
  display: block !important;
}
#rfmf-app .rfmf-dd-search input:focus {
  border-color: #4f46e5 !important;
}

#rfmf-app .rfmf-dd-option {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 12px !important;
  cursor: pointer !important;
  font-size: 12px !important;
  border-bottom: 1px solid #f5f7ff !important;
  color: #374151 !important;
  margin: 0 !important;
  transition: background .1s !important;
}
#rfmf-app .rfmf-dd-option:last-child { border-bottom: none !important; }
#rfmf-app .rfmf-dd-option:hover { background: #eef2ff !important; }
#rfmf-app .rfmf-dd-option input[type=checkbox] {
  width: 14px !important;
  height: 14px !important;
  accent-color: #4f46e5 !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  cursor: pointer !important;
}
#rfmf-app .rfmf-dd-option.hidden { display: none !important; }

/* Bouton reset */
#rfmf-app #rfmf-reset-btn {
  height: 36px !important;
  padding: 0 14px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  border: 1.5px solid #c7d2fe !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: #6b7280 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  -webkit-align-self: flex-end !important;
  align-self: flex-end !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 5px !important;
  transition: all .15s !important;
  float: none !important;
}
#rfmf-app #rfmf-reset-btn:hover {
  background: #fee2e2 !important;
  color: #dc2626 !important;
  border-color: #fca5a5 !important;
}

/* ======== TAGS ACTIFS ======== */
#rfmf-app #rfmf-active-tags {
  padding: 8px 16px !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  background: #fff !important;
  border-bottom: 1px solid #e0e4ef !important;
  margin: 0 !important;
  list-style: none !important;
}
#rfmf-app #rfmf-active-tags:empty {
  display: none !important;
  padding: 0 !important;
}

#rfmf-app .rfmf-tag {
  display: -webkit-inline-flex !important;
  display: inline-flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 11px !important;
  padding: 3px 10px !important;
  border-radius: 20px !important;
  background: #eef2ff !important;
  color: #3730a3 !important;
  cursor: pointer !important;
  border: 1px solid #c7d2fe !important;
  margin: 0 !important;
  max-width: 200px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  float: none !important;
}
#rfmf-app .rfmf-tag:hover { background: #e0e7ff !important; }
#rfmf-app .rfmf-tag .rm {
  font-size: 14px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
}

/* ======== CARTE ======== */
#rfmf-app #rfmf-map-wrap {
  position: relative !important;
  height: 420px !important;
  margin: 0 !important;
  padding: 0 !important;
}
#rfmf-app #rfmf-map {
  width: 100% !important;
  height: 100% !important;
}

#rfmf-app #rfmf-count-badge {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 1000 !important;
  background: rgba(255,255,255,.95) !important;
  border: 1px solid #c7d2fe !important;
  border-radius: 20px !important;
  padding: 5px 14px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #3730a3 !important;
  box-shadow: 0 2px 8px rgba(79,70,229,.12) !important;
}

/* Légende */
#rfmf-app .rfmf-legend {
  position: absolute !important;
  bottom: 30px !important;
  left: 10px !important;
  z-index: 1000 !important;
  background: rgba(255,255,255,.95) !important;
  border: 1px solid #e0e4ef !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
  font-size: 11px !important;
  color: #374151 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
}
#rfmf-app .rfmf-legend-item {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 7px !important;
  margin-bottom: 4px !important;
}
#rfmf-app .rfmf-legend-item:last-child { margin-bottom: 0 !important; }
#rfmf-app .rfmf-legend-dot {
  width: 11px !important;
  height: 11px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}

/* Popup */
.rfmf-popup { font-size: 13px; min-width: 200px; max-width: 240px; line-height: 1.5; }
.rfmf-popup h3 { font-size: 14px; font-weight: 700; color: #3730a3; margin: 0 0 3px; }
.rfmf-popup .type-b { font-size: 11px; color: #6b7280; display: block; margin-bottom: 8px; }
.rfmf-popup .row { display: flex; gap: 6px; margin-bottom: 4px; font-size: 12px; }
.rfmf-popup .lbl { color: #9ca3af; min-width: 60px; font-size: 11px; flex-shrink: 0; }
.rfmf-popup-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 12px;
  color: #fff;
  background: #4f46e5;
  padding: 5px 12px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
}

/* ======== FICHES ======== */
#rfmf-app #rfmf-cards-section {
  background: #f5f7ff !important;
  border-top: 1px solid #e0e4ef !important;
  padding: 16px !important;
  border-radius: 0 0 14px 14px !important;
  margin: 0 !important;
}
#rfmf-app #rfmf-cards-header {
  font-size: 12px !important;
  color: #6b7280 !important;
  margin-bottom: 14px !important;
  font-weight: 600 !important;
}
#rfmf-app #rfmf-cards-grid {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Fiches — largeur auto responsive */
#rfmf-app .rfmf-card {
  background: #fff !important;
  border: 1.5px solid #e0e7ff !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  cursor: pointer !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
  -webkit-flex: 1 1 240px !important;
  flex: 1 1 240px !important;
  max-width: calc(33.33% - 10px) !important;
  transition: border-color .15s, box-shadow .15s, transform .15s !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
#rfmf-app .rfmf-card:hover {
  border-color: #818cf8 !important;
  box-shadow: 0 6px 20px rgba(79,70,229,.12) !important;
  transform: translateY(-2px) !important;
}
#rfmf-app .rfmf-card.active {
  border-color: #4f46e5 !important;
  border-width: 2px !important;
  box-shadow: 0 6px 20px rgba(79,70,229,.18) !important;
}

#rfmf-app .rfmf-card-header {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 14px 16px 10px !important;
  border-bottom: 1px solid #f0f4ff !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-logo {
  width: 48px !important;
  height: 48px !important;
  border-radius: 10px !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  border: 1px solid #e0e7ff !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  -webkit-justify-content: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}
#rfmf-app .rfmf-card-logo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
#rfmf-app .rfmf-card-name {
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: #1a1a2e !important;
  margin: 0 !important;
  padding: 0 !important;
}
#rfmf-app .rfmf-card-type-row {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 5px !important;
  margin-top: 4px !important;
}
#rfmf-app .rfmf-card-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}
#rfmf-app .rfmf-card-type-label {
  font-size: 11px !important;
  color: #6b7280 !important;
  margin: 0 !important;
}

#rfmf-app .rfmf-card-body {
  padding: 12px 16px !important;
  -webkit-flex: 1 !important;
  flex: 1 !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
  gap: 7px !important;
}
#rfmf-app .rfmf-card-ville {
  font-size: 12px !important;
  color: #6b7280 !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-tags {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
}
#rfmf-app .rfmf-ctag {
  font-size: 10px !important;
  padding: 2px 8px !important;
  border-radius: 20px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  display: inline-block !important;
}
#rfmf-app .rfmf-ctag-dom   { background: #eef2ff !important; color: #3730a3 !important; }
#rfmf-app .rfmf-ctag-instr { background: #fdf4ff !important; color: #7e22ce !important; }

#rfmf-app .rfmf-card-contact {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
  gap: 4px !important;
  padding-top: 8px !important;
  border-top: 1px solid #f0f4ff !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-person {
  font-size: 12px !important;
  color: #374151 !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-mail {
  font-size: 11px !important;
  color: #4f46e5 !important;
  word-break: break-all !important;
  margin: 0 !important;
}

#rfmf-app .rfmf-card-footer {
  padding: 10px 16px 12px !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  -webkit-justify-content: space-between !important;
  justify-content: space-between !important;
  border-top: 1px solid #f0f4ff !important;
  gap: 8px !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-socials {
  display: -webkit-flex !important;
  display: flex !important;
  gap: 5px !important;
}
#rfmf-app .rfmf-social-btn {
  display: -webkit-inline-flex !important;
  display: inline-flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  gap: 4px !important;
  font-size: 11px !important;
  padding: 4px 8px !important;
  border: 1px solid #e0e7ff !important;
  border-radius: 6px !important;
  background: #f5f7ff !important;
  color: #374151 !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  margin: 0 !important;
  transition: all .12s !important;
}
#rfmf-app .rfmf-social-btn:hover {
  border-color: #818cf8 !important;
  background: #eef2ff !important;
  color: #3730a3 !important;
}
#rfmf-app .rfmf-card-link {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #4f46e5 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  margin: 0 !important;
}
#rfmf-app .rfmf-card-link:hover { text-decoration: underline !important; }

#rfmf-app .rfmf-no-results {
  padding: 40px !important;
  text-align: center !important;
  color: #9ca3af !important;
  font-size: 14px !important;
  width: 100% !important;
}

/* ======== RESPONSIVE ======== */
@media (max-width: 900px) {
  #rfmf-app .rfmf-card { max-width: calc(50% - 7px) !important; }
}
@media (max-width: 600px) {
  #rfmf-app #rfmf-toolbar { gap: 6px !important; padding: 10px !important; }
  #rfmf-app .rfmf-dd-wrap { -webkit-flex: 1 1 calc(50% - 6px) !important; flex: 1 1 calc(50% - 6px) !important; max-width: none !important; }
  #rfmf-app .rfmf-search-wrap { -webkit-flex: 1 1 100% !important; flex: 1 1 100% !important; max-width: none !important; }
  #rfmf-app #rfmf-map-wrap { height: 280px !important; }
  #rfmf-app .rfmf-card { max-width: 100% !important; }
}


/* Fiche active (clic marqueur) */
.rfmf-lab-card.rfmf-active {
    outline: 3px solid #4f46e5 !important;
    box-shadow: 0 0 0 6px rgba(79,70,229,.15) !important;
}
