
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#D42B2B;--red-d:#b82222;--red-l:#fff5f5;
  --blue:#1A5CA8;--blue-l:#e8f0fb;--blue-d:#134a8a;
  --navy:#0c1829;--navy2:#132238;
  --white:#fff;--off:#f7f6f3;--border:#e8e6e0;
  --text:#1a1816;--muted:#6e6b66;--subtle:#9e9b96;
  --green:#16a34a;--green-l:#f0fdf4;--star:#f59e0b;
  --r:10px;--r2:16px;
  --content-w:740px;
}
html{scroll-behavior:smooth}
body{font-family:'Outfit',system-ui,sans-serif;color:var(--text);background:var(--white);font-size:17px;line-height:1.75;overflow-x:hidden}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:500;background:var(--white);border-bottom:2px solid var(--red);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:1100px;margin:0 auto;padding:0 24px}
.nav-logo img{height:46px;width:auto}
.nav-links{display:flex;gap:0}
.nav-links a{font-size:14px;font-weight:600;color:var(--text);text-decoration:none;padding:8px 12px;border-radius:6px;transition:color .15s}
.nav-links a:hover{color:var(--red)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-tel{font-size:14px;font-weight:700;color:var(--navy);text-decoration:none}
.nav-tel::before{content:"📞 "}
.btn-nav{background:var(--red);color:var(--white);border:none;padding:9px 20px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;font-family:'Outfit',sans-serif}

/* ── BREADCRUMB ── */
.bc{background:var(--off);border-bottom:1px solid var(--border);padding:10px 0}
.bc-inner{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--subtle);max-width:1100px;margin:0 auto;padding:0 24px;flex-wrap:wrap}
.bc-inner a{color:var(--subtle);text-decoration:none}.bc-inner a:hover{color:var(--red)}

/* ── LAYOUT PRINCIPAL ── */
/* Layout WordPress : colonne unique centrée */
.page-wrap{max-width:860px;margin:0 auto;padding:40px 24px;display:block}
.sidebar{display:none !important}

/* ── ARTICLE ── */
article{}

/* ── GEO BADGE ── */
.geo-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--blue-l);border:1px solid rgba(26,92,168,.2);
  border-radius:20px;padding:4px 14px;
  font-size:12px;font-weight:700;color:var(--blue);
  margin-bottom:14px;
}

/* ── MÉTA ARTICLE ── */
.article-meta{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:20px}
.am-date{font-size:13px;color:var(--subtle)}
.am-author{font-size:13px;color:var(--muted);font-weight:600}
.am-reading{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--subtle)}
.am-divider{width:1px;height:14px;background:var(--border)}
.am-certif{display:inline-flex;align-items:center;gap:5px;background:var(--green-l);border:1px solid #86efac;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;color:#15803d}

/* ── H1 ── */
.article-h1{
  font-family:'Oswald',sans-serif;
  font-size:clamp(30px,4vw,48px);
  font-weight:700;line-height:1.05;
  text-transform:uppercase;letter-spacing:-.5px;
  color:var(--navy);margin-bottom:20px;
}
.article-h1 em{font-style:normal;color:var(--red)}

/* ── INTRO ── */
.article-intro{
  font-size:18px;color:var(--muted);line-height:1.8;
  margin-bottom:32px;padding-bottom:32px;
  border-bottom:2px solid var(--border);
  max-width:680px;
}

/* ── IMAGE HERO ── */
.article-hero-img{
  width:100%;border-radius:var(--r2);overflow:hidden;
  margin-bottom:40px;position:relative;
  box-shadow:0 4px 32px rgba(0,0,0,.1);
}
.article-hero-img img{
  width:100%;height:auto;display:block;
  aspect-ratio:16/9;object-fit:cover;
}
.article-hero-img figcaption{
  background:var(--off);border-top:1px solid var(--border);
  padding:10px 16px;font-size:13px;color:var(--subtle);
  font-style:italic;line-height:1.5;
}
/* Placeholder photo */
.photo-placeholder{
  background:linear-gradient(135deg,#1a2d45,#0c1829);
  border-radius:var(--r2);width:100%;
  aspect-ratio:16/9;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;
  border:2px dashed rgba(255,255,255,.15);margin-bottom:40px;
}
.pp-icon{font-size:40px}
.pp-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--red)}
.pp-desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.55;max-width:360px;text-align:center}
.pp-specs{font-size:11px;color:rgba(255,255,255,.3);font-family:'Courier New',monospace}
.pp-caption{font-size:12px;color:rgba(255,255,255,.25);margin-top:4px;font-style:italic}

