/* =============================================
   chevalier-immo.fr : CSS Complet v2
   Style : Pierre de Bourgogne / Bordeaux
   Fichier externe charge par chevalier-core.php
   PRIORITE 9999 (apres GP)
   Lecons ccl-avocat integrees
   ============================================= */

/* === 1. IMPORT FONTS === */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Work+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

/* === 2. VARIABLES GLOBALES === */
:root {
  --color-primary:        #6B2D3E;
  --color-primary-dark:   #52202E;
  --color-primary-mid:    #8A3D52;
  --color-primary-light:  #F3E8EC;
  --color-secondary:      #C4A265;
  --color-secondary-dark: #A68942;
  --color-secondary-light:#FCF5E8;
  --color-bg:             #F5EDE0;
  --color-bg-section:     #EDE4D4;
  --color-bg-card:        #FFFBF5;
  --color-bg-dark:        #2D2D2D;
  --color-border:         #D8CFC0;
  --color-border-light:   #E8DFD0;
  --color-text:           #3D3D3D;
  --color-text-heading:   #2D2D2D;
  --color-text-muted:     #6B6560;
  --color-text-light:     #9A9490;
  --color-success:        #3D7A52;
  --color-danger:         #9B2226;
  --font-headings:        'Cormorant Garamond', Georgia, serif;
  --font-body:            'Work Sans', -apple-system, sans-serif;
  --font-mono:            'JetBrains Mono', monospace;
  --radius:               10px;
  --radius-lg:            12px;
  --shadow:               0 2px 8px rgba(45,45,45,0.08);
  --shadow-md:            0 4px 16px rgba(45,45,45,0.12);
  --shadow-lg:            0 8px 24px rgba(45,45,45,0.16);
  --transition:           0.3s ease;
}

/* === 3. BASE === */
body {
  font-family: var(--font-body) !important;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-text);
  background-color: var(--color-bg);
}

/* === 4. TYPOGRAPHIE === */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title {
  font-family: var(--font-headings) !important;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-text-heading);
}

h1, .entry-title { font-size: 2.1rem; }
h2 { font-size: 1.6rem; color: var(--color-primary); margin-top: 2.5rem; }
h3 { font-size: 1.3rem; color: var(--color-text-heading); margin-top: 2rem; }
h4 { font-size: 1.1rem; }

.entry-content p {
  line-height: 1.85;
  margin-bottom: 1.25rem;
  color: var(--color-text);
}

a { color: var(--color-primary); text-decoration: underline; text-decoration-color: var(--color-secondary); text-underline-offset: 2px; }
a:hover { color: var(--color-primary-dark); text-decoration-color: var(--color-primary); }

.entry-content a { text-decoration-thickness: 1.5px; }

strong, b { font-weight: 700; color: var(--color-text-heading); }

/* === 5. HEADER (lecon #3 : nav-float-right, masquer .site-branding) === */
.site-header,
.main-navigation,
#masthead {
  background: var(--color-bg-dark) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.18);
}

/* Fine ligne bordeaux sous le header */
.site-header::after {
  content: '';
  display: block;
  height: 3px;
  background: var(--color-primary);
}

/* Masquer le titre/description texte GP (lecon #3) */
.site-branding { display: none !important; }
.main-title { display: none !important; }
.site-description { display: none !important; }

/* Logo SVG via custom_logo */
.site-header .custom-logo-link {
  display: flex !important;
  align-items: center;
}
.site-header .custom-logo {
  max-height: 40px !important;
  width: auto !important;
}

/* Navigation */
.main-navigation a,
.nav-primary a {
  color: rgba(255,255,255,0.88) !important;
  font-family: var(--font-body) !important;
  font-weight: 600;
  font-size: 0.88rem;
  letter-spacing: 0.01em;
  transition: color var(--transition);
  padding: 0.5rem 1rem !important;
  text-decoration: none !important;
}

.main-navigation a:hover,
.nav-primary a:hover,
.main-navigation .current-menu-item > a {
  color: var(--color-secondary) !important;
}

/* Dropdown */
.main-navigation .sub-menu {
  background: var(--color-bg-dark) !important;
  border-top: 2px solid var(--color-primary);
}

/* === 6. NO SIDEBAR (lecon #4) === */
#secondary,
.widget-area {
  display: none !important;
}

.content-area,
#primary {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  float: none !important;
}

/* === 7. CONTENU PRINCIPAL === */
.content-area,
#primary {
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 2rem 2.25rem !important;
}

.entry-content { max-width: 100%; }

/* === 8. BREADCRUMB === */
.rank-math-breadcrumb,
.breadcrumbs {
  background: var(--color-bg-section);
  padding: 0.6rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.82rem;
  color: var(--color-text-muted);
}

