/* ============================================================
   WKH Ingénierie — Feuille de styles CUSTOM (versionnée, git)
   Chargée par le mu-plugin wkh-custom-css.php (toujours active).
   => Mets ton CSS écrit à la main ICI, pas dans le Customizer.
   ============================================================ */

/* ---- Variables de marque (Bleu acier) ---- */
:root{
  --steel:#3C6E99; --steel-d:#2E5577; --steel-l:#6E97B8;
  --deep:#243B52;
  --ink:#2D3742; --soft:#647079; --grey:#57636E;
  --line:#E0E7ED; --bg:#EEF3F7; --white:#fff;
}

/* ============================================================
   OVERRIDES du header natif Oxygen (Breakdance)
   ============================================================ */

/* Largeur du header : 100% = pleine largeur (mets 1280px si tu préfères) */
.bde-header-builder__container{ max-width:100% !important; }

/* Bouton "Demander un devis" en bleu acier (au lieu du bleu primary par défaut) */
.btn-devis .button-atom{ background:#3C6E99 !important; color:#fff !important; }
.btn-devis .button-atom:hover{ background:#2E5577 !important; }

/* Téléphone dans le header */
a.phone.breakdance-link{ color:#243B52 !important; text-decoration:none; }
.phone{ font-family:'Poppins',sans-serif; font-weight:600; font-size:.95rem; white-space:nowrap; }

/* Logo : hauteur cohérente (applique la classe wkh-logo-img à l'image) */
.wkh-logo-img, .wkh-logo-img img{ height:64px !important; width:auto !important; display:block; }

/* ============================================================
   Classes utilitaires (réutilisables sur tes pages / sections)
   ============================================================ */
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

.btn-steel{display:inline-block;font-family:'Poppins',sans-serif;font-weight:600;font-size:.95rem;
  background:var(--steel);color:#fff;padding:13px 24px;border-radius:10px;text-decoration:none;
  box-shadow:0 8px 18px rgba(60,110,153,.30);transition:.2s}
.btn-steel:hover{background:var(--steel-d);transform:translateY(-2px);color:#fff}

/* ============================================================
   PAGE D'ACCUEIL
   ============================================================ */
.wkh-home{font-family:'Inter',system-ui,sans-serif;color:var(--ink);line-height:1.7}
.wkh-home h2{font-family:'Poppins',sans-serif;color:var(--deep);font-size:2rem;line-height:1.2;margin:0 0 14px}
.wkh-home h2{font-weight:700;letter-spacing:-.01em}
.wkh-home h2::after{content:"";display:block;width:56px;height:4px;border-radius:2px;margin:16px auto 0;background:linear-gradient(90deg,var(--steel-l),var(--steel))}
/* Eyebrow plus affirmé : pastille acier + petit trait d'amorce */
.wkh-home .eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--steel);background:rgba(60,110,153,.10);padding:6px 14px;border-radius:999px;font-size:.74rem}
.wkh-home .eyebrow::before{content:"";width:16px;height:2px;border-radius:2px;background:var(--steel)}
.wkh-home h3{font-family:'Poppins',sans-serif;color:var(--deep);font-size:1.18rem;margin:0 0 8px}
.wkh-home p{margin:0 0 14px}
.wkh-home .eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--steel);margin-bottom:10px}
.wkh-home .lead{color:var(--soft);font-size:1.08rem;max-width:760px}
.wkh-home section{padding:76px 0}
.wkh-home .alt{background:var(--bg)}
.wkh-home .center{text-align:center}
.wkh-home .center .lead{margin-left:auto;margin-right:auto}