/* ── CORPS ARTICLE ── */
.article-body h2{
  font-family:'Oswald',sans-serif;font-size:clamp(22px,2.5vw,30px);
  font-weight:700;text-transform:uppercase;letter-spacing:-.3px;
  color:var(--navy);margin:48px 0 16px;line-height:1.1;
  padding-bottom:10px;border-bottom:3px solid var(--red);
  display:inline-block;
}
.article-body h3{
  font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;
  text-transform:uppercase;letter-spacing:-.2px;
  color:var(--blue);margin:32px 0 12px;
}
.article-body h4{
  font-family:'Oswald',sans-serif;font-size:17px;font-weight:700;
  text-transform:uppercase;color:var(--navy);margin:24px 0 8px;
}
.article-body p{
  font-size:16px;color:var(--muted);line-height:1.85;margin-bottom:18px;
}
.article-body strong{color:var(--navy);font-weight:700}
.article-body a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;font-weight:500}
.article-body a:hover{color:var(--red)}
.article-body ul,.article-body ol{margin:0 0 20px;padding-left:0;list-style:none}
.article-body ul li,.article-body ol li{
  font-size:16px;color:var(--muted);line-height:1.7;
  padding:7px 0 7px 26px;position:relative;border-bottom:1px solid var(--border);
}
.article-body ul li:last-child,.article-body ol li:last-child{border-bottom:none}
.article-body ul li::before{content:"→";position:absolute;left:0;color:var(--red);font-weight:700}
.article-body ol{counter-reset:ol-c}
.article-body ol li{counter-increment:ol-c}
.article-body ol li::before{
  content:counter(ol-c);position:absolute;left:0;
  background:var(--red);color:var(--white);
  width:18px;height:18px;border-radius:50%;
  font-size:11px;font-weight:700;line-height:18px;text-align:center;
  margin-top:3px;
}

/* ── BLOCS SPÉCIAUX ── */
/* Réponse directe LLM */
.article-answer-box{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--r2);padding:24px 28px;margin:28px 0;
  border-left:5px solid var(--red);
}
.aab-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:8px}
.aab-text{font-size:16px;color:rgba(255,255,255,.9);line-height:1.75;font-weight:500}
.aab-text strong{color:var(--white)}

/* Highlight bleu */
.highlight-blue{
  background:var(--blue-l);border-left:4px solid var(--blue);
  border-radius:0 var(--r) var(--r) 0;padding:18px 22px;
  margin:24px 0;font-size:15px;color:var(--navy);line-height:1.7;
}
.highlight-blue strong{color:var(--blue)}

/* Highlight vert */
.highlight-green{
  background:var(--green-l);border-left:4px solid var(--green);
  border-radius:0 var(--r) var(--r) 0;padding:18px 22px;
  margin:24px 0;font-size:15px;color:#14532d;line-height:1.7;
}

/* Avertissement rouge */
.highlight-red{
  background:var(--red-l);border-left:4px solid var(--red);
  border-radius:0 var(--r) var(--r) 0;padding:18px 22px;
  margin:24px 0;font-size:15px;color:#7f1d1d;line-height:1.7;
}