.rank-math-breadcrumb a { color: var(--color-primary); text-decoration: none; }
.rank-math-breadcrumb a:hover { text-decoration: underline; }

/* === 9. BLOG GRID 2 COLONNES (lecon #5 : selecteurs body.blog exacts) === */
body.blog main#main,
body.archive main#main,
body.category main#main {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.5rem !important;
}

body.blog article.post,
body.archive article.post,
body.category article.post {
  margin: 0 !important;
  padding: 0 !important;
}

body.blog .inside-article,
body.archive .inside-article,
body.category .inside-article {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--color-border-light) !important;
  background: var(--color-bg-card) !important;
  box-shadow: var(--shadow) !important;
  transition: box-shadow var(--transition), transform var(--transition) !important;
  height: 100% !important;
}

body.blog .inside-article:hover,
body.archive .inside-article:hover,
body.category .inside-article:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-4px) !important;
}

/* Image en haut (lecon #5 : order -10 pour forcer au-dessus du header) */
body.blog .inside-article > .post-image,
body.archive .inside-article > .post-image,
body.category .inside-article > .post-image {
  order: -10 !important;
  height: 200px !important;
  overflow: hidden !important;
}

body.blog .inside-article > .post-image img,
body.archive .inside-article > .post-image img,
body.category .inside-article > .post-image img {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform var(--transition) !important;
}

/* Hover scale subtil sur les images */
body.blog .inside-article:hover > .post-image img,
body.archive .inside-article:hover > .post-image img,
body.category .inside-article:hover > .post-image img {
  transform: scale(1.05) !important;
}

body.blog .inside-article > header.entry-header,
body.archive .inside-article > header.entry-header,
body.category .inside-article > header.entry-header {
  order: -5 !important;
  padding: 1.25rem 1.25rem 0 !important;
}

body.blog .inside-article > .entry-summary,
body.archive .inside-article > .entry-summary,
body.category .inside-article > .entry-summary {
  order: 0 !important;
  padding: 0 1.25rem !important;
  /* Excerpt croppe 3 lignes */
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  font-size: 0.88rem !important;
  color: var(--color-text-muted) !important;
  line-height: 1.6 !important;
}

body.blog .inside-article > footer.entry-meta,
body.archive .inside-article > footer.entry-meta,
body.category .inside-article > footer.entry-meta {
  order: 10 !important;
  padding: 0.75rem 1.25rem 1.25rem !important;
  margin-top: auto !important;
}

/* Navigation pagination : full width dans le grid */
body.blog nav.paging-navigation,
body.blog .pagination,
body.archive nav.paging-navigation,
body.archive .pagination {
  grid-column: 1 / -1 !important;
}

/* === 10. CARTES ARTICLES (single) === */
.entry-title a { color: var(--color-text-heading) !important; text-decoration: none !important; }
.entry-title a:hover { color: var(--color-primary) !important; }

.entry-meta,
.posted-on,
.post-date {
  font-size: 0.8rem;
  color: var(--color-text-light);
}

/* === 11. SHORTCODES CHEVALIER-IMMO === */

/* [ci_summary] */
.ci-summary {
  background: var(--color-bg-dark);
  color: #FFFFFF;
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.75rem;
  margin-bottom: 2rem;
}

.ci-summary-title {
  font-family: var(--font-headings) !important;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-secondary);
  margin: 0 0 0.75rem;
}

.ci-summary ul { margin: 0; padding-left: 1.25rem; }
.ci-summary li { color: rgba(255,255,255,0.88); font-size: 0.95rem; margin-bottom: 0.35rem; }

/* FORCE BLANC sur fond sombre (lecon #13) */
.ci-summary, .ci-summary *, .ci-summary strong, .ci-summary a { color: rgba(255,255,255,0.9) !important; }
.ci-summary .ci-summary-title { color: var(--color-secondary) !important; }

/* [ci_encart] */
.ci-encart {
  background: linear-gradient(135deg, var(--color-primary-light), #FBF0F3);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 1.25rem 1.5rem;
  margin: 2rem 0;
  box-shadow: var(--shadow);
}

.ci-encart-title {
  font-family: var(--font-headings) !important;
  font-weight: 700;
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary-dark);
  margin: 0 0 0.6rem;
}

.ci-encart p { margin: 0; color: var(--color-text); }

/* [ci_alerte] */
.ci-alerte {
  background: var(--color-secondary-light);
  border-left: 4px solid var(--color-secondary);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 1.25rem 1.5rem;
  margin: 2rem 0;
}

.ci-alerte-title {
  font-weight: 700;
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-secondary-dark);
  margin: 0 0 0.5rem;
}

