/* Styles modernes pour la page de détail d'une ville */

.city-container {
  padding-bottom: 3rem;
}

/* En-tête de ville modernisé sans fond */
.city-header.modern-header {
  background: none;
  color: var(--text-color);
  padding: 3.5rem 0 2rem;
  margin-bottom: 2.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: none;
}

.city-header.modern-header::before,
.city-header.modern-header::after {
  display: none; /* Supprime les effets de motif et de vague */
}

.city-header.modern-header .city-title {
  font-size: 3.5rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  text-shadow: none;
  font-family: var(--font-heading);
  letter-spacing: -0.5px;
  position: relative;
  color: var(--text-color);
  border-bottom: 4px solid var(--primary-color);
  display: inline-block;
  padding-bottom: 0.5rem;
}

.city-header.modern-header .city-subtitle {
  font-size: 1.3rem;
  opacity: 0.85;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 400;
  position: relative;
  color: var(--text-color);
}

.city-header.modern-header .city-population {
  background-color: var(--primary-color);
  color: white;
  border-radius: 20px;
  padding: 1.5rem;
  display: inline-block;
  text-align: center;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
  border: none;
}

/* Styles pour la description de la ville */
.city-description {
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: 16px;
  padding: 2rem;
  font-size: 1.1rem;
  line-height: 1.6;
  color: var(--text-color);
  border-left: 4px solid var(--primary-color);
}

/* Style pour le contenu WYSIWYG */
.wysiwyg-content {
  line-height: 1.7;
}

.wysiwyg-content h1, 
.wysiwyg-content h2, 
.wysiwyg-content h3, 
.wysiwyg-content h4, 
.wysiwyg-content h5, 
.wysiwyg-content h6 {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  font-family: var(--font-heading);
  color: var(--text-color);
}

.wysiwyg-content p {
  margin-bottom: 1rem;
}

.wysiwyg-content ul, 
.wysiwyg-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

.wysiwyg-content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 1rem 0;
}

.wysiwyg-content a {
  color: var(--primary-color);
  text-decoration: none;

  transition: border-color 0.2s;
  font-size: 0.8em; /* Taille réduite */
  vertical-align: super; 
  
}


.wysiwyg-content a:hover {
  border-color: var(--primary-color);
}

.wysiwyg-content blockquote {
  border-left: 4px solid var(--primary-color);
  padding-left: 1rem;
  margin-left: 0;
  font-style: italic;
  color: #666;
}

/* Nouveau style moderne pour les icônes */
.city-info-icon.modern-icon {
  width: 50px;
  height: 50px;
  background: #f0f0f0; /* Couleur de fond neutre */
  border-radius: 50%; /* Forme circulaire */
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 15px;
  color: #4a90e2; /* Couleur moderne et apaisante */
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Ombre douce pour un effet de profondeur */
  transition: background-color 0.3s ease, color 0.3s ease; /* Transition pour un effet interactif */
}

.city-info-icon.modern-icon:hover {
  background: #4a90e2; /* Inversion des couleurs au survol */
  color: #fff; /* Texte blanc pour contraste */
}

/* Nouveau style pour le badge d'année */
.year-badge {
  background: #4a90e2; /* Couleur bleue moderne */
  color: white;
  padding: 0.4rem 1rem;
  border-radius: 8px; /* Coins moins arrondis pour un look plus moderne */
  font-size: 0.9rem;
  font-weight: 500; /* Légèrement moins gras */
  box-shadow: none; /* Suppression de l'ombre */
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Effet de survol subtil */
.year-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

/* Ajout d'un petit effet visuel */
.year-badge::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(255,255,255,0.1), rgba(255,255,255,0));
  pointer-events: none;
}

/* Ajout d'une petite icône */
.year-badge::after {
  content: "\f073"; /* Code FontAwesome pour l'icône de calendrier */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-left: 0.5rem;
  font-size: 0.8rem;
}

/* Le reste du CSS reste inchangé */
.city-population {
  background-color: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 1.5rem;
  display: inline-block;
  text-align: center;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.2);
  position: relative;
}

.city-population:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
}

.population-number {
  font-size: 2.8rem;
  font-weight: 700;
  display: block;
  line-height: 1;
  margin-bottom: 0.5rem;
}

.population-label {
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 500;
}

.population-year {
  font-size: 0.9rem;
  opacity: 0.85;
  margin-top: 0.5rem;
  font-style: italic;
}

/* Styles modernes pour la carte de population */
.population-card {
  background: linear-gradient(135deg, var(--primary-color), #2980b9);
  color: white;
  border-radius: 16px;
  padding: 1.2rem;
  display: inline-block;
  text-align: center;
  box-shadow: 0 8px 20px rgba(52, 152, 219, 0.2);
  transition: all 0.3s ease;
  border: none;
  position: relative;
  overflow: hidden;
  max-width: 220px;
  margin-bottom: 1.5rem;
  transform: translateZ(0);
}

.population-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
  z-index: 1;
  pointer-events: none;
}

.population-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 25px rgba(52, 152, 219, 0.3);
}

.population-card-title {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 500;
  margin-bottom: 0.3rem;
  opacity: 0.9;
  position: relative;
  z-index: 2;
}

.population-card-value {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
  position: relative;
  z-index: 2;
  line-height: 1.1;
}

.population-card-year {
  font-size: 0.75rem;
  opacity: 0.8;
  font-style: italic;
  position: relative;
  z-index: 2;
}

/* Ajout d'une petite icône */
.population-card::after {
  content: "\f500"; /* Icône "users" de FontAwesome */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  bottom: -15px;
  right: -15px;
  font-size: 3.5rem;
  opacity: 0.1;
  color: white;
  z-index: 1;
}

.city-card {
  background-color: var(--background-color);
  border-radius: 20px;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
  margin-bottom: 2rem;
  height: 100%;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.city-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}

.city-card-header {
  padding: 1.5rem 2rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: rgba(0, 0, 0, 0.02);
}

.city-card-header h2 {
  font-size: 1.6rem;
  margin: 0;
  color: var(--text-color);
  display: flex;
  align-items: center;
  font-family: var(--font-heading);
  font-weight: 600;
}

.city-card-header h2 i {
  margin-right: 1rem;
  color: var(--primary-color);
  font-size: 1.3rem;
}

.city-card-body {
  padding: 2rem;
}

.age-chart-container {
  height: 400px;
  position: relative;
}