/* Citation expert */
.expert-quote{
  background:var(--off);border:1.5px solid var(--border);
  border-radius:var(--r2);padding:24px 28px;margin:28px 0;
  position:relative;
}
.expert-quote::before{
  content:'"';font-family:'Oswald',sans-serif;font-size:80px;
  color:rgba(212,43,43,.15);position:absolute;top:-10px;left:16px;
  line-height:1;
}
.eq-text{font-size:16px;color:var(--muted);line-height:1.8;font-style:italic;margin-bottom:14px;padding-left:8px}
.eq-author{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--navy)}
.eq-av{width:36px;height:36px;border-radius:50%;background:var(--red);color:var(--white);font-family:'Oswald',sans-serif;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}

/* Tableau LLM intégré */
.llm-table{width:100%;border-collapse:collapse;font-size:14px;border-radius:var(--r);overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);margin:24px 0}
.llm-table thead tr{background:var(--navy)}
.llm-table thead th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.9)}
.llm-table tbody tr{background:var(--white)}
.llm-table tbody tr:nth-child(even){background:var(--off)}
.llm-table tbody tr:hover{background:var(--blue-l)}
.llm-table tbody td{padding:11px 16px;border-bottom:1px solid var(--border);color:var(--text);font-size:14px}
.llm-table tbody tr:last-child td{border-bottom:none}
.td-yes{color:var(--green);font-weight:700}
.td-no{color:var(--red);font-weight:700}
.td-warn{color:#d97706;font-weight:700}
.td-b{font-weight:700;color:var(--navy)}
.table-note{font-size:12px;color:var(--subtle);margin-top:8px;display:flex;align-items:flex-start;gap:5px;line-height:1.55}
.table-note::before{content:"ℹ";color:var(--blue);font-weight:700;flex-shrink:0}

/* Photo inline */
.article-photo{margin:32px 0}
.article-photo img{width:100%;border-radius:var(--r2);display:block;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.article-photo .photo-placeholder{aspect-ratio:3/2}
.article-photo figcaption{font-size:13px;color:var(--subtle);font-style:italic;margin-top:8px;text-align:center}

/* FAQ intégré */
.article-faq{margin:40px 0}
.article-faq h2{border-bottom:3px solid var(--red);padding-bottom:10px;margin-bottom:24px}
.fq{border-bottom:1px solid var(--border)}
.fq-q{padding:16px 0;font-size:16px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;color:var(--navy);transition:color .15s}
.fq-q:hover{color:var(--red)}
.fq-icon{width:24px;height:24px;border-radius:50%;background:var(--off);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--red);flex-shrink:0;font-weight:700;transition:all .2s}
.fq-q.open .fq-icon{background:var(--red);border-color:var(--red);color:var(--white)}
.fq-a{display:none;padding-bottom:16px;font-size:15px;color:var(--muted);line-height:1.75}
.fq-a.vis{display:block}

/* ── SIDEBAR ── */
.sidebar{position:sticky;top:84px}

/* Box CTA franchisé */
.franchisee-box{
  background:var(--navy);border-radius:var(--r2);overflow:hidden;
  margin-bottom:24px;
}
.fb-top{
  background:linear-gradient(135deg,var(--red),var(--red-d));
  padding:16px 20px;
}
.fb-top-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;color:var(--white);line-height:1.1}
.fb-top-sub{font-size:12px;color:rgba(255,255,255,.8);margin-top:4px}
.fb-body{padding:20px}
.fb-avail{display:flex;align-items:center;gap:8px;background:rgba(22,163,74,.15);border:1px solid rgba(22,163,74,.25);border-radius:8px;padding:9px 12px;margin-bottom:16px;font-size:13px;font-weight:700;color:#4ade80}
.fb-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pb 1.5s infinite;flex-shrink:0}
@keyframes pb{0%,100%{opacity:1}50%{opacity:.2}}
.fb-name{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:var(--white);margin-bottom:2px}
.fb-dept{font-size:12px;color:rgba(255,255,255,.5);margin-bottom:16px}
.btn-fb-call{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--red);color:var(--white);border-radius:10px;font-size:15px;font-weight:700;text-decoration:none;margin-bottom:10px;transition:background .2s}
.btn-fb-call:hover{background:var(--red-d)}
.btn-fb-devis{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s}
.btn-fb-devis:hover{background:rgba(255,255,255,.14)}