.ci-alerte p { margin: 0; color: var(--color-text); font-size: 0.95rem; }

/* [ci_chiffres] / [ci_chiffre] */
.ci-chiffre-block {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin: 2rem 0;
}

.ci-chiffre {
  flex: 1 1 140px;
  background: var(--color-bg-dark);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  text-align: center;
  min-width: 130px;
}

.ci-chiffre-valeur {
  font-family: var(--font-mono);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--color-secondary);
  display: block;
}

.ci-chiffre-label {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.75);
  display: block;
  margin-top: 0.3rem;
}

/* Hide wpautop <br> that break grid layout */
.ci-chiffre-block br {
  display: none !important;
}

/* FORCE BLANC chiffres (lecon #13) */
.ci-chiffre, .ci-chiffre * { color: rgba(255,255,255,0.75) !important; }
.ci-chiffre .ci-chiffre-valeur { color: var(--color-secondary) !important; }

/* [ci_prix] : shortcode special prix m2 avec icone tendance */
.ci-prix {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--color-bg-dark);
  color: #FFFFFF;
  padding: 0.5rem 1rem;
  border-radius: var(--radius);
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 700;
}

.ci-prix-trend-up { color: var(--color-success); }
.ci-prix-trend-down { color: var(--color-danger); }
.ci-prix-trend-stable { color: var(--color-secondary); }

.ci-prix-label {
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 500;
  color: rgba(255,255,255,0.65);
}

/* [ci_faq] / [ci_q] / [ci_a] */
.ci-faq { margin: 2rem 0; }

.ci-faq-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  margin-bottom: 0.6rem;
  overflow: hidden;
}

.ci-faq-item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  cursor: pointer;
  background: var(--color-bg-card);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--color-text);
  list-style: none;
  transition: background var(--transition);
}

.ci-faq-item summary:hover { background: var(--color-bg-section); }
.ci-faq-item summary::-webkit-details-marker { display: none; }

.ci-faq-item summary::after {
  content: '+';
  font-size: 1.25rem;
  color: var(--color-primary);
  font-weight: 300;
  flex-shrink: 0;
  margin-left: 1rem;
}

.ci-faq-item[open] summary::after { content: '\2212'; }

.ci-faq-content {
  padding: 1rem 1.25rem;
  background: var(--color-bg);
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--color-text-muted);
  border-top: 1px solid var(--color-border-light);
}

/* [ci_toc] */
.ci-toc {
  background: var(--color-bg-section);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-secondary);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: 1.25rem 1.5rem;
  margin: 1.75rem 0 2rem;
}

.ci-toc-title {
  font-family: var(--font-headings) !important;
  font-size: 0.9rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-secondary-dark);
  margin: 0 0 0.75rem;
}

.ci-toc ol { margin: 0; padding-left: 1.25rem; counter-reset: toc; }
.ci-toc li { margin-bottom: 0.4rem; font-size: 0.9rem; }
.ci-toc a { color: var(--color-primary); font-weight: 500; text-decoration: none; }
.ci-toc a:hover { color: var(--color-secondary-dark); text-decoration: underline; }

/* [ci_table] */
.ci-table-wrap { overflow-x: auto; margin: 2rem 0; }

.ci-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.ci-table th {
  background: var(--color-bg-dark);
  color: var(--color-secondary) !important;
  padding: 0.85rem 1rem;
  text-align: left;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-family: var(--font-body);
  font-weight: 700;
}

/* FORCE BLANC th (lecon #13) */
table thead th { color: #FFFFFF !important; }

.ci-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text);
  background: var(--color-bg-card);
}

.ci-table tr:nth-child(even) td { background: var(--color-bg); }
.ci-table tr:hover td { background: var(--color-primary-light); }