.hp-hero{background:linear-gradient(160deg,#fff,var(--bg))}
.hp-hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hp-hero h1{font-family:'Poppins',sans-serif;color:var(--deep);font-size:2.6rem;line-height:1.15;margin:0 0 18px}
.hp-hero h1 .hl{color:var(--steel)}
.hp-hero .visual{border-radius:16px;overflow:hidden;min-height:330px;background:#dfe7ee}
.hp-hero .visual img{width:100%;height:100%;object-fit:cover;display:block}
/* Image du hero (si l'image n'est pas un enfant direct de .visual) */
.hero-img, .hero-img img{width:100%;height:440px;object-fit:cover;border-radius:16px;display:block}
@media(max-width:900px){ .hero-img, .hero-img img{height:300px} }
.hp-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.btn-ghost{display:inline-block;font-family:'Poppins',sans-serif;font-weight:600;padding:13px 24px;border-radius:10px;border:1.5px solid var(--line);color:var(--deep);text-decoration:none}
.btn-ghost:hover{border-color:var(--steel);color:var(--steel)}

.hp-stats{background:var(--deep);color:#fff}
.hp-stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.hp-stats b{display:block;font-family:'Poppins',sans-serif;font-weight:800;font-size:2rem}
.hp-stats span{color:#9FB6CC;font-size:.92rem}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 24px;transition:.2s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(16,58,94,.10)}
.card h3{font-size:1.12rem}
.card p{color:var(--soft);font-size:.94rem;margin-bottom:10px}
.card a{font-family:'Poppins',sans-serif;font-weight:600;color:var(--steel);text-decoration:none;font-size:.9rem}
.card-ico{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:13px;background:rgba(60,110,153,.10);color:var(--steel);margin-bottom:16px}
.card-ico svg{width:27px;height:27px}

/* Mise en page deux colonnes (texte + checklist) */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;text-align:left}
.split h2{text-align:left}
.split h2::after{margin-left:0;margin-right:auto}
.split-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 30px;box-shadow:0 14px 34px rgba(16,58,94,.06)}
.check{list-style:none;margin:0;padding:0}
.check li{position:relative;padding:12px 0 12px 30px;color:var(--ink);border-bottom:1px solid var(--line);line-height:1.5}
.check li:last-child{border-bottom:0}
.check li::before{content:"✓";position:absolute;left:0;top:12px;color:var(--steel);font-weight:800}
@media(max-width:860px){ .split{grid-template-columns:1fr;gap:26px} }

/* Section "Pourquoi nous" — cartes valeurs */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.why-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px 26px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}
.why-item:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(16,58,94,.10)}
.why-item h3{font-family:'Poppins',sans-serif;color:var(--deep);font-size:1.08rem;margin:0 0 8px}
.why-item p{color:var(--soft);font-size:.95rem;line-height:1.6;margin:0}
@media(max-width:900px){ .why-grid{grid-template-columns:1fr} }

.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.feat h3{font-size:1.06rem}
.feat p{color:var(--soft);font-size:.94rem}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 22px}
.step .n{width:40px;height:40px;border-radius:10px;background:var(--steel);color:#fff;font-family:'Poppins',sans-serif;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.step h3{font-size:1.02rem}
.step p{color:var(--soft);font-size:.9rem}

/* Barre de filtres (page /realisations) */
.real-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:8px 0 8px}
.real-filter .rf-btn{font-family:'Poppins',sans-serif;font-weight:600;font-size:.88rem;color:var(--deep);
  background:#fff;border:1.5px solid var(--line);padding:9px 18px;border-radius:999px;cursor:pointer;transition:.18s}
.real-filter .rf-btn:hover{border-color:var(--steel);color:var(--steel)}
.real-filter .rf-btn.is-active{background:var(--steel);border-color:var(--steel);color:#fff}

.real-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}
.real{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:block;text-decoration:none;color:inherit;transition:transform .25s ease,box-shadow .25s ease,opacity .35s ease}
/* état animé du filtre */
#wkh-real-grid .real{will-change:opacity,transform}
.real.rf-hide{opacity:0;transform:translateY(10px) scale(.98);pointer-events:none}
.real:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(16,58,94,.10)}
.real .ph{height:200px;background:#dfe7ee;display:flex;align-items:center;justify-content:center;color:#8aa0b4;font-size:.85rem;text-align:center;padding:0;overflow:hidden}
.real .ph img{width:100%;height:100%;object-fit:cover;display:block;margin:0;border-radius:0}
.real .b{padding:18px 20px}
.real h3{font-size:1.0rem;margin-bottom:4px;line-height:1.3}
.real span{color:var(--soft);font-size:.85rem}
.real .cat{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--steel);margin-bottom:6px}
.real .excerpt{color:var(--soft);font-size:.9rem;line-height:1.55;margin:4px 0 12px}
.real .more{font-family:'Poppins',sans-serif;font-weight:600;font-size:.88rem;color:var(--steel)}