.no-data-message {
  text-align: center;
  padding: 3rem 2rem;
  color: #6c757d;
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.no-data-message i {
  font-size: 3.5rem;
  margin-bottom: 1.5rem;
  color: var(--navbar-link-hover-color);
  opacity: 0.7;
}

.programs-list {
  display: flex;
  flex-direction: column;
  gap: 1.8rem;
  max-height: 500px;
  overflow-y: auto;
  padding-right: 0.75rem;
}

.programs-list::-webkit-scrollbar {
  width: 6px;
}

.programs-list::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 10px;
}

.programs-list::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 10px;
}

.programs-list::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}

.program-item {
  display: flex;
  gap: 1.5rem;
  padding-bottom: 1.8rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease;
}

.program-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.program-item:hover {
  transform: translateY(-3px);
}

.program-image {
  width: 120px;
  height: 120px;
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.program-image a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  cursor: pointer;
}

.program-image a::after {
  content: "\f002"; /* Icône de loupe FontAwesome */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  background-color: rgba(0, 0, 0, 0.5);
  color: white;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.program-image a:hover::after {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

.program-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.program-image a:hover img {
  transform: scale(1.05);
}

.program-image-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #adb5bd;
  font-size: 2.5rem;
}

.program-details {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.program-title {
  font-size: 1.3rem;
  margin: 0 0 0.75rem 0;
  line-height: 1.3;
  font-family: var(--font-heading);
}

.program-title a {
  color: var(--text-color);
  text-decoration: none;
  transition: color 0.2s;
}

.program-title a:hover {
  color: var(--primary-color);
}

.program-developer, .program-delivery {
  font-size: 1rem;
  color: #6c757d;
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
}

.program-developer i, .program-delivery i {
  width: 20px;
  margin-right: 0.5rem;
  text-align: center;
  color: var(--navbar-link-hover-color);
}

.program-action {
  margin-top: auto;
  padding-top: 1rem;
}

.program-action .btn {
  border-radius: 30px;
  padding: 0.5rem 1.2rem;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}

.program-action .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);
}

.city-info-content {
  padding: 1rem 0;
}

.city-info-stat {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.8rem;
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: 16px;
  margin-bottom: 1.5rem;
  transition: transform 0.3s ease;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.03);
}

.city-info-stat:hover {
  transform: translateY(-3px);
  background-color: rgba(0, 0, 0, 0.03);
}

.city-info-text h4 {
  font-size: 1.2rem;
  margin: 0 0 0.5rem 0;
  color: var(--text-color);
  font-family: var(--font-heading);
}

.city-info-text p {
  margin: 0;
  color: #6c757d;
  font-size: 1.1rem;
}

.city-info-placeholder {
  text-align: center;
  padding: 2.5rem 2rem;
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: 16px;
  color: #6c757d;
}

/* Section de débogage */
.debug-info {
  margin-top: 2rem;
  margin-bottom: 3rem;
}

.debug-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.debug-list li {
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.debug-list li:last-child {
  border-bottom: none;
}

/* Style élégant pour les liens de référence */
.reference-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--text-color);
  background-color: #f8f9fa;
  border-radius: 50%;
  text-decoration: none;
  border: 1px solid rgba(0, 0, 0, 0.1);
  position: relative;
  top: -0.5em;
  margin: 0 1px;
  transition: all 0.25s ease;
}

.reference-link:hover {
  background-color: var(--navbar-link-hover-color);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(255, 64, 0, 0.2);
  border-color: var(--navbar-link-hover-color);
}

/* Animation subtile au survol */
@keyframes pulse {
  0% { transform: scale(1) translateY(-0.5em); }
  50% { transform: scale(1.1) translateY(-0.5em); }
  100% { transform: scale(1) translateY(-0.5em); }
}

.reference-link:hover {
  animation: pulse 0.5s ease;
}

/* Style pour la section des références */
.references-list {
  padding-left: 1.5rem;
  margin-bottom: 0;
}

.references-list li {
  margin-bottom: 0.75rem;
  color: var(--text-color);
  font-size: 0.95rem;
  line-height: 1.5;
}

.references-list li:last-child {
  margin-bottom: 0;
}

/* Responsive */
@media (max-width: 992px) {
  .city-header.modern-header {
    padding: 2.5rem 0 2rem;
  }
  
  .city-header.modern-header .city-title {
    font-size: 2.7rem;
  }
  
  .city-population {
    margin-top: 1rem;
  }
  
  .age-chart-container {
    height: 350px;
  }
}

@media (max-width: 768px) {
  .city-header.modern-header {
    text-align: center;
    padding: 2rem 0 2rem;
  }
  
  .city-header.modern-header .city-title {
    font-size: 2.2rem;
  }
  
  .city-population {
    margin: 1.5rem auto 0;
  }
  
  .population-card {
    max-width: 180px;
    margin: 0 auto 1.5rem;
  }
  
  .program-image {
    width: 100px;
    height: 100px;
  }
  
  .city-info-stat {
    flex-direction: column;
    text-align: center;
    padding: 1.5rem;
  }
  
  .city-info-icon.modern-icon {
    margin-bottom: 1rem;
    margin-right: 0;
  }
  
  .reference-link {
    width: 14px;
    height: 14px;
    font-size: 0.65rem;
  }
}