/* Tarifs rapides */
.tarif-box{background:var(--off);border:1.5px solid var(--border);border-radius:var(--r2);padding:20px;margin-bottom:24px}
.tarif-box-title{font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;color:var(--navy);margin-bottom:16px}
.tarif-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.tarif-row:last-child{border-bottom:none}
.tarif-label{color:var(--muted)}
.tarif-price{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;color:var(--red)}
.tarif-note{font-size:11px;color:var(--subtle);margin-top:10px;line-height:1.5}

/* Articles liés */
.related-box{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r2);padding:20px}
.related-box h3{font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;text-transform:uppercase;color:var(--navy);margin-bottom:14px}
.related-article{display:block;padding:12px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:opacity .15s}
.related-article:last-child{border-bottom:none}
.related-article:hover{opacity:.7}
.ra-type{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.ra-title{font-size:14px;font-weight:600;color:var(--navy);line-height:1.3}

/* ── MAILLAGE INTERNE EN PIED D'ARTICLE ── */
.article-maillage{
  background:var(--off);border-radius:var(--r2);
  padding:28px;margin:48px 0;
  border:1.5px solid var(--border);
}
.maillage-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;color:var(--navy);margin-bottom:20px}
.maillage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.maillage-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:16px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:block}
.maillage-card:hover{border-color:var(--blue);box-shadow:0 2px 12px rgba(26,92,168,.1)}
.mc-type{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.mc-title{font-size:14px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:6px;font-family:'Oswald',sans-serif;text-transform:uppercase}
.mc-desc{font-size:12px;color:var(--muted);line-height:1.5}
.mc-arrow{font-size:12px;color:var(--blue);font-weight:700;margin-top:8px}

/* Lien vers page département */
.dept-link-box{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--r2);padding:20px 24px;margin:32px 0;text-decoration:none;
  transition:opacity .15s;
}
.dept-link-box:hover{opacity:.9}
.dlb-left{}
.dlb-tag{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:4px}
.dlb-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;color:var(--white)}
.dlb-sub{font-size:13px;color:rgba(255,255,255,.55);margin-top:3px}
.dlb-btn{background:var(--red);color:var(--white);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:700;white-space:nowrap;font-family:'Oswald',sans-serif;text-transform:uppercase}

/* ── AUTEUR ── */
.author-box{
  border:1.5px solid var(--border);border-radius:var(--r2);
  padding:24px;margin:48px 0 0;
  display:flex;align-items:flex-start;gap:16px;
}
.author-av{
  width:64px;height:64px;border-radius:50%;flex-shrink:0;
  background:var(--red);color:var(--white);
  font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.author-info{}
.author-name{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;color:var(--navy);margin-bottom:2px}
.author-role{font-size:12px;color:var(--muted);margin-bottom:8px}
.author-bio{font-size:14px;color:var(--muted);line-height:1.65}
.author-certifs{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.certif-badge{background:var(--green-l);border:1px solid #86efac;color:#15803d;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}

/* ── FOOTER ── */
footer{background:#060f1c;padding:36px 24px;margin-top:80px;text-align:center}
footer p{font-size:13px;color:rgba(255,255,255,.35)}
footer a{color:rgba(255,255,255,.4);text-decoration:none}
footer a:hover{color:var(--white)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .page-wrap{grid-template-columns:1fr;gap:40px}
  .sidebar{position:static}
  .maillage-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{display:none}
  .maillage-grid{grid-template-columns:1fr}
  .author-box{flex-direction:column}
  .dept-link-box{flex-direction:column;align-items:flex-start}
}


/* Hide standalone nav when inside WordPress theme */
.page-template-default header.nav,
.elementor-page header.nav { display: none !important; }