/* Intro (H1 + texte) en haut de /realisations */
.real-intro{max-width:840px;margin:0 auto 14px;text-align:center;padding:8px 24px 0}
.real-intro .eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel);margin-bottom:10px}
.real-intro h1{font-family:'Poppins',sans-serif;color:var(--deep);font-size:2.1rem;line-height:1.2;margin:0 0 14px}
.real-intro p{color:var(--soft);font-size:1.06rem;line-height:1.7;margin:0}

/* CTA en bas de /realisations */
.real-cta{background:linear-gradient(150deg,var(--deep),var(--steel));color:#fff;text-align:center;
  padding:60px 24px;margin:52px auto 0;}
.real-cta h2{font-family:'Poppins',sans-serif;color:#fff;font-size:1.7rem;line-height:1.2;margin:0 0 10px}
.real-cta p{color:#CFE0EE;max-width:600px;margin:0 auto 22px;line-height:1.6}

/* Carte Leaflet des réalisations */
.wkh-map{height:460px;border-radius:16px;overflow:hidden;margin-top:40px;border:1px solid var(--line);z-index:0}
.wkh-map a{color:var(--steel)}
@media(max-width:560px){ .wkh-map{height:360px} }

/* ============================================================
   HERO des PAGES INTERNES (.wkh-hero-int) — shortcode [wkh_hero_interne]
   ============================================================ */
.wkh-hero-int{--nav:#13233A;--steel-l:#7CA6CC;position:relative;overflow:hidden;color:#fff;
  background:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px) 0 0/46px 46px,
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px) 0 0/46px 46px,
    radial-gradient(900px 500px at 85% -25%,rgba(124,166,204,.16),transparent 60%),
    var(--nav)}