@media (max-width: 576px) {
  .city-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
  
  .year-badge {
    align-self: flex-start;
  }
  
  .program-item {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1rem;
  }
  
  .program-image {
    width: 140px;
    height: 140px;
  }
  
  .program-developer, .program-delivery {
    justify-content: center;
  }
}
/* Carte « Prix de l'immobilier » (lien vers la page prix dédiée DVF) */
.city-card--price .city-card-body { display: flex; flex-direction: column; gap: 0.75rem; }
.city-price-teaser { margin: 0; font-size: 1rem; line-height: 1.5; }
.city-price-teaser-link {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.6rem 1.2rem;
    border-radius: 999px;
    background: var(--vefa-accent, #ff4000);
    color: #fff;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.2s ease;
}
.city-price-teaser-link:hover { transform: translateY(-2px); color: #fff; text-decoration: none; }

/* ===== Page commune unifiée — nouveaux blocs ===== */
.city-keyfacts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 1.25rem 0 0;
}
.city-keyfact {
    display: flex;
    flex-direction: column;
    padding: 0.7rem 1.1rem;
    border-radius: 12px;
    background: var(--vefa-surface, #fff);
    border: 1px solid var(--vefa-border, #e2e8f0);
    min-width: 120px;
}
.city-keyfact__value { font-size: 1.35rem; font-weight: 800; color: var(--vefa-accent, #ff4000); line-height: 1.1; }
.city-keyfact__label { font-size: 0.78rem; color: var(--vefa-text-muted, #475569); }

.city-detail-viz { margin: 0; }

.city-developers { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.75rem; }
.city-developer { display: flex; flex-direction: column; gap: 0.2rem; padding: 0.85rem 1rem; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; text-decoration: none; background: var(--vefa-surface, #fff); transition: transform .2s ease, border-color .2s ease; }
.city-developer:hover { transform: translateY(-2px); border-color: var(--vefa-accent, #ff4000); }
.city-developer__name { font-weight: 700; color: var(--vefa-text, #1e293b); }
.city-developer__meta { font-size: 0.8rem; color: var(--vefa-text-muted, #475569); }

.city-editorial { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; }
.city-editorial__block h3 { font-size: 1.05rem; font-weight: 700; margin: 0 0 0.5rem; color: var(--vefa-text, #1e293b); }
.city-editorial__block h3 i { color: var(--vefa-accent, #ff4000); margin-right: 0.4rem; }

.city-articles { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 0.75rem; }
.city-article { display: flex; flex-direction: column; gap: 0.35rem; padding: 0.85rem 1rem; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; text-decoration: none; background: var(--vefa-surface, #fff); transition: transform .2s ease; }
.city-article:hover { transform: translateY(-2px); }
.city-article__cat { font-size: 0.72rem; text-transform: uppercase; letter-spacing: .03em; color: var(--vefa-primary, #3498db); font-weight: 700; }
.city-article__title { font-weight: 600; color: var(--vefa-text, #1e293b); line-height: 1.35; }

.city-faq__item { border-bottom: 1px solid var(--vefa-border, #e2e8f0); padding: 0.5rem 0; }
.city-faq__q { font-weight: 700; cursor: pointer; color: var(--vefa-text, #1e293b); }
.city-faq__a { margin-top: 0.5rem; color: var(--vefa-text-muted, #475569); line-height: 1.55; }

.city-neighbors { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.city-neighbor { padding: 0.4rem 0.9rem; border-radius: 999px; background: var(--vefa-surface-alt, #f1f5f9); border: 1px solid var(--vefa-border, #e2e8f0); text-decoration: none; color: var(--vefa-text, #1e293b); font-size: 0.85rem; }
.city-neighbor:hover { border-color: var(--vefa-accent, #ff4000); }
.city-neighbor--dept { font-weight: 700; color: var(--vefa-accent, #ff4000); }

/* ===== Bandeau hero commune (photo Wikimedia / carte OSM) ===== */
.city-hero-media {
    position: relative;
    width: 100%;
    max-height: 320px;
    overflow: hidden;
    border-radius: 0 0 16px 16px;
    margin-bottom: 1rem;
}
.city-hero-img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    display: block;
}
.city-hero-credit {
    position: absolute;
    bottom: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    font-size: 0.7rem;
    padding: 0.2rem 0.6rem;
    border-top-left-radius: 8px;
    max-width: 70%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
@media (max-width: 768px) {
    .city-hero-media, .city-hero-img { max-height: 200px; height: 200px; }
}

/* ===== Hub « top villes » (/villes/) ===== */
.cities-hub { max-width: 1000px; margin: 0 auto; padding: 2rem 1rem 3rem; }
.cities-hub__hero { text-align: center; margin-bottom: 2.5rem; }
.cities-hub__hero h1 { font-size: clamp(1.8rem, 4vw, 2.5rem); font-weight: 800; color: var(--vefa-text, #1e293b); margin: 0 0 .6rem; }
.cities-hub__hero p { color: var(--vefa-text-muted, #475569); max-width: 680px; margin: 0 auto; line-height: 1.55; }
.cities-rank { margin-bottom: 2.5rem; }
.cities-rank__title { font-size: 1.3rem; font-weight: 800; color: var(--vefa-text, #1e293b); margin: 0 0 1rem; }
.cities-rank__title i { color: var(--vefa-accent, #ff4000); margin-right: .5rem; }
.cities-rank__list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: .6rem; }
.cities-rank__item { display: flex; align-items: center; gap: .7rem; padding: .7rem 1rem; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; background: var(--vefa-surface, #fff); }
.cities-rank__pos { font-weight: 800; color: var(--vefa-accent, #ff4000); min-width: 1.4rem; }
.cities-rank__city { flex: 1; text-decoration: none; color: var(--vefa-text, #1e293b); font-weight: 700; }
.cities-rank__city:hover { color: var(--vefa-accent, #ff4000); }
.cities-rank__name small { font-weight: 400; color: var(--vefa-text-muted, #475569); }
.cities-rank__metric { font-size: .85rem; color: var(--vefa-text-muted, #475569); white-space: nowrap; }
.cities-rank__price-link { font-size: .75rem; color: var(--vefa-primary, #3498db); text-decoration: none; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 999px; padding: .15rem .5rem; }
.cities-rank__price-link:hover { border-color: var(--vefa-primary, #3498db); }

/* ===== Refonte city_detail : layout unifié (tokens --vefa-*) ===== */
.city-detail__hero-body { padding-top: 1.5rem; padding-bottom: .5rem; }
.city-detail .city-title { font-size: clamp(1.7rem, 4vw, 2.4rem); font-weight: 800; color: var(--vefa-text, #1e293b); margin: 0 0 .4rem; }
.city-detail .city-subtitle { color: var(--vefa-text-muted, #475569); font-size: 1rem; margin: 0 0 1rem; }
.city-detail .city-subtitle i { color: var(--vefa-accent, #ff4000); }

.city-zone { margin: 2.2rem 0; }
.city-zone__title { font-size: 1.5rem; font-weight: 800; color: var(--vefa-text, #1e293b); margin: 0 0 1.1rem; padding-bottom: .5rem; border-bottom: 2px solid var(--vefa-accent-soft, rgba(255,64,0,.12)); }
.city-zone__title i { color: var(--vefa-accent, #ff4000); margin-right: .5rem; }

/* Cartes unifiées sur tokens (override du legacy) */
.city-detail .city-card { background: var(--vefa-surface, #fff); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: var(--vefa-radius, 14px); box-shadow: var(--vefa-shadow-sm, 0 1px 3px rgba(15,23,42,.06)); margin-bottom: 1.2rem; overflow: hidden; }
.city-detail .city-card-header { padding: 1rem 1.3rem .4rem; display: flex; align-items: center; justify-content: space-between; }
.city-detail .city-card-header h2, .city-detail .city-card-header h3 { font-size: 1.15rem; font-weight: 700; color: var(--vefa-text, #1e293b); margin: 0; }
.city-detail .city-card-header i { color: var(--vefa-accent, #ff4000); margin-right: .4rem; }
.city-detail .city-card-body { padding: 1rem 1.3rem 1.3rem; }
.city-card--price { border-color: var(--vefa-accent, #ff4000); background: var(--vefa-accent-soft, rgba(255,64,0,.05)); }
.city-card-cta { margin-top: 1rem; }
.city-viz-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; margin: 1rem 0; }
.city-viz-grid .vefa-viz { margin: 0; }
.year-badge { font-size: .75rem; background: var(--vefa-surface-alt, #f1f5f9); color: var(--vefa-text-muted, #475569); padding: .15rem .6rem; border-radius: 999px; }
.no-data-message { color: var(--vefa-text-muted, #475569); text-align: center; padding: 1.5rem; }
.city-editorial__block h4 { font-size: 1rem; font-weight: 700; margin: 0 0 .4rem; color: var(--vefa-text, #1e293b); }
.city-editorial__block h4 i { color: var(--vefa-accent, #ff4000); margin-right: .35rem; }
.city-map { height: 360px; border-radius: var(--vefa-radius, 12px); z-index: 0; }

/* Carte « projets à venir » (permis Sit@del) — hub commune */
.city-card--upcoming { display: block; text-decoration: none; border-left: 4px solid var(--vefa-accent, #ff4000); transition: transform .15s ease, box-shadow .15s ease; }
.city-card--upcoming:hover { transform: translateY(-2px); box-shadow: var(--vefa-shadow-lg, 0 10px 25px -5px rgba(15,23,42,.1)); }
.city-upcoming__title { margin: 0 0 6px; color: var(--vefa-text-strong, #0b1b30); }
.city-upcoming__title i { color: var(--vefa-accent, #ff4000); }
.city-upcoming__text { margin: 0 0 10px; color: var(--vefa-text-muted, #475569); }

/* Carte « Loyers de référence » (ANIL) — hub commune, accent investisseur (bleu primary) */
.city-card--rent { border-left: 4px solid var(--vefa-primary, #2563eb); }
.city-rent-teaser { margin: 0 0 .5rem; }
.city-rent-teaser-sub { margin: 0 0 .5rem; font-size: .92rem; }

/* Carte « Fiscalité locale » (taux DGFiP) — hub commune, accent neutre/administratif (slate) */
.city-card--tax { border-left: 4px solid var(--vefa-text-muted, #475569); }
.city-tax-teaser { margin: 0 0 .5rem; }
.city-tax-note { margin: 0; font-size: .9rem; }

/* ===== Hero 2 colonnes + Résumé express (refonte 2026-06) ===== */
.city-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(290px, .9fr);
    gap: 2rem;
    align-items: start;
}
.city-hero-main { min-width: 0; }
.city-hero-pitch {
    color: var(--vefa-text-muted, #475569);
    font-size: 1.05rem;
    line-height: 1.55;
    max-width: 46ch;
    margin: 0 0 1.25rem;
}
.city-hero-cta { display: flex; flex-wrap: wrap; gap: .7rem; }
.city-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .7rem 1.4rem;
    border-radius: var(--vefa-radius-pill, 999px);
    font-weight: 700;
    font-size: .95rem;
    text-decoration: none;
    border: 1px solid transparent;
    transition: transform var(--vefa-duration-fast, .15s) var(--vefa-ease, ease), box-shadow var(--vefa-duration-fast, .15s) ease, background var(--vefa-duration-fast, .15s) ease;
}
.city-btn i { font-size: .9em; }
.city-btn--primary { background: var(--vefa-accent, #ff4000); color: #fff; box-shadow: var(--vefa-shadow-sm, 0 1px 3px rgba(15,23,42,.12)); }
.city-btn--primary:hover { background: var(--vefa-accent-dark, #d93600); color: #fff; transform: translateY(-2px); box-shadow: var(--vefa-shadow-md, 0 6px 16px rgba(217,54,0,.25)); }
.city-btn--ghost { background: var(--vefa-surface, #fff); color: var(--vefa-text, #0f172a); border-color: var(--vefa-border-strong, #cbd5e1); }
.city-btn--ghost:hover { border-color: var(--vefa-accent, #ff4000); color: var(--vefa-accent, #ff4000); transform: translateY(-2px); }

.city-summary-card {
    background: var(--vefa-surface, #fff);
    border: 1px solid var(--vefa-border, #e2e8f0);
    border-top: 3px solid var(--vefa-accent, #ff4000);
    border-radius: var(--vefa-radius-lg, 16px);
    box-shadow: var(--vefa-shadow-md, 0 4px 14px rgba(15,23,42,.08));
    padding: 1.1rem 1.25rem 1.25rem;
}
.city-summary-card__title {
    margin: 0 0 .9rem;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--vefa-text-muted, #475569);
}
.city-summary-card__title i { color: var(--vefa-accent, #ff4000); margin-right: .35rem; }
.city-summary-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem .9rem; }
.city-summary-item { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.city-summary-item__value { font-size: 1.55rem; font-weight: 800; line-height: 1.05; color: var(--vefa-text-strong, #0b1b30); }
.city-summary-item__value--sm { font-size: 1.05rem; }
.city-summary-item__label { font-size: .76rem; color: var(--vefa-text-muted, #475569); line-height: 1.25; }

@media (max-width: 900px) {
    .city-hero-grid { grid-template-columns: 1fr; gap: 1.4rem; }
    .city-summary-card { order: -1; }
}

/* ===== Carte programme compacte (page commune) ===== */
.city-programs-intro { margin: 0 0 1rem; font-size: .95rem; }
.program-card--compact .program-card__body { display: flex; flex-direction: column; gap: .35rem; }
.program-card--compact .program-card__meta { font-size: .85rem; color: var(--vefa-text-muted, #475569); display: flex; flex-wrap: wrap; gap: .15rem .4rem; margin: 0; }
.program-card__followers { margin: .1rem 0 0; font-size: .82rem; color: var(--vefa-text-muted, #475569); display: inline-flex; align-items: center; gap: .35rem; }
.program-card__followers i { color: var(--vefa-accent, #ff4000); }
.city-program-card__cta {
    margin-top: auto;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-weight: 700;
    font-size: .9rem;
    color: var(--vefa-accent, #ff4000);
    background: none;
    padding: .5rem 0 0;
    text-decoration: none;
}
.city-program-card__cta:hover { color: var(--vefa-accent-dark, #d93600); text-decoration: none; }
.city-program-card__cta i { transition: transform var(--vefa-duration-fast, .15s) ease; }
.city-program-card__cta:hover i { transform: translateX(3px); }

/* ===== Bloc « Projets à venir » premium ===== */
.city-card--premium {
    border-left-width: 4px;
    background: linear-gradient(135deg, var(--vefa-accent-soft, rgba(255,64,0,.06)) 0%, var(--vefa-surface, #fff) 60%);
}
.city-premium-tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: var(--vefa-accent, #ff4000);
    color: #fff;
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .03em;
    text-transform: uppercase;
    padding: .25rem .6rem;
    border-radius: var(--vefa-radius-pill, 999px);
    margin-bottom: .6rem;
}

/* ===== Promoteur en tête de liste (mise en avant) ===== */
.city-developer--lead { border-color: var(--vefa-accent, #ff4000); background: var(--vefa-accent-soft, rgba(255,64,0,.05)); }
.city-developer--lead .city-developer__name { color: var(--vefa-accent-dark, #d93600); }

/* ===== Bloc risques (réassurance, discret) ===== */
.city-risks-loading { opacity: .85; }
.city-risks-loading .city-card-header h3 { font-size: 1.05rem; color: var(--vefa-text-muted, #475569); }
.city-risks-loading .city-card-header i { color: var(--vefa-text-subtle, #94a3b8); }

/* ============================================================
   Refonte « dashboard moderne » de la page commune (cityx-*).
   Hero carte en débord + barre de stats sombre + sidebar sticky
   + sections « Voir le détail ». Palette VefaConnect (accent orange).
   ============================================================ */
.cityx { --cityx-navy: #102a43; max-width: 1200px; margin: 0 auto; padding: 1rem 1rem 3rem; }

.cityx-breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem; font-size: .85rem; color: var(--vefa-text-muted, #475569); margin: .25rem 0 1rem; }
.cityx-breadcrumb a { color: var(--vefa-text-muted, #475569); text-decoration: none; }
.cityx-breadcrumb a:hover { color: var(--vefa-accent, #ff4000); }
.cityx-breadcrumb__sep { color: var(--vefa-text-subtle, #94a3b8); }
.cityx-breadcrumb__current { color: var(--vefa-text, #0f172a); font-weight: 600; }

/* ===== HERO ===== */
.cityx-hero { position: relative; margin-bottom: 2rem; }
.cityx-hero__img { position: relative; width: 100%; height: clamp(330px, 34vw, 400px); border-radius: 18px 18px 0 0; overflow: hidden; background: var(--vefa-bg-muted, #f1f5f9); }
.cityx-hero__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cityx-hero__credit { position: absolute; bottom: 6px; right: 8px; background: rgba(0,0,0,.55); color: #fff; font-size: .68rem; padding: .15rem .5rem; border-radius: 6px; max-width: 60%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.cityx-hero__card { position: absolute; top: 26px; left: 26px; width: min(430px, 54%); background: var(--vefa-surface, #fff); border-radius: 16px; box-shadow: 0 18px 40px -12px rgba(15,23,42,.38); padding: 1.4rem 1.5rem; z-index: 3; }
.cityx-hero__name { font-size: clamp(1.7rem, 3vw, 2.3rem); font-weight: 800; color: var(--vefa-text-strong, #0b1b30); margin: 0 0 .35rem; line-height: 1.1; }
.cityx-hero__meta { display: flex; flex-wrap: wrap; align-items: baseline; gap: .25rem .7rem; margin-bottom: .65rem; }
.cityx-hero__postal { font-weight: 700; color: var(--vefa-accent, #ff4000); font-size: 1rem; }
.cityx-hero__loc { color: var(--vefa-text-muted, #475569); font-size: .9rem; }
.cityx-hero__chips { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: .8rem; }
.cityx-chip { display: inline-flex; align-items: center; gap: .35rem; background: var(--vefa-bg-muted, #f1f5f9); color: var(--vefa-text, #0f172a); font-size: .74rem; font-weight: 600; padding: .26rem .6rem; border-radius: 999px; }
.cityx-chip i { color: var(--vefa-accent, #ff4000); font-size: .7rem; }
.cityx-hero__desc { color: var(--vefa-text-muted, #475569); font-size: .9rem; line-height: 1.5; margin: 0 0 1rem; }

.cityx-hero__stats { background: var(--cityx-navy); border-radius: 0 0 18px 18px; padding: 1.2rem clamp(1rem, 4vw, 2.4rem); display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1.1rem; }
.cityx-stat-pill { display: flex; align-items: center; gap: .65rem; color: #fff; min-width: 0; }
.cityx-stat-pill > i { font-size: 1.05rem; color: var(--vefa-accent, #ff4000); width: 1.4rem; text-align: center; flex-shrink: 0; }
.cityx-stat-pill__value { display: block; font-size: 1.25rem; font-weight: 800; line-height: 1.1; }
.cityx-stat-pill__label { display: block; font-size: .72rem; color: rgba(255,255,255,.66); margin-top: .1rem; }

/* ===== Layout 2 colonnes ===== */
.cityx-layout { display: grid; grid-template-columns: 256px minmax(0, 1fr); gap: 2rem; align-items: start; }
.cityx-main { min-width: 0; }

.cityx-sidebar { position: sticky; top: 80px; display: flex; flex-direction: column; gap: 1rem; }
.cityx-nav { display: flex; flex-direction: column; gap: 2px; background: var(--vefa-surface, #fff); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 14px; padding: .5rem; }
.cityx-nav__link { display: flex; align-items: center; gap: .7rem; padding: .58rem .75rem; border-radius: 9px; color: var(--vefa-text-muted, #475569); text-decoration: none; font-size: .89rem; font-weight: 600; border-left: 3px solid transparent; transition: background .15s ease, color .15s ease; }
.cityx-nav__link i { width: 1.1rem; text-align: center; color: var(--vefa-text-subtle, #94a3b8); font-size: .88rem; }
.cityx-nav__link:hover { background: var(--vefa-bg-muted, #f1f5f9); color: var(--vefa-text, #0f172a); }
.cityx-nav__link.is-active { background: var(--vefa-accent-soft, rgba(255,64,0,.08)); color: var(--vefa-accent-dark, #d93600); border-left-color: var(--vefa-accent, #ff4000); }
.cityx-nav__link.is-active i { color: var(--vefa-accent, #ff4000); }

.cityx-side-card { background: var(--vefa-surface, #fff); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 14px; padding: 1.1rem 1.2rem; }
.cityx-side-card--invest { border-top: 3px solid var(--vefa-accent, #ff4000); }
.cityx-side-card__title { font-size: 1rem; font-weight: 800; color: var(--vefa-text-strong, #0b1b30); margin: 0 0 .8rem; }
.cityx-side-card__title i { color: var(--vefa-accent, #ff4000); margin-right: .35rem; }
.cityx-checks { list-style: none; margin: 0 0 1rem; padding: 0; display: flex; flex-direction: column; gap: .5rem; }
.cityx-checks li { display: flex; align-items: flex-start; gap: .5rem; font-size: .84rem; color: var(--vefa-text, #0f172a); line-height: 1.35; }
.cityx-checks li i { color: var(--vefa-success, #16a34a); margin-top: .15rem; font-size: .78rem; }
.cityx-side-news { list-style: none; margin: 0 0 .6rem; padding: 0; display: flex; flex-direction: column; }
.cityx-side-news li + li { border-top: 1px solid var(--vefa-border-subtle, #f1f5f9); }
.cityx-side-news a { display: flex; flex-direction: column; gap: .15rem; padding: .55rem 0; text-decoration: none; }
.cityx-side-news__cat { font-size: .67rem; text-transform: uppercase; letter-spacing: .03em; font-weight: 700; color: var(--vefa-primary, #3498db); }
.cityx-side-news__title { font-size: .84rem; font-weight: 600; color: var(--vefa-text, #0f172a); line-height: 1.3; }
.cityx-side-news a:hover .cityx-side-news__title { color: var(--vefa-accent, #ff4000); }
.cityx-side-card__more { font-size: .82rem; font-weight: 700; color: var(--vefa-accent, #ff4000); text-decoration: none; }

/* Boutons */
.cityx-btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .7rem 1.3rem; border-radius: 999px; font-weight: 700; font-size: .9rem; text-decoration: none; border: 1px solid transparent; transition: transform .15s ease, background .15s ease, box-shadow .15s ease; cursor: pointer; }
.cityx-btn--primary { background: var(--vefa-accent, #ff4000); color: #fff; }
.cityx-btn--primary:hover { background: var(--vefa-accent-dark, #d93600); color: #fff; transform: translateY(-2px); box-shadow: 0 8px 18px -6px rgba(217,54,0,.5); }
.cityx-btn--block { width: 100%; }

/* Sections */
.cityx-section { margin-bottom: 2.4rem; scroll-margin-top: 88px; }
.cityx-section__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.cityx-section__title { font-size: 1.4rem; font-weight: 800; color: var(--vefa-text-strong, #0b1b30); margin: 0; }
.cityx-section__more { font-size: .87rem; font-weight: 700; color: var(--vefa-accent, #ff4000); text-decoration: none; white-space: nowrap; }
.cityx-section__more:hover { color: var(--vefa-accent-dark, #d93600); }
.cityx-section__badge { font-size: .73rem; background: var(--vefa-bg-muted, #f1f5f9); color: var(--vefa-text-muted, #475569); padding: .18rem .6rem; border-radius: 999px; font-weight: 600; }
.cityx-section__intro { color: var(--vefa-text-muted, #475569); font-size: .92rem; margin: 0 0 1rem; }
.cityx-section__cta { margin-top: 1.2rem; }

/* Panneaux */
.cityx-panel { background: var(--vefa-surface, #fff); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 14px; padding: 1.3rem 1.4rem; box-shadow: var(--vefa-shadow-sm, 0 1px 3px rgba(15,23,42,.06)); }
.cityx-panel + .cityx-panel { margin-top: 1.2rem; }
.cityx-panel--flush { padding: .5rem; }
.cityx-panel__title { font-size: 1.05rem; font-weight: 700; color: var(--vefa-text, #0f172a); margin: 0 0 1rem; }
.cityx-panel__title i { color: var(--vefa-accent, #ff4000); margin-right: .4rem; }

/* Cartes marché */
.cityx-cards { display: grid; gap: 1rem; }
.cityx-cards--market { grid-template-columns: repeat(auto-fit, minmax(215px, 1fr)); margin-bottom: 1.2rem; }
.cityx-market-card { background: var(--vefa-surface, #fff); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 14px; padding: 1.2rem 1.3rem; display: flex; flex-direction: column; gap: .2rem; box-shadow: var(--vefa-shadow-sm, 0 1px 3px rgba(15,23,42,.06)); }
.cityx-market-card__label { font-size: .9rem; font-weight: 700; color: var(--vefa-text, #0f172a); }
.cityx-market-card__sub { font-size: .75rem; color: var(--vefa-text-subtle, #94a3b8); }
.cityx-market-card__value { font-size: 1.85rem; font-weight: 800; color: var(--vefa-text-strong, #0b1b30); line-height: 1.1; margin: .35rem 0 .1rem; }
.cityx-market-card__range { font-size: .82rem; color: var(--vefa-text-muted, #475569); }
.cityx-market-card__range.cityx-pos { color: var(--vefa-success, #16a34a); font-weight: 700; }
.cityx-market-card__src { font-size: .69rem; color: var(--vefa-text-subtle, #94a3b8); margin-top: .5rem; }
/* Cartes « profil économique / investisseur » (revenus, chômage) — accent primary discret. */
.cityx-market-card--eco { border-left: 3px solid var(--vefa-primary, #3498db); background: var(--vefa-primary-soft, rgba(52,152,219,.05)); }
.cityx-market-card--eco .cityx-market-card__value { color: var(--vefa-primary-dark, #2980b9); }
.cityx-market-charts { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.2rem; }
.cityx-viz { margin: 0; }
.cityx-viz .vefa-viz__title { font-size: .85rem; font-weight: 700; color: var(--vefa-text, #0f172a); margin: 0 0 .5rem; }

.cityx-program-grid { margin: 0 -.5rem; }
.cityx-map { height: 380px; border-radius: 10px; z-index: 0; }
.cityx-map-note { margin: .6rem 0 0; font-size: .78rem; color: var(--vefa-text-muted, #475569); line-height: 1.45; }
.cityx-map-note i { color: var(--vefa-accent, #ff4000); margin-right: .3rem; }
/* Marqueur « cluster » (programmes co-localisés au centroïde commune) */
.cityx-map-cluster { background: transparent; border: 0; }
.cityx-map-cluster span { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; background: var(--vefa-accent, #ff4000); color: #fff; font-weight: 800; font-size: .9rem; border: 2px solid #fff; box-shadow: 0 1px 5px rgba(15,23,42,.35); }
.cityx-map-popup-list { margin: .35rem 0 0; padding-left: 1.1rem; }
.cityx-map-popup-list li { margin: .1rem 0; }

/* Projets à venir (premium) */
.cityx-premium { display: block; text-decoration: none; border: 1px solid var(--vefa-accent, #ff4000); border-left-width: 4px; border-radius: 14px; padding: 1.3rem 1.5rem; background: linear-gradient(135deg, var(--vefa-accent-soft, rgba(255,64,0,.07)) 0%, var(--vefa-surface, #fff) 65%); transition: transform .15s ease, box-shadow .15s ease; }
.cityx-premium:hover { transform: translateY(-2px); box-shadow: 0 12px 26px -10px rgba(255,64,0,.3); }
.cityx-premium__tag { display: inline-flex; align-items: center; gap: .35rem; background: var(--vefa-accent, #ff4000); color: #fff; font-size: .68rem; font-weight: 800; letter-spacing: .03em; text-transform: uppercase; padding: .25rem .6rem; border-radius: 999px; margin-bottom: .6rem; }
.cityx-premium__title { font-size: 1.2rem; font-weight: 800; color: var(--vefa-text-strong, #0b1b30); margin: 0 0 .4rem; }
.cityx-premium__title i { color: var(--vefa-accent, #ff4000); margin-right: .3rem; }
.cityx-premium__text { color: var(--vefa-text-muted, #475569); margin: 0 0 .7rem; font-size: .92rem; }
.cityx-premium__link { font-weight: 700; color: var(--vefa-accent, #ff4000); font-size: .9rem; }

/* Promoteurs */
.cityx-developers { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: .75rem; }
.cityx-dev { display: flex; flex-direction: column; gap: .2rem; padding: .85rem 1rem; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; text-decoration: none; background: var(--vefa-surface, #fff); transition: transform .15s ease, border-color .15s ease; }
.cityx-dev:hover { transform: translateY(-2px); border-color: var(--vefa-accent, #ff4000); }
.cityx-dev__name { font-weight: 700; color: var(--vefa-text, #0f172a); }
.cityx-dev__meta { font-size: .8rem; color: var(--vefa-text-muted, #475569); }
.cityx-dev--lead { border-color: var(--vefa-accent, #ff4000); background: var(--vefa-accent-soft, rgba(255,64,0,.05)); }
.cityx-dev--lead .cityx-dev__name { color: var(--vefa-accent-dark, #d93600); }

/* Cadre de vie */
.cityx-editorial { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.3rem; }
.cityx-editorial__block h4 { font-size: 1rem; font-weight: 700; color: var(--vefa-text, #0f172a); margin: 0 0 .4rem; }
.cityx-editorial__block h4 i { color: var(--vefa-accent, #ff4000); margin-right: .35rem; }

/* Articles */
.cityx-articles { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: .75rem; }
.cityx-article { display: flex; flex-direction: column; gap: .3rem; padding: .85rem 1rem; border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; text-decoration: none; transition: border-color .15s ease; }
.cityx-article:hover { border-color: var(--vefa-accent, #ff4000); }
.cityx-article__cat { font-size: .67rem; text-transform: uppercase; letter-spacing: .03em; font-weight: 700; color: var(--vefa-primary, #3498db); }
.cityx-article__title { font-size: .89rem; font-weight: 600; color: var(--vefa-text, #0f172a); line-height: 1.35; }

/* FAQ */
.cityx-faq { border-bottom: 1px solid var(--vefa-border, #e2e8f0); padding: .6rem 0; }
.cityx-faq:last-child { border-bottom: 0; }
.cityx-faq__q { font-weight: 700; cursor: pointer; color: var(--vefa-text, #0f172a); }
.cityx-faq__a { margin-top: .5rem; color: var(--vefa-text-muted, #475569); line-height: 1.55; }

/* Villes voisines */
.cityx-neighbors { display: flex; flex-wrap: wrap; gap: .5rem; }
.cityx-neighbor { padding: .4rem .9rem; border-radius: 999px; background: var(--vefa-bg-muted, #f1f5f9); border: 1px solid var(--vefa-border, #e2e8f0); text-decoration: none; color: var(--vefa-text, #0f172a); font-size: .85rem; }
.cityx-neighbor:hover { border-color: var(--vefa-accent, #ff4000); }
.cityx-neighbor--accent { font-weight: 700; color: var(--vefa-accent, #ff4000); }

/* Empty */
.cityx-empty { color: var(--vefa-text-muted, #475569); background: var(--vefa-bg-soft, #f8fafc); border: 1px dashed var(--vefa-border-strong, #cbd5e1); border-radius: 12px; padding: 1.2rem 1.4rem; font-size: .92rem; }
.cityx-empty i { color: var(--vefa-accent, #ff4000); margin-right: .4rem; }

/* ===== Responsive ===== */
@media (max-width: 960px) {
    .cityx-layout { grid-template-columns: 1fr; gap: 1.4rem; }
    .cityx-sidebar { position: static; }
    .cityx-nav { flex-direction: row; overflow-x: auto; gap: .35rem; }
    .cityx-nav__link { border-left: 0; border-bottom: 3px solid transparent; white-space: nowrap; flex-shrink: 0; }
    .cityx-nav__link.is-active { border-left: 0; border-bottom-color: var(--vefa-accent, #ff4000); }
}
@media (max-width: 768px) {
    .cityx-hero__img { height: 220px; border-radius: 14px 14px 0 0; }
    .cityx-hero__card { position: static; width: auto; margin: -48px .75rem 0; box-shadow: 0 10px 30px -12px rgba(15,23,42,.4); }
    .cityx-hero__stats { border-radius: 0 0 14px 14px; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .cityx-stat-pill__value { font-size: 1.1rem; }
}
@media (max-width: 420px) {
    .cityx-hero__stats { grid-template-columns: 1fr; }
}

/* ===== Bloc Éducation (annuaire Éduc. nat. + IVAL) ===== */
.cityx-school-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)); gap: .8rem; margin-bottom: 1.3rem; }
.cityx-school-stat { background: var(--vefa-bg-soft, #f8fafc); border: 1px solid var(--vefa-border, #e2e8f0); border-radius: 12px; padding: .9rem 1rem; display: flex; flex-direction: column; gap: .1rem; }
.cityx-school-stat__value { font-size: 1.6rem; font-weight: 800; color: var(--vefa-text-strong, #0b1b30); line-height: 1.05; }
.cityx-school-stat--split .cityx-school-stat__value { font-size: 1.3rem; }
.cityx-school-stat__sep { color: var(--vefa-text-subtle, #94a3b8); margin: 0 .15rem; font-weight: 600; }
.cityx-school-stat__label { font-size: .76rem; color: var(--vefa-text-muted, #475569); }

.cityx-panel__title--sub { font-size: .95rem; margin-top: .2rem; }
.cityx-lycees { list-style: none; margin: 0 0 .9rem; padding: 0; display: flex; flex-direction: column; }
.cityx-lycee { display: flex; align-items: center; justify-content: space-between; gap: .8rem; padding: .6rem 0; border-bottom: 1px solid var(--vefa-border-subtle, #f1f5f9); flex-wrap: wrap; }
.cityx-lycee:last-child { border-bottom: 0; }
.cityx-lycee__name { font-weight: 600; color: var(--vefa-text, #0f172a); font-size: .9rem; }
.cityx-lycee__sector { font-size: .72rem; font-weight: 500; color: var(--vefa-text-subtle, #94a3b8); }
.cityx-lycee__metrics { display: flex; align-items: center; gap: .8rem; }
.cityx-lycee__rate { font-weight: 700; color: var(--vefa-text, #0f172a); font-size: .9rem; display: inline-flex; align-items: baseline; gap: .3rem; }
.cityx-lycee__rate-lbl { font-size: .68rem; font-weight: 500; color: var(--vefa-text-subtle, #94a3b8); }
.cityx-va { display: inline-flex; align-items: baseline; gap: .3rem; font-weight: 800; font-size: .9rem; color: var(--vefa-text-muted, #475569); padding: .1rem .55rem; border-radius: 999px; background: var(--vefa-bg-muted, #f1f5f9); white-space: nowrap; }
.cityx-va__lbl { font-size: .66rem; font-weight: 600; opacity: .85; }
.cityx-va--pos { color: #15803d; background: rgba(22,163,74,.12); }
.cityx-va--neg { color: #b91c1c; background: rgba(220,38,38,.12); }
.cityx-schools__note { font-size: .82rem; color: var(--vefa-text-muted, #475569); line-height: 1.5; margin: .2rem 0 .8rem; padding: .6rem .8rem; background: var(--vefa-bg-soft, #f8fafc); border-radius: 10px; }
.cityx-schools__src { font-size: .7rem; color: var(--vefa-text-subtle, #94a3b8); margin: 0; }
.cityx-schools__hint { font-size: .8rem; color: var(--vefa-text-muted, #475569); margin: 0 0 .9rem; }
.cityx-schools__hint i { color: var(--vefa-accent, #ff4000); margin-right: .35rem; }

/* KPI cliquables (boutons-onglets) */
.cityx-school-stat--btn { font: inherit; text-align: left; cursor: pointer; appearance: none; transition: border-color .15s ease, background .15s ease, transform .15s ease; }
.cityx-school-stat--btn:hover { border-color: var(--vefa-accent, #ff4000); transform: translateY(-2px); }
.cityx-school-stat--btn.is-active { border-color: var(--vefa-accent, #ff4000); background: var(--vefa-accent-soft, rgba(255,64,0,.07)); box-shadow: inset 0 -3px 0 var(--vefa-accent, #ff4000); }
.cityx-school-stat--btn.is-active .cityx-school-stat__value { color: var(--vefa-accent-dark, #d93600); }

/* Liste nominative (scrollable) */
.cityx-school-listing__head { display: flex; align-items: center; justify-content: space-between; gap: .8rem; margin-top: .4rem; }
.cityx-school-names { list-style: none; margin: .3rem 0 .9rem; padding: 0; max-height: 360px; overflow-y: auto; }
.cityx-school-name { display: flex; align-items: center; justify-content: space-between; gap: .8rem; padding: .55rem .2rem; border-bottom: 1px solid var(--vefa-border-subtle, #f1f5f9); flex-wrap: wrap; }
.cityx-school-name:last-child { border-bottom: 0; }
.cityx-school-name__label { font-weight: 600; color: var(--vefa-text, #0f172a); font-size: .89rem; }
.cityx-school-name__sector { font-size: .72rem; font-weight: 500; color: var(--vefa-text-subtle, #94a3b8); }
.cityx-rep-badge { display: inline-block; font-size: .64rem; font-weight: 800; letter-spacing: .03em; color: #b45309; background: rgba(245,158,11,.16); padding: .08rem .4rem; border-radius: 5px; vertical-align: middle; }

/* « Voir plus » (pagination de la liste) */
.cityx-loadmore { display: flex; justify-content: center; padding: .7rem 0 .2rem; position: sticky; bottom: 0; background: linear-gradient(to top, var(--vefa-surface, #fff) 60%, transparent); }
.cityx-loadmore__btn { display: inline-flex; align-items: center; gap: .4rem; font: inherit; font-size: .85rem; font-weight: 700; cursor: pointer; color: var(--vefa-accent, #ff4000); background: var(--vefa-accent-soft, rgba(255,64,0,.07)); border: 1px solid var(--vefa-accent, #ff4000); border-radius: 999px; padding: .45rem 1.1rem; transition: background .15s ease, transform .15s ease; }
.cityx-loadmore__btn:hover { background: var(--vefa-accent, #ff4000); color: #fff; transform: translateY(-1px); }
.cityx-loadmore__btn[disabled] { opacity: .6; cursor: wait; }
.cityx-loadmore__count { font-weight: 500; opacity: .85; }
