/*
Theme Name: ChauffeEauHS
Theme URI: https://chauffeeauhs.fr
Author: Esther Référencement
Author URI: https://esther-referencement.fr
Description: Thème sur mesure — Spécialistes chauffe-eau électrique IDF. Gutenberg + Yoast. Fonts self-hosted, zéro jQuery, PageSpeed 90+.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: chauffeeauhs
*/

/* ========================================
   FONTS SELF-HOSTED (PageSpeed)
   ======================================== */
@font-face {
  font-family: 'DM Sans';
  src: url('assets/fonts/dm-sans-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('assets/fonts/dm-sans-400i.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('assets/fonts/dm-sans-500.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('assets/fonts/dm-sans-600.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('assets/fonts/dm-sans-700.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Source Serif 4';
  src: url('assets/fonts/source-serif-600.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Source Serif 4';
  src: url('assets/fonts/source-serif-700.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Source Serif 4';
  src: url('assets/fonts/source-serif-600i.woff2') format('woff2');
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

/* ========================================
   DESIGN SYSTEM V2 — ChauffeEauHS
   ======================================== */
:root {
  --c-dark: #1C2127;
  --c-dark-mid: #252B33;
  --c-dark-soft: #2E353E;
  --c-slate: #3A4250;
  --c-terra: #C4654A;
  --c-terra-hover: #B05840;
  --c-terra-light: #D4896F;
  --c-terra-glow: rgba(196,101,74,0.10);
  --c-terra-deep: #A04E38;
  --c-warm: #E8DDD0;
  --c-warm-mid: #D6C8B8;
  --c-cream: #F5F1EB;
  --c-green: #3D8B5E;
  --c-green-bg: rgba(61,139,94,0.08);
  --c-green-light: #4DA672;
  --c-text: #F0EDE6;
  --c-text-muted: #9AA0AC;
  --c-text-dark: #1C2127;
  --c-text-body: #4A5060;
  --c-text-light: #6B7280;
  --c-bg: #FDFCFA;
  --c-bg-alt: #F5F1EB;
  --c-bg-card: #FFFFFF;
  --c-border: rgba(0,0,0,0.07);
  --c-border-dark: rgba(255,255,255,0.08);
  --max-w: 1100px;
  --max-w-narrow: 960px;
  --radius: 6px;
  --radius-lg: 10px;
  --shadow: 0 1px 8px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
  --transition: 0.25s ease;
  --font-display: 'Source Serif 4', Georgia, serif;
  --font-body: 'DM Sans', -apple-system, sans-serif;
}

/* ========================================
   RESET + BASE
   ======================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--c-text-dark);background:var(--c-bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ========================================
   LAYOUT
   ======================================== */
.wrap{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.wrap--narrow{max-width:var(--max-w-narrow);margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section--alt{background:var(--c-bg-alt)}
.section--dark{background:var(--c-dark);color:var(--c-text)}
.section--slate{background:var(--c-dark-mid);color:var(--c-text)}

/* ========================================
   TYPOGRAPHIE
   ======================================== */
h1,h2,h3,h4{line-height:1.2}
h1{font-family:var(--font-display);font-weight:700;font-size:2.5rem}
h2{font-family:var(--font-display);font-weight:700;font-size:1.75rem;margin-bottom:16px}
h3{font-family:var(--font-body);font-weight:600;font-size:1.1rem;margin-bottom:8px}
h4{font-family:var(--font-body);font-weight:600;font-size:1rem}
p{margin-bottom:16px}
strong{font-weight:600}
.eyebrow{font-family:var(--font-body);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--c-terra);margin-bottom:12px}
.section-header{text-align:center;margin-bottom:52px}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--c-text-body);max-width:540px;margin:0 auto;font-size:.95rem}
.section--dark .section-header p,.section--slate .section-header p{color:var(--c-text-muted)}

/* ========================================
   BOUTONS
   ======================================== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition);white-space:nowrap}
.btn--primary{background:var(--c-terra);color:#fff}
.btn--primary:hover{background:var(--c-terra-hover);transform:translateY(-1px)}
.btn--outline{background:transparent;border:1.5px solid var(--c-border-dark);color:var(--c-text)}
.btn--outline:hover{border-color:var(--c-terra-light);color:var(--c-terra-light)}
.btn--outline-dark{background:transparent;border:1.5px solid var(--c-border);color:var(--c-text-dark)}
.btn--outline-dark:hover{border-color:var(--c-terra);color:var(--c-terra)}
.btn--dark{background:var(--c-dark);color:#fff}
.btn--dark:hover{background:var(--c-dark-mid)}
.btn--sm{padding:10px 20px;font-size:.82rem}
.btn--white{background:#fff;color:var(--c-terra)}
.btn svg{width:16px;height:16px;flex-shrink:0}

/* ========================================
   TOPBAR
   ======================================== */
.topbar{position:sticky;top:0;z-index:100;background:var(--c-dark);border-bottom:1px solid var(--c-border-dark)}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.topbar__logo{font-family:var(--font-body);font-size:1.05rem;font-weight:700;color:var(--c-text);letter-spacing:-.01em}
.topbar__logo span{color:var(--c-terra-light)}
.topbar__nav{display:flex;align-items:center;gap:24px}
.topbar__nav a{color:var(--c-text-muted);font-size:.84rem;font-weight:500;transition:color var(--transition)}
.topbar__nav a:hover{color:#fff}
.topbar__cta{display:flex;align-items:center;gap:16px}
.topbar__phone{display:flex;align-items:center;gap:6px;color:#fff;font-weight:700;font-size:.9rem}
.topbar__phone svg{color:var(--c-terra-light)}
.topbar__avail{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--c-green-light);font-weight:500}

/* Pulse */
.pulse-dot{width:6px;height:6px;background:var(--c-green-light);border-radius:50%;position:relative}
.pulse-dot::before{content:'';position:absolute;inset:-3px;border-radius:50%;background:var(--c-green-light);opacity:.3;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.3}50%{transform:scale(2);opacity:0}}

/* Hamburger */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:20px;height:2px;background:#fff;margin:4px 0;transition:var(--transition)}

/* Mobile nav */
.topbar__nav--open{display:flex!important;position:absolute;top:60px;left:0;right:0;background:var(--c-dark);flex-direction:column;padding:16px 24px;gap:12px;border-bottom:1px solid var(--c-border-dark)}

/* ========================================
   HERO ACCUEIL
   ======================================== */
.hero{background:var(--c-dark);padding:72px 0 64px;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-terra-light),transparent);opacity:.2}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero__specialite{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:4px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;background:var(--c-terra-glow);color:var(--c-terra-light);border:1px solid rgba(196,101,74,.12);margin-bottom:20px}
.hero h1{color:#fff;font-size:2.6rem;line-height:1.12;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--c-terra-light)}
.hero__sub{color:var(--c-text-muted);font-size:1rem;margin-bottom:28px;max-width:480px;line-height:1.7}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}

/* Promise box */
.promise-box{background:rgba(255,255,255,.03);border:1px solid var(--c-border-dark);border-radius:var(--radius-lg);padding:32px}
.promise-box__main{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:#fff;line-height:1.3;margin-bottom:20px}
.promise-box__main em{font-style:italic;color:var(--c-terra-light)}
.promise-list li{display:flex;align-items:flex-start;gap:10px;padding:10px 0;font-size:.88rem;color:var(--c-text-muted);border-bottom:1px solid rgba(255,255,255,.04)}
.promise-list li:last-child{border-bottom:none}
.promise-list .check{width:18px;height:18px;background:var(--c-green-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;color:var(--c-green-light);font-size:.7rem}
.promise-box__phone{text-align:center;padding-top:20px;border-top:1px solid var(--c-border-dark)}
.promise-box__number{font-size:1.5rem;font-weight:800;color:#fff;display:block;margin-bottom:4px;letter-spacing:.02em}
.promise-box__avail{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.75rem;color:var(--c-green-light);margin-bottom:16px}

/* Trust bar */
.trust-bar{background:var(--c-dark-mid);border-bottom:1px solid var(--c-border-dark);padding:20px 0}
.trust-bar__inner{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.trust-bar__item{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--c-text-muted)}
.trust-bar__val{font-weight:700;color:#fff;font-size:.92rem}

/* ========================================
   PERSONA CARDS
   ======================================== */
.personas{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.persona-card{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:28px 24px;transition:all var(--transition)}
.persona-card:hover{box-shadow:var(--shadow-md);border-color:rgba(196,101,74,.15)}
.persona-card--primary{border-left:3px solid var(--c-terra)}
.persona-card__tag{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--c-terra);margin-bottom:12px}
.persona-card h3{font-size:1.05rem;margin-bottom:10px}
.persona-card p{color:var(--c-text-body);font-size:.88rem;margin-bottom:14px}
.persona-card__features{font-size:.82rem;color:var(--c-text-light)}
.persona-card__features li{padding:4px 0;padding-left:16px;position:relative}
.persona-card__features li::before{content:'';position:absolute;left:0;top:11px;width:5px;height:5px;background:var(--c-terra);border-radius:50%}

/* ========================================
   CARDS
   ======================================== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:24px 22px;transition:all var(--transition)}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.card__urgency{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:3px}
.card__urgency--high{background:rgba(220,53,69,.08);color:#DC3545}
.card__urgency--medium{background:rgba(232,148,58,.08);color:#C87A2B}
.card__urgency--low{background:var(--c-green-bg);color:var(--c-green)}
.card h3{font-size:1rem;margin-bottom:6px}
.card h3 a{transition:color var(--transition)}
.card h3 a:hover{color:var(--c-terra)}
.card p{color:var(--c-text-body);font-size:.84rem;margin-bottom:12px;line-height:1.55}
.card__link{font-size:.82rem;font-weight:600;color:var(--c-terra);display:inline-flex;align-items:center;gap:4px}

/* ========================================
   GUARANTEE
   ======================================== */
.guarantee{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.guarantee__list li{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--c-border);font-size:.9rem;color:var(--c-text-body)}
.guarantee__list li:last-child{border-bottom:none}
.guarantee__icon{width:32px;height:32px;background:var(--c-terra-glow);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--c-terra);font-size:.85rem}
.guarantee__visual{background:var(--c-bg-alt);border-radius:var(--radius-lg);border:1px solid var(--c-border);padding:40px}
.guarantee__stat{text-align:center;padding:24px 0}
.guarantee__stat-val{font-family:var(--font-display);font-size:3rem;font-weight:700;color:var(--c-terra);line-height:1}
.guarantee__stat-label{font-size:.85rem;color:var(--c-text-body);margin-top:8px}
.guarantee__stats-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid var(--c-border)}

/* ========================================
   BAILLEURS
   ======================================== */
.bailleur-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.bailleur-item{background:rgba(255,255,255,.03);border:1px solid var(--c-border-dark);border-radius:var(--radius-lg);padding:24px 20px;text-align:center}
.bailleur-item__num{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--c-terra-light);margin-bottom:4px}
.bailleur-item h4{color:#fff;font-size:.88rem;margin-bottom:8px}
.bailleur-item p{color:var(--c-text-muted);font-size:.8rem;line-height:1.5;margin:0}

/* ========================================
   STEPS
   ======================================== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;counter-reset:step}
.step{counter-increment:step;position:relative;padding-left:56px}
.step::before{content:counter(step);position:absolute;left:0;top:0;width:40px;height:40px;background:var(--c-terra);color:#fff;font-size:1rem;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center}
.step h3{margin-bottom:6px;font-size:1rem}
.step p{color:var(--c-text-body);font-size:.88rem}

/* ========================================
   TARIFS
   ======================================== */
.tarifs-table{width:100%;border-collapse:collapse;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--c-border);font-size:.9rem}
.tarifs-table thead th{background:var(--c-dark);color:#fff;padding:14px 20px;font-size:.82rem;font-weight:600;text-align:left}
.tarifs-table td{padding:14px 20px;border-bottom:1px solid var(--c-border)}
.tarifs-table tr:last-child td{border-bottom:none}
.tarifs-table tr:nth-child(even) td{background:var(--c-bg-alt)}
.tarifs-price{font-weight:700;color:var(--c-text-dark);white-space:nowrap}

/* ========================================
   AVIS
   ======================================== */
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.avis{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:24px}
.avis__stars{color:var(--c-terra);font-size:.85rem;letter-spacing:2px;margin-bottom:10px}
.avis__text{font-size:.88rem;color:var(--c-text-dark);margin-bottom:12px;font-style:italic;line-height:1.6}
.avis__author{font-size:.78rem;color:var(--c-text-light);font-weight:600}
.avis__type{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--c-terra);background:var(--c-terra-glow);padding:2px 8px;border-radius:3px;margin-top:6px}

/* ========================================
   ZONES
   ======================================== */
.zone-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.zone-tag{padding:8px 16px;border-radius:var(--radius);font-size:.8rem;font-weight:500;background:rgba(255,255,255,.04);color:var(--c-text-muted);border:1px solid rgba(255,255,255,.06)}
.zone-tag strong{color:#fff}

/* ========================================
   FAQ
   ======================================== */
.faq-list{max-width:680px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-item:first-child{border-top:1px solid var(--c-border)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:18px 0;cursor:pointer;font-weight:600;font-size:.95rem;gap:16px}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--c-terra);flex-shrink:0;transition:transform var(--transition)}
.faq-item.open .faq-q::after{content:'\2212'}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-a{max-height:500px}
.faq-a__inner{padding:0 0 18px;color:var(--c-text-body);font-size:.88rem;line-height:1.7}

/* ========================================
   CTA BOTTOM
   ======================================== */
.cta-bottom{background:var(--c-terra);padding:52px 0;text-align:center;color:#fff}
.cta-bottom h2{font-family:var(--font-display);color:#fff;margin-bottom:8px;font-size:1.5rem}
.cta-bottom p{opacity:.9;margin-bottom:24px;font-size:.95rem}
.cta-bottom__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ========================================
   FOOTER
   ======================================== */
.footer{background:var(--c-dark);color:var(--c-text-muted);padding:48px 0 24px;font-size:.8rem}
.footer__grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:36px;margin-bottom:32px}
.footer__brand{font-family:var(--font-body);font-size:1rem;font-weight:700;color:#fff;margin-bottom:10px}
.footer__brand span{color:var(--c-terra-light)}
.footer__desc{color:var(--c-text-muted);font-size:.82rem;line-height:1.6}
.footer h4{color:var(--c-warm-mid);font-size:.78rem;margin-bottom:12px;text-transform:uppercase;letter-spacing:.08em}
.footer a{color:var(--c-text-muted);transition:color var(--transition);display:block;padding:3px 0;font-size:.82rem}
.footer a:hover{color:var(--c-terra-light)}
.footer__bottom{border-top:1px solid var(--c-border-dark);padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem}
.footer__legal{display:flex;gap:20px}
.footer__siret{font-size:.75rem;margin-top:10px}

/* ========================================
   BREADCRUMB
   ======================================== */
.breadcrumb{padding:12px 0;font-size:.78rem;color:var(--c-text-muted);background:var(--c-dark)}
.breadcrumb a:hover{color:var(--c-terra-light)}
.breadcrumb .sep{margin:0 6px;opacity:.4}

/* ========================================
   HERO PRESTATION (page.php)
   ======================================== */
.hero-presta{background:var(--c-dark);padding:44px 0 52px;position:relative;overflow:hidden}
.hero-presta--has-thumb{background-size:cover;background-position:center}
.hero-presta--has-thumb::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(28,33,39,.70),rgba(37,43,51,.60))}
.hero-presta__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center}
.hero-presta h1{color:#fff;font-size:2rem;margin-bottom:14px}
.hero-presta__desc{color:var(--c-text-muted);font-size:.95rem;margin-bottom:20px;line-height:1.65}
.hero-presta__actions{display:flex;gap:10px;flex-wrap:wrap}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.chip{padding:5px 12px;border-radius:4px;font-size:.72rem;font-weight:500;background:var(--c-terra-glow);color:var(--c-terra-light);border:1px solid rgba(196,101,74,.1)}

/* Phone box */
.phone-box{background:rgba(255,255,255,.03);border:1px solid var(--c-border-dark);border-radius:var(--radius-lg);padding:28px;text-align:center}
.phone-box__number{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:4px}
.phone-box__sub{font-size:.78rem;color:var(--c-text-muted);margin-bottom:16px}

/* ========================================
   CONTENU GUTENBERG (.sa-content)
   Styles pour contenu agent + Gutenberg
   ======================================== */
.sa-content{padding:48px 0}

/* --- Headings --- */
.sa-content h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:40px 0 16px;padding-bottom:10px;border-bottom:2px solid var(--c-border);color:var(--c-text-dark);line-height:1.3}
.sa-content h2:first-child{margin-top:0}
.sa-content h3{font-size:1.08rem;font-weight:600;margin:28px 0 10px;color:var(--c-dark);line-height:1.35}
.sa-content h4{font-size:.95rem;font-weight:600;margin:20px 0 8px;color:var(--c-dark)}

/* --- Paragraphs + inline --- */
.sa-content p{color:var(--c-text-body);font-size:.92rem;line-height:1.75;margin-bottom:16px}
.sa-content strong{color:var(--c-text-dark);font-weight:600}
.sa-content em{font-style:italic}

/* --- Links --- */
.sa-content a{color:var(--c-terra);font-weight:500;text-decoration:none;border-bottom:1px solid rgba(196,101,74,.25);transition:border-color var(--transition)}
.sa-content a:hover{border-bottom-color:var(--c-terra)}

/* --- Lists --- */
.sa-content ul,.sa-content ol{margin-bottom:18px;padding-left:0}
.sa-content li{color:var(--c-text-body);margin-bottom:8px;padding-left:18px;position:relative;font-size:.92rem;line-height:1.65}
.sa-content ul>li::before{content:'';position:absolute;left:0;top:10px;width:5px;height:5px;background:var(--c-terra);border-radius:50%}
.sa-content ol{counter-reset:ol-counter;padding-left:0}
.sa-content ol>li{counter-increment:ol-counter;padding-left:26px}
.sa-content ol>li::before{content:counter(ol-counter) '.';position:absolute;left:0;font-weight:700;color:var(--c-terra);font-size:.88rem}
/* Nested lists */
.sa-content li ul,.sa-content li ol{margin-top:8px;margin-bottom:8px}

/* --- Tables --- */
.sa-content table{width:100%;border-collapse:collapse;margin:24px 0;border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;font-size:.88rem}
.sa-content thead th{background:var(--c-dark);color:#fff;padding:12px 16px;font-size:.82rem;font-weight:600;text-align:left;border:none}
.sa-content th{background:var(--c-bg-alt);text-align:left;padding:12px 16px;font-size:.82rem;font-weight:600;border-bottom:2px solid var(--c-border)}
.sa-content td{padding:12px 16px;border-bottom:1px solid var(--c-border);color:var(--c-text-body);vertical-align:top}
.sa-content tr:last-child td{border-bottom:none}
.sa-content tr:nth-child(even) td{background:var(--c-bg-alt)}
.sa-content table strong{color:var(--c-text-dark)}
/* Responsive table */
@media(max-width:640px){
  .sa-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:.8rem}
  .sa-content td,.sa-content th{padding:8px 10px;white-space:nowrap}
}

/* --- Blockquote / Callout --- */
.sa-content blockquote{background:var(--c-terra-glow);border-left:3px solid var(--c-terra);padding:20px 24px;margin:28px 0;border-radius:0 var(--radius) var(--radius) 0;font-style:normal}
.sa-content blockquote p{margin:0;color:var(--c-text-dark);font-size:.9rem}
.sa-content blockquote p:last-child{margin:0}

/* --- Separator / HR --- */
.sa-content hr{border:none;height:1px;background:linear-gradient(90deg,var(--c-terra-light),var(--c-border),transparent);margin:40px 0;opacity:.6}

/* --- Images --- */
.sa-content img{border-radius:var(--radius-lg);margin:24px 0;box-shadow:var(--shadow)}
.sa-content figure{margin:24px 0}
.sa-content figcaption{font-size:.78rem;color:var(--c-text-light);text-align:center;margin-top:8px}

/* --- Details / Summary (FAQ agent) --- */
.sa-content details{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;background:var(--c-bg-card)}
.sa-content details[open]{border-color:rgba(196,101,74,.2)}
.sa-content summary{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--c-text-dark);background:var(--c-bg-alt);transition:background var(--transition);list-style:none}
.sa-content summary::-webkit-details-marker{display:none}
.sa-content summary::marker{display:none}
.sa-content summary::after{content:'+';font-size:1.3rem;color:var(--c-terra);flex-shrink:0;font-weight:400;margin-left:16px;transition:transform var(--transition)}
.sa-content details[open] summary::after{content:'\2212'}
.sa-content details[open] summary{background:var(--c-bg-alt);border-bottom:1px solid var(--c-border)}
.sa-content summary:hover{background:var(--c-cream)}
.sa-content details>div,.sa-content details>p{padding:16px 20px;font-size:.88rem;color:var(--c-text-body);line-height:1.7}
.sa-content details>p:first-of-type{padding-top:16px}
.sa-content details>p:last-child{padding-bottom:16px}
/* Handle + symbol used as toggle text */
.sa-content summary+div{padding:16px 20px}

/* --- Code --- */
.sa-content code{background:var(--c-bg-alt);padding:2px 6px;border-radius:3px;font-size:.85em;color:var(--c-terra-deep);font-family:monospace}
.sa-content pre{background:var(--c-dark);color:var(--c-text);padding:20px 24px;border-radius:var(--radius-lg);overflow-x:auto;margin:24px 0;font-size:.85rem;line-height:1.6}
.sa-content pre code{background:none;padding:0;color:inherit}

/* --- Gutenberg alignments --- */
.sa-content .alignwide{max-width:var(--max-w);margin-left:auto;margin-right:auto}
.sa-content .alignfull{max-width:100vw;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%)}

/* --- Gutenberg columns --- */
.sa-content .wp-block-columns{display:flex;gap:24px;margin:24px 0}
.sa-content .wp-block-column{flex:1}
@media(max-width:640px){.sa-content .wp-block-columns{flex-direction:column}}

/* --- Gutenberg buttons --- */
.sa-content .wp-block-button__link{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;font-weight:600;background:var(--c-terra);color:#fff;border:none;border-bottom:none;transition:all var(--transition)}
.sa-content .wp-block-button__link:hover{background:var(--c-terra-hover);transform:translateY(-1px);border-bottom:none}

/* ========================================
   COMPAT ANCIEN CONTENU (classes pce-*)
   ======================================== */
/* Override les variables pce avec le design V2 */
.pce-section{--pce-primary:#C4654A;--pce-primary-dark:#A04E38;--pce-danger:#DC3545;--pce-gray-700:var(--c-text-muted);--pce-gray-100:var(--c-bg-alt);--pce-gray-200:var(--c-border)}

/* Neutraliser les fonds/couleurs inline de l'ancien thème qui cassent le design */
.sa-content [style*="background:var(--pce"]{background:var(--c-bg-alt)!important}
.sa-content [style*="color:var(--pce-primary)"]{color:var(--c-terra)!important}
.sa-content [style*="color:var(--pce-danger)"]{color:#DC3545!important}
.sa-content [style*="color: var(--pce-primary)"]{color:var(--c-terra)!important}
.sa-content [style*="background:var(--pce-primary)"]{background:var(--c-terra)!important}
.sa-content [style*="background: var(--pce-primary)"]{background:var(--c-terra)!important}

/* pce-faq styles (ancien agent) */
.pce-faq-question{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--c-text-dark);background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:6px;transition:background var(--transition)}
.pce-faq-question:hover{background:var(--c-cream)}
.pce-faq-answer{padding:16px 20px;font-size:.88rem;color:var(--c-text-body);line-height:1.7;border:1px solid var(--c-border);border-top:none;border-radius:0 0 var(--radius) var(--radius);margin-top:-7px;margin-bottom:8px}

/* ========================================
   COMPAT AGENT CEHS-* (classes actuelles)
   ======================================== */
/* Article wrapper */
.cehs-article{font-size:.92rem;color:var(--c-text-body);line-height:1.75}

/* Recap express */
.cehs-recap-express{background:var(--c-terra-glow);border-left:3px solid var(--c-terra);border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:20px 24px;margin:24px 0}
.cehs-recap-express p{margin:6px 0;font-size:.88rem;color:var(--c-text-dark)}

/* Encart technique */
.cehs-encart-technique{background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px 24px;margin:24px 0}
.cehs-encart-technique p{margin:6px 0;font-size:.88rem;color:var(--c-text-body)}

/* Encart E-E-A-T */
.cehs-encart-eeat{background:var(--c-bg-alt);border-radius:var(--radius-lg);padding:24px 28px;margin:28px 0;border:1px solid var(--c-border);font-style:italic;font-size:.92rem;color:var(--c-text-dark);line-height:1.65}

/* Grid modules (cards) */
.cehs-grid-modules{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:24px 0}
.cehs-module-card{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px 22px;transition:all var(--transition)}
.cehs-module-card:hover{box-shadow:var(--shadow-md);border-color:rgba(196,101,74,.15)}
.cehs-module-card strong{display:block;font-size:.95rem;color:var(--c-text-dark);margin-bottom:8px}
.cehs-module-card p{font-size:.85rem;color:var(--c-text-body);margin:0;line-height:1.6}
@media(max-width:640px){.cehs-grid-modules{grid-template-columns:1fr}}

/* Table wrap */
.cehs-table-wrap{margin:24px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}

/* FAQ section */
.cehs-faq-section details{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;background:var(--c-bg-card)}
.cehs-faq-section details[open]{border-color:rgba(196,101,74,.2)}
.cehs-faq-section summary{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--c-text-dark);background:var(--c-bg-alt);transition:background var(--transition);list-style:none}
.cehs-faq-section summary::-webkit-details-marker{display:none}
.cehs-faq-section summary::marker{display:none}
.cehs-faq-section summary::after{content:'+';font-size:1.3rem;color:var(--c-terra);flex-shrink:0;font-weight:400;margin-left:16px}
.cehs-faq-section details[open] summary::after{content:'\2212'}
.cehs-faq-section details[open] summary{border-bottom:1px solid var(--c-border)}
.cehs-faq-section summary:hover{background:var(--c-cream)}
.cehs-faq-answer{padding:16px 20px;font-size:.88rem;color:var(--c-text-body);line-height:1.7}
.cehs-faq-answer p{margin:8px 0}

/* ========================================
   COMPOSANTS UX PERSONA-DRIVEN
   Bailleur = délégation + résultat
   Proprio = compréhension + décision
   ======================================== */

/* --- Section break (respiration visuelle entre blocs) --- */
.cehs-section-break{margin:48px 0;padding:0;border:none;height:3px;background:linear-gradient(90deg,transparent,var(--c-terra-light),transparent);opacity:.2}

/* --- Bloc RÉSOLU (garantie résultat — message persona bailleur) --- */
.cehs-resolu{background:var(--c-dark);border-radius:var(--radius-lg);padding:28px 32px;margin:32px 0;color:var(--c-text);position:relative;overflow:hidden}
.cehs-resolu::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--c-terra)}
.cehs-resolu__title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:12px}
.cehs-resolu__title em{font-style:italic;color:var(--c-terra-light)}
.cehs-resolu p{color:var(--c-text-muted);font-size:.88rem;margin:8px 0;line-height:1.65}
.cehs-resolu__list{margin:16px 0 0}
.cehs-resolu__list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:.85rem;color:var(--c-text-muted);border:none}
.cehs-resolu__list li::before{display:none}
.cehs-resolu__check{color:var(--c-green-light);font-size:.8rem;flex-shrink:0;margin-top:2px}