.wkh-hero-int .in{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:16px 24px 18px}
.wkh-hero-int .eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-l);margin-bottom:12px}
.wkh-hero-int h1{font-family:'Poppins',sans-serif;font-weight:800;color:#fff !important;font-size:2.5rem;line-height:1.15;margin:0;max-width:760px}
.wkh-hero-int .hero-accent{display:block;width:66px;height:4px;border-radius:2px;margin:20px 0 0;background:linear-gradient(90deg,var(--steel-l),var(--steel))}
.wkh-hero-int p{color:#C3D2E0;font-size:1.08rem;line-height:1.7;max-width:620px;margin:14px 0 0}
.wkh-hero-int .blueprint{position:absolute;top:0;right:0;bottom:0;width:58%;z-index:1;color:var(--steel-l);opacity:.55;pointer-events:none;
  -webkit-mask-image:linear-gradient(to left,#000 26%,transparent 88%);
          mask-image:linear-gradient(to left,#000 26%,transparent 88%)}
.wkh-hero-int .blueprint svg{position:absolute;right:-18px;top:50%;transform:translateY(-50%);height:120%;width:auto}
@media(max-width:900px){
  .wkh-hero-int h1{font-size:1.9rem}
  .wkh-hero-int .in{padding:14px 24px 16px}
  .wkh-hero-int .blueprint{opacity:.25;width:85%}
}

/* Pages légales (mentions légales, confidentialité) */
.legal{max-width:840px;margin:0 auto;padding:24px;color:var(--ink)}
.legal h2{font-family:'Poppins',sans-serif;color:var(--deep);font-size:1.4rem;margin:2.2rem 0 .6rem}
.legal h3{font-family:'Poppins',sans-serif;color:var(--deep);font-size:1.08rem;margin:1.4rem 0 .3rem}
.legal p,.legal li{line-height:1.75;margin:0 0 .8rem}
.legal ul{margin:0 0 1rem 1.2rem}
.legal a{color:var(--steel)}
.legal .maj{color:var(--soft);font-size:.9rem}

/* Conteneur du formulaire de contact : largeur limitée + centré */
.wkh-form{max-width:720px;margin-left:auto;margin-right:auto;width:100%}

/* Bloc coordonnées (Contact) */
.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:36px}
.contact-info .ci{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;text-align:center}
.contact-info .ci .card-ico{margin:0 auto 12px}
.contact-info .ci h3{font-family:'Poppins',sans-serif;color:var(--deep);font-size:1rem;margin:0 0 4px}
.contact-info .ci a,.contact-info .ci p{color:var(--soft);text-decoration:none;margin:0;font-size:.95rem}
.contact-info .ci a:hover{color:var(--steel)}

/* Contenu d'article de blog */
.wkh-article{max-width:760px;margin:0 auto;color:var(--ink);font-size:1.06rem;line-height:1.8}
.wkh-article .lead{font-size:1.18rem;color:var(--soft);line-height:1.7;margin:0 0 1.4rem}
.wkh-article h2{font-family:'Poppins',sans-serif;font-weight:700;color:var(--deep);font-size:1.5rem;line-height:1.25;margin:2.4rem 0 .7rem}
.wkh-article h2::after{content:"";display:block;width:48px;height:3px;border-radius:2px;margin:12px 0 0;background:linear-gradient(90deg,var(--steel-l),var(--steel))}
.wkh-article h3{font-family:'Poppins',sans-serif;font-weight:600;color:var(--deep);font-size:1.16rem;margin:1.6rem 0 .4rem}
.wkh-article p{margin:0 0 1.1rem}
.wkh-article ul,.wkh-article ol{margin:0 0 1.2rem 1.3rem}
.wkh-article li{margin:0 0 .5rem}
.wkh-article a{color:var(--steel);text-decoration:underline;text-underline-offset:2px}
.wkh-article strong{color:var(--deep)}
.wkh-article h1{font-family:'Poppins',sans-serif;font-weight:800;color:var(--deep);font-size:2rem;line-height:1.2;margin:0 0 1.1rem}
.wkh-article-img{width:100%;height:auto;border-radius:14px;display:block;margin:0 0 1.8rem}

/* En-tête d'article construit dans Oxygen : heading (H1) + image, enfants directs de .wkh-article */
.wkh-article > h1,
.wkh-article > .bde-heading{
  font-family:'Poppins',sans-serif !important;font-weight:800 !important;color:var(--deep) !important;
  font-size:2.2rem !important;line-height:1.2 !important;margin:1.8rem 0 .4rem !important}
.wkh-article > h1::after,
.wkh-article > .bde-heading::after{
  content:"";display:block;width:64px;height:4px;border-radius:2px;margin:18px 0 0;
  background:linear-gradient(90deg,var(--steel-l),var(--steel))}
.wkh-article > img,
.wkh-article > .oxy-image{
  width:100% !important;display:block;border-radius:14px;margin:1.6rem 0 2.2rem;
  max-height:460px;object-fit:cover}

/* Section Zones d'intervention (home) */
.zones{padding:76px 0;background:var(--bg)}
.zones .wrap{max-width:900px;text-align:center}
.zones .eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel);margin-bottom:10px}
.zones h2{font-family:'Poppins',sans-serif;color:var(--deep);font-size:2rem;line-height:1.2;margin:0 0 14px}
.zones .lead{color:var(--soft);font-size:1.06rem;line-height:1.7;max-width:720px;margin:0 auto 26px}
.zones-deps{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:22px}
.zones-deps span{font-family:'Poppins',sans-serif;font-weight:600;font-size:.9rem;color:var(--deep);
  background:#fff;border:1.5px solid var(--line);padding:9px 16px;border-radius:999px}
.zones-towns{color:var(--soft);font-size:.95rem;margin:0 0 28px}
.zones-towns b{color:var(--deep);font-weight:600}

.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.avis{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px}
.avis .stars{color:#F2B705;letter-spacing:2px;margin-bottom:10px}
.avis p{font-style:italic;color:var(--ink);margin-bottom:6px}
.avis .who{font-family:'Poppins',sans-serif;font-weight:600;color:var(--deep);font-size:.9rem}

.faq{max-width:820px;margin:40px auto 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:0 20px;margin-bottom:12px}
.faq summary{position:relative;font-family:'Poppins',sans-serif;font-weight:600;color:var(--deep);cursor:pointer;padding:18px 34px 18px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:16px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:600;font-size:1.4rem;line-height:1;color:var(--steel);transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .a{padding:14px 0;color:var(--soft);font-size:.96rem}

.hp-cta{background:linear-gradient(150deg,var(--deep),var(--steel));color:#fff;text-align:center}
.hp-cta h2{color:#fff}
.hp-cta p{color:#CFE0EE;max-width:600px;margin:0 auto 22px}
.btn-white{display:inline-block;font-family:'Poppins',sans-serif;font-weight:600;background:#fff;color:var(--deep);padding:14px 28px;border-radius:10px;text-decoration:none}

@media(max-width:900px){
  .hp-hero .wrap{grid-template-columns:1fr}
  .cards,.feat,.steps,.real-grid,.avis-grid,.hp-stats .wrap{grid-template-columns:1fr 1fr}
  .hp-hero h1{font-size:2.1rem}
}
@media(max-width:560px){.cards,.feat,.steps,.real-grid,.avis-grid,.hp-stats .wrap{grid-template-columns:1fr}}

/* ============================================================
   HERO ACCUEIL (.wkh-hero)
   Déplacé depuis le <style> en ligne du code block Oxygen.
   => Modifier le hero ICI, plus dans Oxygen. Oxygen ne garde que le HTML.
   ============================================================ */
.wkh-hero{--nav:#13233A;--steel:#3C6E99;--steel-l:#7CA6CC;color:#fff;overflow:hidden;font-family:'Inter',system-ui,sans-serif;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px) 0 0/44px 44px,
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px) 0 0/44px 44px,
    radial-gradient(1200px 520px at 72% -12%,rgba(124,166,204,.14),transparent 60%),
    var(--nav)}
.wkh-hero *{box-sizing:border-box}
.wkh-hero .in{max-width:1180px;margin:0 auto;padding:72px 24px;display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:center}
.wkh-hero .eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-l);margin-bottom:16px}
.wkh-hero h1{font-family:'Poppins',sans-serif;font-weight:800;font-size:2.7rem;line-height:1.28;margin:0 0 20px;color:#fff !important}
.wkh-hero h1 .u{white-space:nowrap;color:#fff;padding-bottom:6px;
  background:linear-gradient(90deg,var(--steel-l),var(--steel)) no-repeat 0 100%;background-size:100% 6px}
.wkh-hero p.sub{font-size:1.08rem;color:#C3D2E0;max-width:520px;line-height:1.7;margin:0}
.wkh-hero .cta{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}
.wkh-hero .b1{font-family:'Poppins',sans-serif;font-weight:600;background:#fff;color:var(--nav);padding:14px 26px;border-radius:10px;text-decoration:none;box-shadow:0 10px 24px rgba(0,0,0,.22)}
.wkh-hero .b1:hover{transform:translateY(-2px)}
.wkh-hero .b2{font-family:'Poppins',sans-serif;font-weight:600;color:#fff;border:1.5px solid rgba(255,255,255,.4);padding:14px 24px;border-radius:10px;text-decoration:none}
.wkh-hero .b2:hover{border-color:#fff}
.wkh-hero .trust{margin-top:26px;display:flex;gap:20px;flex-wrap:wrap;color:#9FB6CC;font-size:.9rem}
.wkh-hero .trust span{display:flex;align-items:center;gap:7px}
.wkh-hero .trust b{color:var(--steel-l)}
.wkh-hero .visual img{width:100%;height:auto;display:block;filter:drop-shadow(0 24px 40px rgba(0,0,0,.35))}
@media(max-width:900px){
  .wkh-hero .in{grid-template-columns:1fr;padding:54px 24px;gap:30px}
  .wkh-hero h1{font-size:2.05rem}
}

/* ============================================================
   CONTENU D'ARTICLE / PAGE INTERNE (.wkh-article)
   Enrober le contenu HTML dans <div class="wkh-article">…</div> :
   texte aligné à GAUCHE, seuls les H2 restent CENTRÉS.
   ============================================================ */
.wkh-article{max-width:880px;margin:0 auto;padding:0 24px;color:var(--ink);text-align:left}
.wkh-article > h2{font-family:'Poppins',sans-serif;font-weight:800;color:var(--deep);
  font-size:1.9rem;line-height:1.25;text-align:center;margin:0 0 10px}
/* trait sous le H2 centré */
.wkh-article > h2 + .wkh-sep,
.wkh-article .wkh-sep{display:block;width:66px;height:4px;border-radius:2px;margin:14px auto 30px;
  background:linear-gradient(90deg,var(--steel-l),var(--steel))}
.wkh-article h3{font-family:'Poppins',sans-serif;font-weight:700;color:var(--deep);
  font-size:1.22rem;line-height:1.3;text-align:left;margin:34px 0 10px}
.wkh-article p{text-align:left;line-height:1.75;color:var(--soft);margin:0 0 16px;font-size:1.02rem}
.wkh-article ul,.wkh-article ol{text-align:left;line-height:1.7;color:var(--soft);margin:0 0 18px;padding-left:22px}
.wkh-article li{margin:6px 0}
.wkh-article a{color:var(--steel);text-decoration:underline}

/* ============================================================
   CARROUSEL GALERIE (.wkhc) — override du shortcode [gallery]
   ============================================================ */
.wkhc{max-width:980px;margin:8px auto 2px;padding:0 24px}
.wkhc-viewport{position:relative;overflow:hidden;border-radius:14px;background:#0e1d30;
  box-shadow:0 18px 40px rgba(16,58,94,.16)}
.wkhc-track{display:flex;gap:14px;transition:transform .55s cubic-bezier(.4,.0,.2,1);will-change:transform}
.wkhc-slide{flex:0 0 calc((100% - 14px)/2);margin:0;cursor:zoom-in;aspect-ratio:16/9;background:#0e1d30}
.wkhc-slide img{width:100%;height:100%;object-fit:cover;display:block}
.wkhc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;border:none;border-radius:50%;cursor:pointer;
  background:rgba(20,35,58,.55);color:#fff;font-size:1.1rem;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:.18s;backdrop-filter:blur(2px)}
.wkhc-arrow:hover{background:var(--steel)}
.wkhc-prev{left:14px}
.wkhc-next{right:14px}
.wkhc-count{position:absolute;right:14px;bottom:12px;z-index:3;
  background:rgba(20,35,58,.6);color:#fff;font-family:'Poppins',sans-serif;font-size:.78rem;
  padding:4px 10px;border-radius:999px;letter-spacing:.03em}
.wkhc-dots{display:flex;justify-content:center;gap:9px;margin-top:14px}
.wkhc-dot{width:9px;height:9px;border-radius:50%;border:none;cursor:pointer;padding:0;
  background:var(--line);transition:.2s}
.wkhc-dot.is-active{background:var(--steel);transform:scale(1.25)}
@media(max-width:560px){
  .wkhc-slide{flex:0 0 100%;aspect-ratio:4/3}
  .wkhc-arrow{width:38px;height:38px}
}

/* ---- Lightbox (zoom au clic) ---- */
.wkhc-lb{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;
  background:rgba(8,16,28,.92);padding:30px}
.wkhc-lb[hidden]{display:none}
.wkhc-lb-img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,.5)}
.wkhc-lb-close,.wkhc-lb-prev,.wkhc-lb-next{position:absolute;border:none;cursor:pointer;color:#fff;
  background:rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.18s}
.wkhc-lb-close:hover,.wkhc-lb-prev:hover,.wkhc-lb-next:hover{background:var(--steel)}
.wkhc-lb-close{top:22px;right:26px;width:46px;height:46px;font-size:1.7rem;line-height:1}
.wkhc-lb-prev,.wkhc-lb-next{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:1.4rem}
.wkhc-lb-prev{left:22px}
.wkhc-lb-next{right:22px}
@media(max-width:560px){
  .wkhc-lb-prev,.wkhc-lb-next{width:42px;height:42px}
  .wkhc-lb-prev{left:10px}.wkhc-lb-next{right:10px}
}

/* ============================================================
   CARTE SOCIÉTÉ (footer) — shortcode [wkh_carte_societe]
   ============================================================ */
.wkh-map-soc{max-width:340px}
.wkh-map-soc__t{font-family:'Poppins',sans-serif;font-weight:700;color:#fff;margin:0 0 12px;font-size:1rem}
.wkh-map-soc__frame{position:relative;height:var(--h,220px);border-radius:12px;overflow:hidden;
  border:1px solid rgba(255,255,255,.14);box-shadow:0 12px 28px rgba(0,0,0,.28);background:#0e1d30}
.wkh-map-soc__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;
  filter:grayscale(.25) contrast(1.02)}
.wkh-map-soc__dir{display:inline-block;margin-top:10px;font-size:.85rem;color:#C3D2E0;text-decoration:none;line-height:1.4}
.wkh-map-soc__dir:hover{color:#fff;text-decoration:underline}

/* ============================================================
   APPARITION AU SCROLL (reveal) — piloté par function.js
   Ajoute .is-visible quand l'élément entre dans le viewport.
   Classes utilisables aussi à la main dans Oxygen :
   .reveal (fondu), .reveal-up, .reveal-left, .reveal-right
   ============================================================ */
.reveal,.reveal-up,.reveal-left,.reveal-right{
  opacity:0;
  transition:opacity .7s ease,transform .7s cubic-bezier(.22,.61,.36,1);
  will-change:opacity,transform;
}
.reveal-up{transform:translateY(34px)}
.reveal-left{transform:translateX(-46px)}
.reveal-right{transform:translateX(46px)}
.reveal.is-visible,
.reveal-up.is-visible,
.reveal-left.is-visible,
.reveal-right.is-visible{
  opacity:1;
  transform:none;
}
/* Accessibilité : aucun mouvement si l'utilisateur le demande */
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-up,.reveal-left,.reveal-right{
    opacity:1!important;transform:none!important;transition:none!important;
  }
}

/* Petit relief sur les chiffres pendant le count-up */
.hp-stats b{transition:transform .3s ease}

/* ============================================================
   BROCHURE (home) — shortcode [wkh_brochure]
   ============================================================ */
.wkh-broch{background:var(--bg);padding:64px 0}
.wkh-broch__inner{display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:center}
.wkh-broch__cover a{display:block;border-radius:12px;overflow:hidden;
  box-shadow:0 18px 40px rgba(36,59,82,.22);transition:transform .3s ease,box-shadow .3s ease}
.wkh-broch__cover a:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(36,59,82,.30)}
.wkh-broch__cover img{display:block;width:100%;height:auto}
.wkh-broch__ph{display:flex;align-items:center;justify-content:center;height:380px;
  background:var(--deep);color:#fff;font-family:'Poppins',sans-serif;font-weight:800;
  font-size:2.4rem;letter-spacing:.08em}
.wkh-broch__eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--steel);margin-bottom:10px}
.wkh-broch__title{font-family:'Poppins',sans-serif;font-weight:800;color:var(--deep);
  font-size:2rem;margin:0 0 12px}
.wkh-broch__text{color:var(--soft);font-size:1.05rem;line-height:1.6;margin:0 0 24px;max-width:48ch}
.wkh-broch__btns{display:flex;flex-wrap:wrap;gap:14px}
@media(max-width:760px){
  .wkh-broch{padding:44px 0}
  .wkh-broch__inner{grid-template-columns:1fr;gap:28px;text-align:center}
  .wkh-broch__cover{max-width:260px;margin:0 auto}
  .wkh-broch__text{margin-left:auto;margin-right:auto}
  .wkh-broch__btns{justify-content:center}
}

/* ============================================================
   PAGE BROCHURE (HTML, SEO) — shortcode [wkh_brochure_page]
   ============================================================ */
.wkh-bp{color:var(--ink)}
.wkh-bp__hero{background:var(--deep);color:#fff;padding:64px 0}
.wkh-bp__eyebrow{display:inline-block;font-family:'Poppins',sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:var(--steel-l);margin-bottom:12px}
.wkh-bp__h1{font-family:'Poppins',sans-serif;font-weight:800;font-size:2.4rem;line-height:1.15;margin:0 0 18px}
.wkh-bp__lead{font-size:1.12rem;line-height:1.7;color:#CDD9E5;max-width:70ch;margin:0}
.wkh-bp__dl{margin-top:24px;background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.wkh-bp__dl:hover{border-color:#fff;color:#fff}
.wkh-bp__sec{padding:54px 24px}
.wkh-bp__sec h2{font-family:'Poppins',sans-serif;font-weight:800;color:var(--deep);
  font-size:1.7rem;margin:0 0 8px}
.wkh-bp__mat{color:var(--steel);font-weight:600;margin:0 0 26px}
.wkh-bp__sec>p{font-size:1.05rem;line-height:1.7;color:var(--soft);max-width:80ch}
.wkh-bp__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
.wkh-bp__card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;
  box-shadow:0 8px 22px rgba(36,59,82,.06)}
.wkh-bp__card h3{font-family:'Poppins',sans-serif;font-weight:700;color:var(--steel-d);
  font-size:1.18rem;margin:0 0 12px}
.wkh-bp__card p{color:var(--soft);line-height:1.6;margin:0 0 10px}
.wkh-bp__card ul{margin:0 0 10px;padding-left:18px;color:var(--ink)}
.wkh-bp__card li{margin:5px 0}
.wkh-bp__tags{list-style:none;display:flex;flex-wrap:wrap;gap:12px;padding:0;margin:0 0 24px}
.wkh-bp__tags li{background:var(--bg);border:1px solid var(--line);border-radius:999px;
  padding:9px 18px;font-family:'Poppins',sans-serif;font-weight:600;color:var(--deep);font-size:.92rem}
.wkh-bp__cta{background:var(--bg);padding:54px 0;text-align:center}
.wkh-bp__cta h2{font-family:'Poppins',sans-serif;font-weight:800;color:var(--deep);font-size:1.7rem;margin:0 0 10px}
.wkh-bp__coord{color:var(--soft);margin:0 0 24px}
.wkh-bp__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
@media(max-width:860px){.wkh-bp__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){
  .wkh-bp__hero{padding:44px 0}.wkh-bp__h1{font-size:1.9rem}
  .wkh-bp__grid{grid-template-columns:1fr}
}