/* [ci_badge] */
.badge {
  display: inline-block;
  padding: 0.18rem 0.6rem;
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.badge-expert { background: var(--color-primary); color: #FFF; }
.badge-prix { background: var(--color-secondary-light); color: var(--color-secondary-dark); }
.badge-quartier { background: var(--color-primary-light); color: var(--color-primary-dark); }
.badge-2026 { background: var(--color-bg-dark); color: var(--color-secondary); }
.badge-investissement { background: #E8F5E9; color: #2E7D32; }

/* [ci_bio] */
.ci-bio {
  border-top: 1px solid var(--color-border);
  margin-top: 3rem;
  padding-top: 1.5rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.ci-bio-avatar {
  width: 56px;
  height: 56px;
  background: var(--color-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.ci-bio-avatar svg {
  width: 100%;
  height: 100%;
}

.ci-bio-name {
  font-weight: 700;
  color: var(--color-text-heading);
  margin: 0 0 0.2rem;
  font-size: 0.92rem;
}

.ci-bio-role {
  font-size: 0.78rem;
  color: var(--color-secondary-dark);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 0.4rem;
}

.ci-bio-desc {
  font-size: 0.82rem;
  color: var(--color-text-muted);
  margin: 0;
  line-height: 1.55;
}

/* === 12. SHORTCODE ci_articles AVEC IMAGES (lecon #8) === */
.ci-hub-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin: 2rem 0;
}

.ci-hub-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
  text-decoration: none;
  display: block;
}

.ci-hub-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}

.ci-hub-card .card-img {
  width: 100%;
  height: auto; aspect-ratio: 4/3;
  overflow: hidden;
}

.ci-hub-card .card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition);
}

.ci-hub-card:hover .card-img img {
  transform: scale(1.05);
}

.ci-hub-card-body {
  padding: 1.25rem;
}

.ci-hub-card-title {
  font-family: var(--font-headings);
  font-size: 1.05rem;
  color: var(--color-text-heading);
  margin: 0 0 0.3rem;
  line-height: 1.3;
}

.ci-hub-card-date {
  font-size: 0.75rem;
  color: var(--color-text-light);
  margin: 0 0 0.4rem;
  display: block;
}

.ci-hub-card-excerpt {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin: 0;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* === 13. SIMULATEURS === */
.simulateur-block {
  background: var(--color-bg-card);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-lg);
  padding: 2rem;
  margin: 2.5rem 0;
  box-shadow: var(--shadow-md);
}

.simulateur-title {
  font-family: var(--font-headings) !important;
  font-size: 1.2rem;
  color: var(--color-primary);
  margin: 0 0 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}

.simulateur-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.simulateur-label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.simulateur-input {
  width: 100%;
  padding: 0.65rem 0.9rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  font-family: var(--font-mono);
  font-size: 1rem;
  background: var(--color-bg);
  color: var(--color-text);
  transition: border-color var(--transition);
  box-sizing: border-box;
  margin-bottom: 1rem;
}

.simulateur-input:focus {
  outline: none;
  border-color: var(--color-primary);
  background: #FFFFFF;
}

.simulateur-select {
  width: 100%;
  padding: 0.65rem 0.9rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.95rem;
  background: var(--color-bg);
  color: var(--color-text);
  margin-bottom: 1rem;
  cursor: pointer;
}

.simulateur-btn {
  background: var(--color-primary);
  color: #FFFFFF;
  border: none;
  padding: 0.75rem 2rem;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition), transform var(--transition);
  letter-spacing: 0.02em;
}

.simulateur-btn:hover {
  background: var(--color-primary-dark);
  transform: translateY(-2px);
}

.simulateur-result {
  margin-top: 1.5rem;
  background: var(--color-primary-light);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  border: 1px solid var(--color-primary-mid);
}

.simulateur-result-label {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-primary-mid);
  display: block;
  margin-bottom: 0.4rem;
}

.simulateur-result-value {
  font-family: var(--font-mono);
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  display: block;
}

.simulateur-result-detail {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin-top: 0.5rem;
  line-height: 1.5;
}

/* === 14. TAGS === */
.entry-tags a,
.post-tags a {
  display: inline-block;
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  padding: 0.2rem 0.65rem;
  border-radius: 20px;
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
  margin: 0.2rem;
  transition: background var(--transition);
}

.entry-tags a:hover {
  background: var(--color-primary);
  color: #FFFFFF;
}

/* === 15. FOOTER GP MASQUE (lecon #10) === */
.site-footer,
.footer-bar,
.site-info,
footer.site-footer {
  display: none !important;
}

/* Footer custom via wp_footer */
.ci-footer {
  background: var(--color-bg-dark);
  color: rgba(255,255,255,0.75);
  padding: 3rem 2rem 1.5rem;
}

.ci-footer a { color: rgba(255,255,255,0.75); text-decoration: none; }
.ci-footer a:hover { color: var(--color-secondary); }

.ci-footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem;
  max-width: 100%;
  margin: 0 auto 2rem;
}

.ci-footer-title {
  color: var(--color-secondary);
  font-family: var(--font-headings);
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  padding-bottom: 0.5rem;
}

.ci-footer-links { list-style: none; margin: 0; padding: 0; }
.ci-footer-links li { margin-bottom: 0.4rem; }
.ci-footer-links a { font-size: 0.88rem; }

.ci-footer-copy {
  text-align: center;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.4);
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 1.5rem;
  max-width: 100%;
  margin: 0 auto;
}