/* --- Bloc BAILLEUR (délégation — "on gère pour vous") --- */
.cehs-bailleur{background:linear-gradient(135deg,var(--c-dark) 0%,var(--c-dark-mid) 100%);border-radius:var(--radius-lg);padding:28px 32px;margin:32px 0;color:var(--c-text)}
.cehs-bailleur__tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;background:var(--c-terra-glow);color:var(--c-terra-light);border:1px solid rgba(196,101,74,.12);margin-bottom:14px}
.cehs-bailleur__title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:10px}
.cehs-bailleur p{color:var(--c-text-muted);font-size:.88rem;margin:8px 0;line-height:1.65}
.cehs-bailleur__steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0 0}
.cehs-bailleur__step{background:rgba(255,255,255,.03);border:1px solid var(--c-border-dark);border-radius:var(--radius);padding:16px 14px;text-align:center}
.cehs-bailleur__step-num{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--c-terra-light);margin-bottom:4px}
.cehs-bailleur__step-text{font-size:.78rem;color:var(--c-text-muted);line-height:1.4}
@media(max-width:640px){.cehs-bailleur__steps{grid-template-columns:1fr}}

/* --- CTA Résultat (pas panique — orienté outcome) --- */
.cehs-cta-resultat{background:var(--c-terra);border-radius:var(--radius-lg);padding:32px;margin:36px 0;text-align:center;color:#fff}
.cehs-cta-resultat__title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:6px}
.cehs-cta-resultat__sub{font-size:.88rem;opacity:.9;margin-bottom:20px}
.cehs-cta-resultat__phone{font-size:1.6rem;font-weight:800;color:#fff;display:block;margin-bottom:6px;text-decoration:none;border:none}
.cehs-cta-resultat__phone:hover{border:none;opacity:.9}
.cehs-cta-resultat__avail{font-size:.78rem;opacity:.8;margin-bottom:16px}
.cehs-cta-resultat__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cehs-cta-resultat .btn--dark{background:var(--c-dark);color:#fff}
.cehs-cta-resultat .btn--white{background:#fff;color:var(--c-terra);border:none}
.cehs-cta-resultat .btn--white:hover{border:none;opacity:.9}

/* --- Bloc Confiance (trust inline — certifications, garanties) --- */
.cehs-confiance{display:flex;gap:16px;margin:28px 0;flex-wrap:wrap}
.cehs-confiance__item{flex:1;min-width:140px;background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:18px 16px;text-align:center;transition:all var(--transition)}
.cehs-confiance__item:hover{border-color:rgba(196,101,74,.15);box-shadow:var(--shadow)}
.cehs-confiance__icon{font-size:1.3rem;margin-bottom:6px}
.cehs-confiance__val{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--c-text-dark);margin-bottom:2px}
.cehs-confiance__label{font-size:.75rem;color:var(--c-text-light)}

/* --- Verdict (aide à la décision — "réparer ou remplacer ?") --- */
.cehs-verdict{background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:24px 28px;margin:28px 0}
.cehs-verdict__title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--c-text-dark);margin-bottom:16px}
.cehs-verdict__grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cehs-verdict__col{padding:16px 18px;border-radius:var(--radius);font-size:.85rem;line-height:1.6}
.cehs-verdict__col--repair{background:var(--c-green-bg);border:1px solid rgba(61,139,94,.15)}
.cehs-verdict__col--replace{background:var(--c-terra-glow);border:1px solid rgba(196,101,74,.15)}
.cehs-verdict__col strong{display:block;margin-bottom:8px;font-size:.9rem}
.cehs-verdict__col--repair strong{color:var(--c-green)}
.cehs-verdict__col--replace strong{color:var(--c-terra)}
.cehs-verdict__col p{margin:4px 0;color:var(--c-text-body)}
@media(max-width:640px){.cehs-verdict__grid{grid-template-columns:1fr}}

/* --- Alerte sécurité (pour pages urgence type disjoncteur) --- */
.cehs-alerte{background:#FEF2F2;border:1px solid rgba(220,53,69,.15);border-left:4px solid #DC3545;border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:20px 24px;margin:28px 0}
.cehs-alerte__title{font-weight:700;color:#DC3545;font-size:.95rem;margin-bottom:8px}
.cehs-alerte p{color:var(--c-text-body);font-size:.88rem;margin:6px 0;line-height:1.65}

/* --- Encart "Vous êtes bailleur ?" (mini-CTA contextuel) --- */
.cehs-bailleur-mini{background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:20px 24px;margin:28px 0;display:flex;align-items:center;gap:20px}
.cehs-bailleur-mini__icon{font-size:1.5rem;flex-shrink:0}
.cehs-bailleur-mini__content{flex:1}
.cehs-bailleur-mini__content strong{display:block;font-size:.92rem;color:var(--c-text-dark);margin-bottom:4px}
.cehs-bailleur-mini__content p{font-size:.82rem;color:var(--c-text-body);margin:0}
.cehs-bailleur-mini__cta{flex-shrink:0}
@media(max-width:640px){.cehs-bailleur-mini{flex-direction:column;text-align:center;gap:12px}}

/* Callout */
.sa-callout{background:var(--c-terra-glow);border-left:3px solid var(--c-terra);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px;margin:28px 0}
.sa-callout p{margin:0;color:var(--c-text-dark);font-size:.9rem}

/* E-E-A-T */
.sa-eeat{background:var(--c-bg-alt);border-radius:var(--radius-lg);padding:24px 28px;margin:28px 0;border:1px solid var(--c-border)}
.sa-eeat__quote{font-style:italic;font-size:.95rem;color:var(--c-text-dark);margin-bottom:10px;line-height:1.6}
.sa-eeat__author{font-size:.78rem;color:var(--c-text-light);font-weight:600}

/* Disclaimer */
.sa-disclaimer{background:var(--c-bg-alt);border-radius:var(--radius);padding:14px 18px;margin:28px 0;font-size:.78rem;color:var(--c-text-light);border:1px dashed var(--c-border)}

/* Interventions accordion */
.sa-interventions{margin:24px 0}
.intervention-item{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:6px;overflow:hidden}
.intervention-q{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;cursor:pointer;font-weight:500;font-size:.88rem;background:var(--c-bg-alt)}
.intervention-q::after{content:'+';color:var(--c-terra);font-size:1.1rem}
.intervention-item.open .intervention-q::after{content:'\2212'}
.intervention-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.intervention-item.open .intervention-a{max-height:200px}
.intervention-a__inner{padding:14px 18px;font-size:.85rem;color:var(--c-text-body)}

/* ========================================
   SOMMAIRE AUTO
   ======================================== */
.sa-toc{background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:24px 28px;margin:0 0 32px}
.sa-toc__title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:14px;color:var(--c-text-dark)}
.sa-toc__links{display:flex;flex-wrap:wrap;gap:8px 20px}
.sa-toc__links a{font-size:.85rem;color:var(--c-text-body);font-weight:500;padding:4px 0;transition:color var(--transition);border-bottom:1px solid transparent}
.sa-toc__links a:hover{color:var(--c-terra);border-bottom-color:var(--c-terra)}
@media(max-width:768px){
  .sa-toc__links{flex-direction:column;gap:6px}
  .sa-toc__links a{padding:6px 0;border-bottom:1px solid var(--c-border)}
  .sa-toc__links a:last-child{border-bottom:none}
}

/* ========================================
   404
   ======================================== */
.page-404{text-align:center;padding:120px 24px}
.page-404 h1{font-size:5rem;color:var(--c-terra);margin-bottom:16px}
.page-404 p{color:var(--c-text-body);font-size:1.1rem;margin-bottom:32px}

/* ========================================
   PRINT
   ======================================== */
@media print{
  .topbar,.cta-bottom,.footer,.hamburger,.btn,.phone-box,.promise-box,.trust-bar{display:none!important}
  body{color:#000;background:#fff;font-size:12pt}
  .hero,.hero-presta,.section--dark,.section--slate{background:#fff!important;color:#000!important;padding:20px 0!important}
  .hero h1,.hero-presta h1{color:#000!important}
  a{color:#000!important}
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media(max-width:768px){
  h1{font-size:1.8rem}
  h2{font-size:1.35rem}
  .section{padding:48px 0}
  .topbar__nav{display:none}
  .hamburger{display:block}
  .hero__inner{grid-template-columns:1fr;gap:32px}
  .hero{padding:48px 0 40px}
  .hero h1{font-size:2rem}
  .trust-bar__inner{gap:24px}
  .personas{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:20px}
  .guarantee{grid-template-columns:1fr}
  .bailleur-grid{grid-template-columns:1fr 1fr}
  .avis-grid{grid-template-columns:1fr}
  .hero-presta__inner{grid-template-columns:1fr}
  .hero-presta--has-thumb::before{background:linear-gradient(135deg,rgba(28,33,39,.70),rgba(37,43,51,.60))}
  .footer__grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer__bottom{flex-direction:column;gap:10px;text-align:center}
  .tarifs-table{font-size:.82rem}
  .tarifs-table td,.tarifs-table th{padding:10px 12px}
}
@media(max-width:480px){
  .hero h1{font-size:1.65rem}
  .hero__actions,.hero-presta__actions,.cta-bottom__actions{flex-direction:column}
  .trust-bar__inner{flex-direction:column;gap:12px;align-items:center}
  .bailleur-grid{grid-template-columns:1fr}
  .guarantee__stats-row{grid-template-columns:1fr}
}