/* === 16. PAGINATION === */
.pagination .page-numbers {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  padding: 0.5rem 0.9rem;
  border-radius: var(--radius);
  text-decoration: none;
  font-size: 0.9rem;
  margin: 0.2rem;
  display: inline-block;
  transition: all var(--transition);
}

.pagination .page-numbers:hover,
.pagination .page-numbers.current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #FFFFFF;
}

/* === 17. IMAGES ARTICLES === */
.entry-content > img,
.entry-content > figure img,
.entry-content > p img {
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.entry-content figcaption {
  font-size: 0.8rem;
  color: var(--color-text-light);
  text-align: center;
  margin-top: 0.4rem;
  font-style: italic;
}

/* === 18. FORCE BLANC SUR FOND SOMBRE (lecon #13) === */
[style*="background:#2D2D2D"] *,
[style*="background: #2D2D2D"] *,
[style*="background:linear-gradient"] * {
  color: #FFFFFF !important;
}
[style*="background:#2D2D2D"] a,
[style*="background: #2D2D2D"] a {
  color: rgba(255,255,255,0.85) !important;
}
[style*="background:#2D2D2D"] .ci-chiffre-label,
[style*="background: #2D2D2D"] .ci-chiffre-label {
  color: rgba(255,255,255,0.75) !important;
}

/* === 19. HOMEPAGE SPECIFIQUE === */
/* HERO : image de fond Dijon + overlay gradient sombre
   IMAGE A GENERER avec Gemini 2.5 Flash Image (modele: gemini-2.5-flash-image) :
   Prompt : "Aerial photograph taken with a DJI Mavic 3 looking down at 45 degrees onto the historic
   center of Dijon France. The Ducal Palace, Notre-Dame church, colorful Burgundy rooftops with
   traditional glazed tiles, the Place de la Liberation. Late afternoon golden hour warm light.
   Burgundy stone facades. Atmospheric depth. Rich warm tones, no text, no watermarks."
   Crop 21:9, upload sur WP, recuperer l'URL et la mettre dans le CSS ci-dessous.
*/
.ci-hero {
  background: linear-gradient(135deg, rgba(45,45,45,0.82) 0%, rgba(61,61,61,0.75) 100%),
              url('https://chevalier-immo.fr/wp-content/uploads/2026/03/ci_hero_dijon.png') center/cover no-repeat;
  color: #fff;
  padding: 5rem 2rem;
  text-align: center;
  border-radius: var(--radius-lg);
  margin-bottom: 3rem;
  position: relative;
  overflow: hidden;
}

.ci-hero-badge {
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-secondary);
  margin: 0 0 0.75rem;
  font-weight: 700;
}

.ci-hero h1 {
  font-size: 2.2rem;
  font-weight: 700;
  margin: 0 0 1rem;
  line-height: 1.2;
  color: #fff !important;
  font-family: var(--font-headings);
}

.ci-hero p {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.85) !important;
  max-width: 600px;
  margin: 0 auto 2rem;
  line-height: 1.7;
}

.ci-hero-buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.ci-hero-btn {
  display: inline-block;
  font-weight: 700;
  padding: 0.85rem 1.75rem;
  border-radius: var(--radius);
  text-decoration: none !important;
  font-size: 0.95rem;
  transition: transform var(--transition), box-shadow var(--transition);
}

.ci-hero-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.ci-hero-btn-primary {
  background: var(--color-primary);
  color: #fff !important;
}

.ci-hero-btn-outline {
  background: transparent;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.5);
}

/* Hub cards homepage avec icones SVG */
.ci-home-hubs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.25rem;
  margin-bottom: 3rem;
}

.ci-home-hub-card {
  display: block;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  text-decoration: none;
  transition: box-shadow var(--transition), transform var(--transition);
  border-top: 4px solid var(--color-primary);
}

.ci-home-hub-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}

.ci-home-hub-card .hub-icon {
  width: 40px;
  height: 40px;
  margin-bottom: 0.75rem;
}

.ci-home-hub-card h3 {
  font-size: 1rem;
  color: var(--color-text-heading);
  margin: 0 0 0.4rem;
  font-family: var(--font-headings);
}

.ci-home-hub-card p {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin: 0;
  line-height: 1.5;
}

/* Outils cards homepage */
.ci-home-tools {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 2rem;
  margin-bottom: 3rem;
}

.ci-home-tools-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}

.ci-home-tool-card {
  border-radius: var(--radius);
  padding: 1.25rem;
  text-decoration: none;
  display: block;
  transition: transform var(--transition), box-shadow var(--transition);
}

.ci-home-tool-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.ci-home-tool-card strong {
  display: block;
  margin-bottom: 0.3rem;
}

.ci-home-tool-card span {
  font-size: 0.82rem;
}

/* === 21. PRINT === */
@media print {
  .site-header, .ci-footer, #secondary, .navigation { display: none; }
  .content-area { box-shadow: none; padding: 0 !important; }
  body { background: #FFF; }
  a::after { content: " (" attr(href) ")"; font-size: 0.8em; color: #666; }
}




/* Header et footer full width */
.inside-header, .inside-navigation {
  max-width: 100% !important;
}






/* === ARTICLES GRID DESKTOP 2 COLUMNS === */
.ci-articles-grid,
.ci-hub-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1.25rem !important;
  max-width: 1100px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* === FULL WIDTH DESKTOP === */
body .grid-container {
  max-width: 100% !important;
  padding: 0 2rem !important;
}
body .one-container .site-content,
body #primary, body .content-area,
body .inside-article, body .entry-content {
  max-width: 100% !important;
  width: 100% !important;
}
.inside-header, .inside-navigation {
  max-width: 100% !important;
}

/* === MOBILE === */
@media (max-width: 768px) {
  /* === NUCLEAR: prevent ALL horizontal overflow === */
  html {
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  body {
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  
  /* GP wrappers: zero padding, overflow hidden, 100% width */
  #page, .site,
  .site-content, #content,
  .grid-container,
  #primary, .content-area,
  .inside-article,
  .site-main, #main,
  .entry-content,
  .one-container .site-content,
  .one-container .inside-article,
  body .grid-container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  .entry-content {
    padding: 0 0.75rem !important;
    overflow-x: hidden !important;
  }
  
  /* Every child div in entry-content must be contained */
  .entry-content > div,
  .entry-content > div > div {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* ALL inline-styled grids and flex containers */
  div[style*="display:grid"],
  div[style*="display:flex"],
  div[style*="display: grid"],
  div[style*="display: flex"] {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* === HEADER === */
  .inside-header {
    padding: 0.5rem 0.75rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
  .site-logo { margin: 0 !important; }
  .site-logo img { max-height: 28px !important; display: block !important; }
  .site-branding, .main-title, .site-description { display: none !important; }
  button.menu-toggle { padding: 0.4rem 0.75rem !important; font-size: 0.85rem !important; }
  .site-header { position: relative !important; }

  /* Mobile menu */
  .main-navigation.toggled {
    position: absolute !important; top: 100% !important;
    left: 0 !important; right: 0 !important; z-index: 9999 !important;
    background: #1A1A1A !important; max-height: 70vh !important;
    overflow-y: auto !important; box-shadow: 0 8px 24px rgba(0,0,0,0.3) !important;
  }
  .main-navigation.toggled .main-nav ul li a {
    padding: 0.7rem 1.25rem !important; font-size: 0.92rem !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  }
  .main-navigation { background: #1A1A1A !important; }

  /* === HERO === */
  .ci-hero {
    padding: 2rem 0.75rem !important;
    border-radius: 0 !important;
    margin: 0 0 1.5rem 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .ci-hero h1 { font-size: 1.3rem !important; line-height: 1.3 !important; }
  .ci-hero p { font-size: 0.88rem !important; }
  .ci-hero-badge { font-size: 0.68rem !important; }
  .ci-hero-buttons, .ci-hero div[style*="display:flex"] {
    flex-direction: column !important; gap: 0.5rem !important;
  }
  .ci-hero-btn, .ci-hero a {
    display: block !important; width: 100% !important;
    text-align: center !important; padding: 0.7rem !important;
    box-sizing: border-box !important;
  }

  /* === TYPOGRAPHY === */
  h1, .entry-title { font-size: 1.4rem !important; }
  h2, h2[style] { font-size: 1.15rem !important; }

  /* === CHIFFRES 2x2 === */
  .ci-chiffre-block {
    display: grid !important; grid-template-columns: repeat(2,1fr) !important;
    gap: 0.5rem !important; max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .ci-chiffre { padding: 0.65rem !important; }
  .ci-chiffre-valeur { font-size: 1.15rem !important; }
  .ci-chiffre-label { font-size: 0.65rem !important; }

  /* === HUBS: vertical stack, NOT carousel === */
  .ci-home-hubs {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
    overflow: visible !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .ci-home-hub-card {
    min-width: 0 !important; max-width: 100% !important;
    width: auto !important;
  }

  /* === TOOL CARDS: vertical stack === */
  .ci-home-tools {
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }
  .ci-home-tools-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
    overflow: visible !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .ci-home-tool-card {
    min-width: 0 !important; max-width: 100% !important;
    width: auto !important; box-sizing: border-box !important;
  }

  /* === ARTICLE GRIDS: 1 column === */
  .ci-articles-grid, .ci-hub-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.75rem !important;
    overflow: visible !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .ci-article-card, .ci-hub-card {
    min-width: 0 !important; max-width: 100% !important;
    width: auto !important;
  }

  /* === INLINE STYLED GRIDS === */
  div[style*="grid-template-columns:repeat(2,1fr)"],
  div[style*="grid-template-columns:repeat(3,1fr)"],
  div[style*="grid-template-columns: repeat(2"],
  div[style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  div[style*="grid-template-columns:repeat(4,1fr)"],
  div[style*="grid-template-columns: repeat(4"] {
    grid-template-columns: repeat(2,1fr) !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* === SIMULATEURS === */
  .simulateur-block {
    padding: 0.75rem !important; border-radius: 0 !important;
    margin: 0 !important; max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .simulateur-block div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
  .simulateur-input, .simulateur-select, select, input[type="number"] {
    font-size: 16px !important; width: 100% !important;
    box-sizing: border-box !important;
  }

  /* === CONFIGURATEUR CTA (flex row -> column) === */
  div[style*="display:flex"][style*="gap:1.5rem"],
  div[style*="display:flex"][style*="gap:2rem"] {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 1rem 0.75rem !important;
  }

  /* CTA blocks */
  div[style*="border-left:4px"], div[style*="border-left:3px"] {
    flex-direction: column !important; text-align: center !important;
    margin: 1.5rem 0.75rem !important;
    max-width: 100% !important; box-sizing: border-box !important;
  }

  /* === TABLES === */
  table {
    display: block !important; overflow-x: auto !important;
    font-size: 0.78rem !important; max-width: 100% !important;
  }

  /* === BLOG GRID 1 COL === */
  body.blog main#main, body.archive main#main, body.category main#main {
    grid-template-columns: 1fr !important;
  }

  /* === FOOTER === */
  .ci-footer-grid { grid-template-columns: 1fr !important; }

  /* === BIO === */
  .ci-bio, div[style*="display:flex"][style*="align-items:flex-start"] {
    flex-direction: column !important; align-items: center !important;
    text-align: center !important;
    max-width: 100% !important; box-sizing: border-box !important;
  }

  /* === IMAGES: contained on mobile === */
  .page-header-image-single,
  .page-header-image-single.grid-container,
  .page-header-image-single.grid-container.grid-parent,
  .featured-image,
  .post-image {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 0 0.75rem 0 !important;
    overflow: hidden !important;
    border-radius: 0 !important;
  }
  .page-header-image-single img,
  .featured-image img,
  .post-image img,
  .wp-post-image {
    width: 100% !important;
    height: auto !important;
    max-height: 280px !important;
    object-fit: contain !important;
    background: #F5EDE0;
  }
  .entry-content figure {
    max-width: 100% !important;
    margin: 1rem 0 !important;
    padding: 0 !important;
    border-radius: 8px !important;
    overflow: hidden !important;
  }
  .entry-content > figure img,
  .entry-content > img,
  .entry-content > p img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
  }
  /* Cards keep their aspect-ratio fill on mobile */
  .ci-hub-card .card-img img,
  .ci-hub-grid .card-img img {
    height: 100% !important;
    max-height: none !important;
  }

  /* Force white text on dark backgrounds */
  div[style*="background:#6B2D3E"] strong,
  div[style*="background:#2D2D2D"] strong,
  div[style*="background:#3D7A52"] strong,
  a[style*="background:#6B2D3E"] strong,
  a[style*="background:#2D2D2D"] strong {
    color: #FFFBF5 !important;
  }
}


  .entry-content { padding: 0 0.5rem !important; }
  .ci-hero { padding: 1.5rem 0.75rem !important; }
  .ci-hero h1 { font-size: 1.15rem !important; }
  /* Chiffres stay 2x2 even on small screens */
  .ci-chiffre-block {
    grid-template-columns: repeat(2,1fr) !important;
  }
}

@media (max-width: 480px) {
  .entry-content { padding: 0 0.5rem !important; }
  .ci-hero { padding: 1.5rem 0.75rem !important; }
  .ci-hero h1 { font-size: 1.15rem !important; }
  .ci-chiffre-block {
    grid-template-columns: repeat(2,1fr) !important;
  }
}

@media print {
  .site-header, .ci-footer, #secondary, .navigation { display: none; }
  body { background: #FFF; }
}


/* === IMAGES: contained display === */

/* Featured image container - override GP grid-container */
.page-header-image-single,
.page-header-image-single.grid-container,
.page-header-image-single.grid-container.grid-parent,
.featured-image,
.post-image {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 0 0 1.5rem 0;
}

.page-header-image-single img,
.featured-image img,
.post-image img,
.wp-post-image {
  width: 100% !important;
  height: auto !important;
  max-height: 450px;
  object-fit: contain;
  display: block;
  border-radius: 0;
  background: #F5EDE0;
}

/* Inline images in articles */
.entry-content figure {
  width: 100%;
  max-width: 100%;
  margin: 1.5rem 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-align: center;
}

.entry-content figure img,
.entry-content > img,
.entry-content > figure img,
.entry-content > p img {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  object-fit: contain;
  border-radius: var(--radius-lg);
}

/* Cards: preserve aspect-ratio fill */
.ci-hub-card .card-img img,
.ci-hub-grid .card-img img,
.ci-article-card .card-img img {
  height: 100% !important;
  max-height: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.entry-content figcaption {
  text-align: center;
  font-size: 0.82rem;
  color: var(--color-text-muted);
  font-style: italic;
  margin: 0.5rem 0 0;
  padding: 0.5rem;
}

/* Articles: entire content in centered container */
body.single .inside-article {
  max-width: 860px !important;
  margin: 0 auto !important;
  padding: 2rem 2.5rem !important;
}

/* Shortcode blocks can be wider */
.entry-content .simulateur-block,
.entry-content .ci-chiffre-block,
.entry-content .ci-hub-grid,
.entry-content .ci-articles-grid,
.entry-content div[style*="border-left:4px"],
.entry-content div[style*="border-left:3px"],
.entry-content div[style*="background:#F3E8EC"],
.entry-content div[style*="background:#FFFBF5"],
.entry-content div[style*="background:#FCF5E8"],
.entry-content table {
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* === CTA TRAVAUX (leadgen iframe) === */
.ci-cta-travaux {
  margin: 2.5rem 0;
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-lg);
  background: var(--color-bg-card);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.ci-cta-travaux-inner {
  padding: 2rem 2rem 0.5rem;
}
.ci-cta-travaux h3 {
  font-family: var(--font-headings) !important;
  font-size: 1.4rem;
  color: var(--color-primary);
  margin: 0 0 0.75rem;
  border-bottom: 3px solid var(--color-secondary);
  padding-bottom: 0.5rem;
  display: inline-block;
}
.ci-cta-travaux p {
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.ci-cta-travaux iframe {
  border: none;
  border-radius: var(--radius);
  width: 100%;
  min-height: 700px;
}
@media (max-width: 768px) {
  .ci-cta-travaux-inner { padding: 1.25rem 1rem 0.25rem; }
  .ci-cta-travaux iframe { min-height: 600px; }
}

/* === FOOTER CTA BANNER === */
.ci-footer-cta {
  background: linear-gradient(135deg, #6B2D3E 0%, #8B3D4E 100%);
  text-align: center;
  padding: 2rem 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}
.ci-footer-cta span {
  color: #FFFBF5;
  font-family: var(--font-headings);
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}
.ci-footer-cta p {
  color: rgba(255,251,245,0.7);
  font-size: 0.95rem;
  margin: 0;
}
.ci-footer-cta a {
  display: inline-block;
  background: var(--color-secondary);
  color: var(--color-bg-dark) !important;
  font-weight: 700;
  font-size: 1rem;
  padding: 0.85rem 2.5rem;
  border-radius: 8px;
  text-decoration: none !important;
  transition: background var(--transition), transform 0.2s;
}
.ci-footer-cta a:hover {
  background: var(--color-secondary-dark);
  color: #fff !important;
  transform: translateY(-1px);
}

/* CTA Devis compact bloc */
.ci-cta-devis {
  margin: 2rem 0;
  background: linear-gradient(135deg, #6B2D3E 0%, #8B3D4E 100%);
  border-radius: 12px;
  overflow: hidden;
}
.ci-cta-devis-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.5rem 2rem;
}
.ci-cta-devis-text strong {
  display: block;
  color: #fff;
  font-size: 1.15rem;
  font-family: var(--font-headings);
  margin-bottom: 0.3rem;
}
.ci-cta-devis-text span {
  color: rgba(255,251,245,0.75);
  font-size: 0.9rem;
}
.ci-cta-devis-btn {
  display: inline-block;
  background: var(--color-secondary) !important;
  color: #2D2D2D !important;
  font-weight: 700 !important;
  font-size: 0.95rem;
  padding: 0.75rem 1.8rem;
  border-radius: 8px;
  text-decoration: none !important;
  white-space: nowrap;
  transition: background 0.2s, transform 0.2s;
}
.ci-cta-devis-btn:hover {
  background: var(--color-secondary-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
}
@media (max-width: 768px) {
  .ci-cta-devis-inner { flex-direction: column; text-align: center; padding: 1.2rem 1.5rem; }
  .ci-cta-devis-btn { width: 100%; text-align: center; }
}
