/* ============================================================
   WAPIX - ENHANCE LAYER (global, toutes les pages clonées)
   Smooth scroll + scroll reveals + micro-interactions.
   Non-cassant : l'état "caché" est posé par JS, jamais en CSS seul.
   ============================================================ */
:root{ --wx-ease:cubic-bezier(.16,1,.3,1); }

/* ── Retirer le sous-menu (méga-menu) de RÉALISATIONS ── */
.cmsmasters-megamenu-container{ display:none !important; }

/* ════ Blog / Actualités : hero enrichi (SEO + GEO) sur fond vidéo ════ */
body.blog .elementor-element-6feaa677{
  box-shadow:inset 0 0 0 2000px rgba(0,0,0,.46) !important;   /* voile : lisibilité sur la vidéo */
  padding:clamp(120px,16vh,190px) 22px clamp(46px,7vh,80px) !important;
}
body.blog .elementor-element-53a0b3c9{ display:none !important; }  /* fil d'Ariane "No breadcrumbs" masqué */
body.blog .wx-bhero{ max-width:920px; margin:0 auto; text-align:center; color:#fff; }
body.blog .wx-bhero__eyebrow{ font-family:'DM Mono',monospace; text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; color:#F0B200; margin:0 0 14px; }
body.blog .wx-bhero__title{ font-family:'Bricolage Grotesque',system-ui,sans-serif !important; font-weight:700 !important; font-size:clamp(2rem,4.6vw,3.4rem) !important; line-height:1.04 !important; letter-spacing:-.02em !important; color:#fff !important; margin:0 auto 18px !important; max-width:20ch; }
body.blog .wx-bhero__lead{ font-size:clamp(1rem,1.25vw,1.18rem); line-height:1.6; color:#e6e6e6; max-width:64ch; margin:0 auto 22px; }
body.blog .wx-bhero__lead strong{ color:#fff; }
body.blog .wx-bhero__chips{ list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:9px; padding:0; margin:0 0 26px; }
body.blog .wx-bhero__chips li{ font-size:.8rem; font-weight:600; padding:7px 14px; border:1px solid rgba(255,255,255,.28); border-radius:999px; color:#fff; background:rgba(255,255,255,.06); }
body.blog .wx-bhero__ctas{ display:flex; flex-wrap:wrap; justify-content:center; gap:12px; }
body.blog .wx-bhero__btn{ display:inline-flex; align-items:center; justify-content:center; padding:13px 26px; border-radius:999px; font-weight:600; font-size:.95rem; text-decoration:none !important; transition:transform .2s ease; }
body.blog .wx-bhero__btn:not(.wx-bhero__btn--ghost){ background:#F0B200; color:#111 !important; box-shadow:0 8px 24px rgba(240,178,0,.32); }
body.blog .wx-bhero__btn--ghost{ background:transparent; color:#fff !important; border:1.5px solid rgba(255,255,255,.4); }
body.blog .wx-bhero__btn:hover{ transform:translateY(-2px); }

/* ════ Article : hero unifié - fond dégradé sombre, titre centré blanc, sans méta ════ */
/* Cible la classe stable .cmsmasters-section-for-header-yes (les IDs Elementor varient selon le gabarit). */
body.single-post .cmsmasters-section-for-header-yes{
  display:flex !important; flex-direction:column !important;
  align-items:center !important; justify-content:center !important; text-align:center !important;
  min-height:50vh !important;
  padding:clamp(120px,15vh,180px) 22px clamp(42px,6vh,72px) !important;
  background:#14110d linear-gradient(140deg,#241c12 0%,#0f0d0a 72%) !important;
}
/* conteneurs internes : fond transparent (efface une éventuelle image de fond), centrés pleine largeur */
body.single-post .cmsmasters-section-for-header-yes .e-con,
body.single-post .cmsmasters-section-for-header-yes .e-con-inner{
  background:transparent !important; background-image:none !important; box-shadow:none !important;
  display:flex !important; flex-direction:column !important;
  align-items:center !important; justify-content:center !important;
  width:100% !important; max-width:none !important; margin:0 auto !important; padding-left:0 !important; padding-right:0 !important; min-height:0 !important; text-align:center !important;
}
/* neutraliser le voile noir décoratif (::before/::after) du gabarit, qui apparaissait en bande noire sans image */
body.single-post .cmsmasters-section-for-header-yes .e-con::before,
body.single-post .cmsmasters-section-for-header-yes .e-con::after,
body.single-post .cmsmasters-section-for-header-yes [data-id]::before,
body.single-post .cmsmasters-section-for-header-yes [data-id]::after{ content:none !important; display:none !important; background:transparent !important; }
/* masquer catégorie, auteur, date, avatar + images de hero (évite le doublon d'image) */
body.single-post .cmsmasters-section-for-header-yes [data-name="taxonomy"],
body.single-post .cmsmasters-section-for-header-yes [data-name="author"],
body.single-post .cmsmasters-section-for-header-yes [data-name="date"],
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-meta-data,
body.single-post .cmsmasters-section-for-header-yes .elementor-widget-cmsmasters-post-featured-image,
body.single-post .cmsmasters-section-for-header-yes img{ display:none !important; }
/* le H1/excerpt se rétrécissaient (width:max-content) et se calaient à gauche → bloc pleine largeur centré */
body.single-post .cmsmasters-section-for-header-yes h1.entry-title,
body.single-post .cmsmasters-section-for-header-yes .entry-title,
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-widget-title__heading,
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text,
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text .entry-content,
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text .entry-content p{
  display:block !important; width:100% !important; max-width:760px !important;
  margin-left:auto !important; margin-right:auto !important; text-align:center !important;
}
/* tout le texte du hero en blanc */
body.single-post .cmsmasters-section-for-header-yes,
body.single-post .cmsmasters-section-for-header-yes h1,
body.single-post .cmsmasters-section-for-header-yes .entry-title,
body.single-post .cmsmasters-section-for-header-yes .entry-content,
body.single-post .cmsmasters-section-for-header-yes .entry-content p,
body.single-post .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text *{ color:#fff !important; }

/* ════ Article : retirer encadré auteur + formulaire de commentaires (sur tous les articles) ════ */
body.single-post .elementor-widget-cmsmasters-post-comments,
body.single-post #comments,
body.single-post .comment-respond,
body.single-post .elementor-widget-cmsmasters-post-author,
body.single-post [data-name="author"],
body.single-post .cmsmasters-postmeta[data-name="author"],
body.single-post .avatar-wrap{ display:none !important; }

/* ════ Article : mise en page de lecture UNIFIÉE sur tous les articles (modèle = branding-pme) ════ */
/* certains articles ont les conteneurs Elementor en display:inline (variable --display absente)
   → le contenu n'était pas centré (pleine largeur). On centre directement la colonne de lecture. */
body.single-post .elementor-widget-cmsmasters-post-content{ display:block !important; width:100% !important; }
body.single-post .elementor-widget-cmsmasters-post-content > .elementor-widget-container{ display:block !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content{ max-width:820px !important; margin-left:auto !important; margin-right:auto !important; width:auto !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content h2{
  font-family:'Bricolage Grotesque',system-ui,sans-serif !important; font-weight:700 !important;
  font-size:clamp(22px,2.3vw,27px) !important; line-height:1.25 !important; letter-spacing:-.02em !important;
  color:#111 !important; margin:46px 0 14px !important;
}
body.single-post .elementor-widget-cmsmasters-post-content .entry-content h3{
  font-family:'Bricolage Grotesque',system-ui,sans-serif !important; font-weight:600 !important;
  font-size:clamp(18px,1.9vw,21px) !important; line-height:1.35 !important; letter-spacing:-.01em !important;
  color:#1a1a1a !important; margin:34px 0 10px !important;
}
body.single-post .elementor-widget-cmsmasters-post-content .entry-content p{
  font-family:'DM Sans',sans-serif !important; font-size:16px !important; line-height:1.75 !important; color:#333 !important; margin:0 0 20px !important;
}
body.single-post .elementor-widget-cmsmasters-post-content .entry-content p a,
body.single-post .elementor-widget-cmsmasters-post-content .entry-content li a{
  color:#bb8a00 !important; text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; font-weight:600;
}
body.single-post .elementor-widget-cmsmasters-post-content .entry-content img{ max-width:100% !important; height:auto !important; border-radius:14px; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content figure{ margin:36px 0 !important; width:auto !important; max-width:100% !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content figure img{ width:100%; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content figcaption{ font-family:'DM Mono',monospace; font-size:.74rem; letter-spacing:.02em; color:#9a9a9a; text-align:center; margin-top:.6em; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content ul,
body.single-post .elementor-widget-cmsmasters-post-content .entry-content ol{ margin:0 0 22px !important; padding-left:1.35em !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content li{ font-family:'DM Sans',sans-serif !important; font-size:16px !important; line-height:1.7 !important; color:#333 !important; margin:0 0 9px !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content ul li{ list-style:disc !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content ol li{ list-style:decimal !important; }
body.single-post .elementor-widget-cmsmasters-post-content .entry-content blockquote{
  border-left:3px solid #F0B200 !important; margin:30px 0 !important; padding:4px 0 4px 22px !important;
  font-style:italic; color:#444 !important; font-size:1.06em;
}

/* ════ Pages services : hero UNIFIÉ - fond sombre + titre blanc (cohérent avec Réalisations) ════ */
/* cible les pages à hero cmsmasters par défaut ; exclut nos-realisations (hero custom, page-id-62489) ; blog est body.blog donc non concerné */
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes{
  background:#15110c linear-gradient(135deg,#221a12 0%,#100d0a 72%) !important;
  position:relative;
}
/* conteneurs internes transparents (sinon un fond gris clair masque le dégradé) */
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .e-con,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .e-con-inner{
  background-color:transparent !important; background-image:none !important;
}
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes h1,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes h1.cmsmasters-widget-title__heading,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .cmsmasters-widget-title__heading{
  font-family:'Bricolage Grotesque',system-ui,sans-serif !important; font-weight:700 !important;
  font-size:clamp(2.1rem,4.2vw,3.3rem) !important; line-height:1.06 !important;
  letter-spacing:-.02em !important; color:#fff !important;
}
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .cmsmasters-widget-title__subtitle,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .cmsmasters-widget-short-text *,
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes p{ color:rgba(255,255,255,.85) !important; }
/* phrase de description sous le titre du hero service */
body.page-template-default:not(.page-id-62489) .cmsmasters-section-for-header-yes .wx-svc-desc{
  display:block !important; margin:18px auto 0 !important; max-width:46ch;
  font-family:'DM Sans',sans-serif !important; font-size:clamp(1rem,1.15vw,1.12rem) !important;
  line-height:1.6 !important; color:rgba(255,255,255,.82) !important; text-align:center !important;
}

/* ════ Boutons swap cmsmasters : style identique au bouton « Lancer l'audit » (.cta-diag-btn) ════ */
.elementor-widget-cmsmasters-swap-button__icon{ display:none !important; }   /* masque les icônes demo cassées */
.elementor-widget-cmsmasters-swap-button__button{
  display:inline-flex !important; align-items:center !important; gap:8px !important;
  padding:12px 24px !important; border-radius:50px !important;
  background:#F0B200 !important; color:#0a0a0a !important; border:none !important;
  font-family:'DM Sans',sans-serif !important; font-weight:700 !important; font-size:14px !important;
  letter-spacing:normal !important; text-decoration:none !important; cursor:pointer !important;
  box-shadow:none !important;
  transition:transform .2s var(--wx-ease), filter .2s var(--wx-ease) !important;
}
.elementor-widget-cmsmasters-swap-button__button:hover{ transform:translateY(-2px) !important; filter:brightness(1.05) !important; }
/* neutraliser le liseré + padding interne du texte (effet « bouton dans le bouton ») */
.elementor-widget-cmsmasters-swap-button__text{
  color:#0a0a0a !important; border:none !important; background:transparent !important;
  padding:0 !important; margin:0 !important; border-radius:0 !important; box-shadow:none !important;
}
.elementor-widget-cmsmasters-swap-button__button::after{ content:"↗" !important; font-size:1em; line-height:1; font-weight:700; }

/* ════ nos-solutions : hero passé en sombre (cohérent avec les pages services) ════ */
.wx-sol-hero{ background:#15110c linear-gradient(135deg,#221a12 0%,#100d0a 72%) !important; }
.wx-sol-hero .eyebrow{ color:#F0B200 !important; }
.wx-sol-hero h1{ color:#fff !important; }
.wx-sol-hero h1 em{ color:#F0B200 !important; }
.wx-sol-hero .lead{ color:#cfcfcf !important; }
.wx-sol-stats b{ color:#fff !important; }
.wx-sol-stats span{ color:#9a9a9a !important; }
.wx-sol-hero .wx-sol-btn--ghost{ color:#fff !important; border-color:rgba(255,255,255,.4) !important; background:transparent !important; }

/* ════ Articles blog : image, CTA, maillage interne, FAQ (SEO/GEO) ════ */
body.single-post .wx-art-figure{ margin:0 0 30px; }
body.single-post .wx-art-figure img{ width:100%; height:auto; border-radius:14px; display:block; }
body.single-post .wx-art-figure figcaption{ margin-top:.6em; font-family:'DM Mono',monospace; font-size:.74rem; letter-spacing:.03em; color:#9a9a9a; text-align:center; }
body.single-post .wx-art-cta{ max-width:720px; margin:42px auto; padding:30px 32px; border-radius:18px;
  background:linear-gradient(135deg,#0a0a0a,#1a1a1a); color:#fff; text-align:center; }
body.single-post .wx-art-cta h3{ font-family:'Bricolage Grotesque',sans-serif!important; font-optical-sizing:auto; font-weight:600; font-size:clamp(1.3rem,2.4vw,1.8rem); color:#fff!important; margin:0 0 .4em; letter-spacing:-.02em; }
body.single-post .wx-art-cta p{ color:rgba(255,255,255,.78)!important; max-width:52ch; margin:0 auto 1.2em; }
body.single-post .wx-art-cta .wx-art-btns{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
body.single-post .wx-art-cta a{ display:inline-flex; align-items:center; gap:8px; padding:13px 24px; border-radius:100px; font-weight:600; text-decoration:none!important; font-size:.95rem; transition:transform .35s var(--wx-ease),box-shadow .35s; }
body.single-post .wx-art-cta a.wx-cta-primary{ background:#F0B200; color:#141414!important; }
body.single-post .wx-art-cta a.wx-cta-ghost{ background:transparent; color:#fff!important; border:1px solid rgba(255,255,255,.3); }
body.single-post .wx-art-cta a:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(0,0,0,.3); }
body.single-post .wx-art-faq{ max-width:720px; margin:36px auto; }
body.single-post .wx-art-faq summary{ cursor:pointer; list-style:none; padding:18px 2px; font-family:'Bricolage Grotesque',sans-serif!important; font-weight:600; font-size:clamp(1rem,1.4vw,1.16rem); color:#141414; border-bottom:1px solid rgba(0,0,0,.1); position:relative; }
body.single-post .wx-art-faq summary::-webkit-details-marker{ display:none; }
body.single-post .wx-art-faq summary::after{ content:'+'; position:absolute; right:4px; top:50%; transform:translateY(-50%); color:#F0B200; font-weight:700; }
body.single-post .wx-art-faq details[open] summary::after{ content:'−'; }
body.single-post .wx-art-faq details > div{ padding:6px 2px 18px; color:#454545; line-height:1.7; border-bottom:1px solid rgba(0,0,0,.06); }
body.single-post .wx-art-links{ max-width:720px; margin:36px auto 0; padding-top:22px; border-top:1px solid rgba(0,0,0,.1); }
body.single-post .wx-art-links h2{ margin:0 0 .6em!important; }
body.single-post .wx-art-links ul{ list-style:none; padding:0; display:grid; gap:10px; }
body.single-post .wx-art-links a{ color:#111; text-decoration:none!important; font-weight:600; border-bottom:2px solid #F0B200; transition:color .25s; }
body.single-post .wx-art-links a:hover{ color:#b98700; }

/* ════ Bloc réalisations sur pages "Nos solutions" (design = page réalisations) ════ */
.wx-sol-real{ background:#0a0a0a; padding:54px 0 64px; width:100% !important; display:block !important; }
.wx-sol-real .wapix-real-videos__inner{ max-width:1400px; margin:0 auto; padding:0 24px; }
.wx-sol-real .wapix-real-grid{ display:grid; grid-template-columns:4fr 4fr 4fr; gap:1px; background:#1d1d1d;
  transition:grid-template-columns .6s var(--wx-ease), grid-template-rows .6s var(--wx-ease); }
.wx-sol-real .wapix-real-card{ position:relative; overflow:hidden; background:#0a0a0a; cursor:pointer; min-height:0; min-width:0; height:100%; }
.wx-sol-real .wapix-real-card__media{ position:absolute; inset:0; opacity:0; transition:opacity .55s ease; }
.wx-sol-real .wapix-real-card:hover .wapix-real-card__media{ opacity:1; }
.wx-sol-real .wapix-real-card__video{ width:100%; height:100%; object-fit:cover; display:block; }
.wx-sol-real .wapix-real-card__overlay{ position:absolute; inset:0; z-index:2; display:flex; align-items:center; justify-content:center; padding:22px; pointer-events:none; transition:opacity .5s ease; }
.wx-sol-real .wapix-real-card:hover .wapix-real-card__overlay{ opacity:0; }
.wx-sol-real .wapix-real-card__title{ font-family:'Fraunces',serif !important; font-style:italic !important; font-weight:400 !important; font-optical-sizing:auto; color:#fff !important; font-size:clamp(1.1rem,1.6vw,1.8rem) !important; letter-spacing:-.01em !important; line-height:1.15 !important; text-align:center; margin:0; }
@media(max-width:980px){
  .wx-sol-real .wapix-real-grid{ grid-template-columns:1fr !important; height:auto !important; gap:3px; }
  .wx-sol-real .wapix-real-card{ aspect-ratio:16/9; height:auto; }
  .wx-sol-real .wapix-real-card__media{ opacity:1; }
  .wx-sol-real .wapix-real-card__overlay{ opacity:1; align-items:flex-end; justify-content:flex-start; background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.75)); }
  .wx-sol-real .wapix-real-card__title{ text-align:left; }
}

/* ── BOUTON RETOUR EN HAUT (footer "Click here") : rond sombre + chevron ↑ ── */
a[href="#accueil-scroll-top"]{
  width:64px!important;height:64px!important;min-width:0!important;max-width:64px!important;
  padding:0!important;margin:0!important;border-radius:50%!important;
  background:#0a0a0a!important;border:1px solid rgba(255,255,255,.18)!important;
  display:inline-flex!important;align-items:center!important;justify-content:center!important;
  overflow:hidden!important;box-shadow:0 12px 32px rgba(0,0,0,.4)!important;cursor:pointer;
  transition:transform .4s var(--wx-ease),background .3s ease,border-color .3s ease!important;
}
a[href="#accueil-scroll-top"]:hover{transform:translateY(-5px)!important;background:#171717!important;border-color:rgba(255,255,255,.4)!important}
a[href="#accueil-scroll-top"] > *{display:none!important}
a[href="#accueil-scroll-top"]::after{
  content:''!important;display:block!important;width:22px!important;height:22px!important;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 15 12 9 18 15'/%3E%3C/svg%3E")!important;
  transition:transform .4s var(--wx-ease)!important;
}
a[href="#accueil-scroll-top"]:hover::after{transform:translateY(-2px)!important}

/* ---- SCROLL REVEALS (classe posée par JS) ---- */
.wx-reveal{opacity:0;transform:translateY(38px);
  transition:opacity 1s var(--wx-ease),transform 1s var(--wx-ease)}
.wx-reveal.wx-in{opacity:1;transform:none}

/* ---- BOUTONS : lift fluide + ombre ---- */
.elementor-button,
.elementor-widget-button a,
.elementor-widget-cmsmasters-button a,
.cmsmasters-button__link,
.btn-y,.btn-k,.btn-d,.btn-w,
.ct-submit,
button[type="submit"],
.wpx-process .proc-cta a{
  transition:transform .45s var(--wx-ease),box-shadow .45s var(--wx-ease),
    background-color .35s ease,color .35s ease,border-color .35s ease !important;
  will-change:transform;
}
.elementor-button:hover,
.elementor-widget-button a:hover,
.elementor-widget-cmsmasters-button a:hover,
.cmsmasters-button__link:hover,
.btn-y:hover,.btn-k:hover,.btn-d:hover,.btn-w:hover,
.ct-submit:hover,
button[type="submit"]:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(0,0,0,.16);
}

/* ---- IMAGES DE CARTES : zoom doux dans leur cadre ---- */
.cmsmasters-widget-blog__entry-image,
.elementor-widget-cmsmasters-featured-box__image-link,
.elementor-widget-cmsmasters-featured-box__image-wrap,
.cmsmasters-widget-blog__entry-thumb,
.real-card-img,.project-card-img{
  overflow:hidden !important;
}
.cmsmasters-widget-blog__entry-image img,
.elementor-widget-cmsmasters-featured-box__image-link img,
.elementor-widget-cmsmasters-featured-box__image-wrap img,
.cmsmasters-widget-blog__entry-thumb img{
  transition:transform .9s var(--wx-ease) !important;will-change:transform;
}
.cmsmasters-widget-blog__entry:hover .cmsmasters-widget-blog__entry-image img,
.elementor-widget-cmsmasters-featured-box:hover .elementor-widget-cmsmasters-featured-box__image-link img,
.elementor-widget-cmsmasters-featured-box:hover .elementor-widget-cmsmasters-featured-box__image-wrap img{
  transform:scale(1.06);
}

/* ---- LIENS DE NAV / TITRES BLOG : transition douce ---- */
.cmsmasters-widget-blog__entry-title a,
.elementor-widget-cmsmasters-featured-box__title{
  transition:color .3s ease !important;
}

/* ---- FEATURED BOX : lift de la carte entière ---- */
.elementor-widget-cmsmasters-featured-box{
  transition:transform .45s var(--wx-ease) !important;
}

/* ---- FOCUS clavier propre ---- */
a:focus-visible,button:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--y,#F0B200);outline-offset:3px;border-radius:4px;
}

/* ---- Désactivation si reduced-motion ---- */
@media(prefers-reduced-motion:reduce){
  .wx-reveal{opacity:1 !important;transform:none !important;transition:none !important}
  *{scroll-behavior:auto !important}
}

/* ════════════════════════════════════════════════════════════════
   ACCORDÉON FAQ - éditorial, lisible, animé.
   Technique grid-template-rows 0fr→1fr : fluide dans les deux sens,
   ZÉRO texte fantôme (le contenu plié mesure réellement 0), sans JS de mesure.
   ════════════════════════════════════════════════════════════════ */
.elementor-widget-cmsmasters-toggles__list{border-top:1px solid rgba(0,0,0,.12)}
.elementor-widget-cmsmasters-toggles__item{border-bottom:1px solid rgba(0,0,0,.12)}

/* ligne question */
.elementor-widget-cmsmasters-toggles__title{cursor:pointer;display:flex!important;align-items:center;gap:22px;
  padding:22px 2px!important;margin:0!important;list-style:none}
.elementor-widget-cmsmasters-toggles__title-link{flex:1 1 auto;display:flex!important;align-items:center;
  text-decoration:none!important;background:none!important;border:none!important;padding:0!important;margin:0!important;min-height:0!important}
.elementor-widget-cmsmasters-toggles__title-text{
  font-family:'Bricolage Grotesque',sans-serif!important;font-optical-sizing:auto;
  font-weight:600!important;text-transform:none!important;letter-spacing:-.01em!important;
  font-size:clamp(1rem,1.35vw,1.16rem)!important;line-height:1.3!important;color:#141414!important;
  transition:color .3s ease}
.elementor-widget-cmsmasters-toggles__title:hover .elementor-widget-cmsmasters-toggles__title-text,
.elementor-widget-cmsmasters-toggles__item.wx-acc-open .elementor-widget-cmsmasters-toggles__title-text{color:#000!important}

/* bouton rond +/- (se remplit en jaune à l'ouverture) */
.elementor-widget-cmsmasters-toggles__trigger{flex:0 0 auto;width:40px;height:40px;border-radius:50%;
  display:flex!important;align-items:center!important;justify-content:center!important;
  border:1px solid rgba(0,0,0,.18);background:transparent;line-height:0!important;
  transition:background .35s var(--wx-ease),border-color .35s ease,transform .4s var(--wx-ease)}
/* centrer le +/− dans le cercle */
.elementor-widget-cmsmasters-toggles__trigger-closed,
.elementor-widget-cmsmasters-toggles__trigger-opened{
  display:flex!important;align-items:center!important;justify-content:center!important;
  width:100%;height:100%;line-height:0!important;margin:0!important;padding:0!important}
.elementor-widget-cmsmasters-toggles__trigger svg{display:block!important;margin:0 auto!important}
.elementor-widget-cmsmasters-toggles__title:hover .elementor-widget-cmsmasters-toggles__trigger{border-color:#141414;transform:scale(1.06)}
.elementor-widget-cmsmasters-toggles__item.wx-acc-open .elementor-widget-cmsmasters-toggles__trigger{background:#F0B200;border-color:#F0B200}
.elementor-widget-cmsmasters-toggles__trigger svg{width:13px;height:13px;fill:#141414}
.elementor-widget-cmsmasters-toggles__item:not(.wx-acc-open) .elementor-widget-cmsmasters-toggles__trigger-opened{display:none!important}
.elementor-widget-cmsmasters-toggles__item.wx-acc-open .elementor-widget-cmsmasters-toggles__trigger-closed{display:none!important}

/* réponse : pliée = grid-rows 0fr (hauteur réelle 0), dépliée = 1fr */
.elementor-widget-cmsmasters-toggles__content{
  display:grid!important;grid-template-rows:0fr;overflow:hidden!important;opacity:0;padding:0!important;
  transition:grid-template-rows .48s var(--wx-ease),opacity .4s ease!important}
.elementor-widget-cmsmasters-toggles__item.wx-acc-open .elementor-widget-cmsmasters-toggles__content{grid-template-rows:1fr;opacity:1}
.wx-acc-inner{min-height:0;overflow:hidden;padding:2px 52px 26px 2px}
.wx-acc-inner,.wx-acc-inner p,.wx-acc-inner li,.wx-acc-inner span{
  font-family:'DM Sans',sans-serif!important;font-size:1rem!important;line-height:1.72!important;color:#454545!important}
.wx-acc-inner p{margin:0 0 .7em!important;max-width:68ch}
.wx-acc-inner :last-child{margin-bottom:0!important}

/* ════════════════════════════════════════════════════════════════
   ARTICLES BLOG - lecture éditoriale, minimaliste, animée (sans sidebar)
   Scope strict : body.single-post (n'affecte pas le listing /blog/).
   ════════════════════════════════════════════════════════════════ */
/* barre de progression de lecture */
.wx-readbar{position:fixed;top:0;left:0;width:100%;height:3px;background:#F0B200;z-index:9999;
  transform:scaleX(0);transform-origin:0 50%;will-change:transform;pointer-events:none}

/* hero article : titre + meta centrés, aérés */
body.single-post h1.entry-title,
body.single-post h1.cmsmasters-widget-title__heading{
  max-width:18ch;margin-left:auto;margin-right:auto;text-align:center}
body.single-post .cmsmasters-meta-data{justify-content:center!important;gap:14px 20px;flex-wrap:wrap;
  font-family:'DM Mono',monospace!important;font-size:.78rem!important;letter-spacing:.04em;
  text-transform:uppercase;color:#8a8a8a!important}
body.single-post .cmsmasters-meta-data a{color:#8a8a8a!important}

/* colonne de lecture : on neutralise le 800px centré, on aligne à gauche */
body.single-post .elementor-widget-cmsmasters-post-content{width:100%!important;max-width:none!important}
body.single-post .entry-content{text-align:left!important;max-width:none!important;margin:0!important;
  font-family:'DM Sans',sans-serif;font-size:1.12rem;line-height:1.8;color:#2c2c2c}
/* chaque bloc dans une colonne de lecture confortable et centrée */
body.single-post .entry-content > *{max-width:720px;margin-left:auto!important;margin-right:auto!important}
body.single-post .entry-content > figure,
body.single-post .entry-content > img,
body.single-post .entry-content > .wp-block-image{max-width:880px}

/* paragraphes */
body.single-post .entry-content p{margin:0 0 1.45em;color:#333}
body.single-post .entry-content strong{font-weight:700;color:#111}
/* titres de section : espacement éditorial (tailles gérées par le bloc inline) */
body.single-post .entry-content h2{letter-spacing:-.02em;margin-top:2.2em!important}
body.single-post .entry-content h3{letter-spacing:-.01em;margin-top:1.8em!important}
/* liens : soulignement jaune */
body.single-post .entry-content a{color:#111;text-decoration:underline;text-decoration-color:#F0B200;
  text-decoration-thickness:2px;text-underline-offset:3px;transition:color .25s ease,text-decoration-color .25s ease}
body.single-post .entry-content a:hover{color:#b98700;text-decoration-color:#b98700}
/* listes */
body.single-post .entry-content ul,
body.single-post .entry-content ol{margin:0 0 1.5em;padding-left:1.4em}
body.single-post .entry-content li{margin:0 0 .55em;line-height:1.72;color:#333}
body.single-post .entry-content ul li::marker{color:#F0B200}
body.single-post .entry-content ol li::marker{color:#b98700;font-family:'DM Mono',monospace;font-weight:600}
/* citations */
body.single-post .entry-content blockquote{margin:2em auto;padding:.2em 0 .2em 1.5em;border-left:3px solid #F0B200;
  font-family:'Fraunces',serif;font-style:italic;font-size:1.32rem;line-height:1.5;color:#1a1a1a}
/* images */
body.single-post .entry-content img{display:block;width:100%;height:auto;border-radius:14px;margin:1.9em auto}
body.single-post .entry-content figure{margin:1.9em auto}
body.single-post .entry-content figcaption{margin-top:.7em;text-align:center;
  font-family:'DM Mono',monospace;font-size:.78rem;letter-spacing:.03em;color:#9a9a9a}

/* révélations douces des blocs (posées par JS) */
body.single-post .wx-areveal{opacity:0;transform:translateY(20px);
  transition:opacity .7s var(--wx-ease),transform .7s var(--wx-ease)}
body.single-post .wx-areveal.wx-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  body.single-post .wx-areveal{opacity:1!important;transform:none!important}
  .wx-readbar{display:none}
}

/* ════════════════════════════════════════════════════════════════
   LISTING BLOG (body.blog) - grille éditoriale moderne (cartes JS)
   ════════════════════════════════════════════════════════════════ */
body.blog .wx-bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px 28px;
  max-width:1180px;margin:0 auto;padding:0 24px}
@media(max-width:980px){body.blog .wx-bgrid{grid-template-columns:repeat(2,1fr);gap:30px 24px}}
@media(max-width:640px){body.blog .wx-bgrid{grid-template-columns:1fr;gap:26px}}

body.blog .wx-bcard{display:flex;flex-direction:column;text-decoration:none!important;color:inherit;
  background:#fff;border:1px solid #ededed;border-radius:16px;overflow:hidden;
  transition:transform .5s var(--wx-ease),box-shadow .5s var(--wx-ease),border-color .4s ease}
body.blog .wx-bcard:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,0,0,.1);border-color:#e2e2e2}
body.blog .wx-bcard-img{display:block;aspect-ratio:16/10;overflow:hidden;background:#f2f2f2}
body.blog .wx-bcard-img img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s var(--wx-ease);will-change:transform}
body.blog .wx-bcard:hover .wx-bcard-img img{transform:scale(1.06)}
body.blog .wx-bcard-body{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:22px 22px 24px;flex:1}
body.blog .wx-bcard-cat{font-family:'DM Mono',monospace;font-size:.66rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:#141414;background:#F0B200;padding:5px 11px;border-radius:100px}
body.blog .wx-bcard-title{font-family:'Bricolage Grotesque',sans-serif;font-optical-sizing:auto;
  font-weight:600;font-size:1.16rem;line-height:1.26;letter-spacing:-.01em;color:#121212;transition:color .3s ease}
body.blog .wx-bcard:hover .wx-bcard-title{color:#000}
body.blog .wx-bcard-exc{font-family:'DM Sans',sans-serif;font-size:.94rem;line-height:1.6;color:#6a6a6a;margin:0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
body.blog .wx-bcard-date{margin-top:auto;font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.03em;color:#a0a0a0;padding-top:4px}

/* carte LEAD : pleine largeur, image + texte côte à côte */
@media(min-width:760px){
  body.blog .wx-bcard--lead{grid-column:1/-1;flex-direction:row;align-items:stretch}
  body.blog .wx-bcard--lead .wx-bcard-img{flex:0 0 56%;aspect-ratio:auto;min-height:340px}
  body.blog .wx-bcard--lead .wx-bcard-body{justify-content:center;padding:40px 44px;gap:16px}
  body.blog .wx-bcard--lead .wx-bcard-title{font-size:clamp(1.55rem,2.6vw,2.15rem);line-height:1.12}
  body.blog .wx-bcard--lead .wx-bcard-exc{font-size:1.05rem;-webkit-line-clamp:4}
}

/* bouton « Voir plus » centré (remplace la pagination numérotée) */
body.blog .wx-bmore{display:flex;justify-content:center;margin:56px auto 8px}
body.blog .wx-bmore-btn{appearance:none;cursor:pointer;border:1.5px solid #111;background:#fff;color:#111;
  font-family:'Bricolage Grotesque',system-ui,sans-serif;font-weight:600;font-size:.97rem;letter-spacing:-.01em;
  padding:15px 38px;border-radius:999px;transition:background .25s var(--wx-ease),color .25s,transform .2s,box-shadow .25s}
body.blog .wx-bmore-btn:hover{background:#F0B200;border-color:#F0B200;color:#111;transform:translateY(-2px);box-shadow:0 10px 26px rgba(240,178,0,.32)}
body.blog .wx-bmore-btn:active{transform:translateY(0)}

/* pagination native masquée (remplacée par « Voir plus ») */
body.blog ul.page-numbers{display:none !important}
body.blog ul.page-numbers.__legacy{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;list-style:none;padding:0;margin:52px auto 0}
body.blog ul.page-numbers li{margin:0}
body.blog .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;
  padding:0 13px;border:1px solid #e4e4e4;border-radius:11px;font-family:'DM Mono',monospace;font-size:.88rem;
  color:#333;text-decoration:none;transition:border-color .3s ease,color .3s ease,background .3s ease}
body.blog a.page-numbers:hover{border-color:#141414;color:#000}
body.blog .page-numbers.current{background:#F0B200;border-color:#F0B200;color:#141414;font-weight:600}
body.blog .page-numbers svg{width:14px;height:14px}

/* ════════════════════════════════════════════════════════════════
   LOGOS MARQUEE - clients + technologies (défilement infini fluide)
   Le JS Swiper/marquee d'origine échoue sur le site statique ; on
   reprend la main avec un ruban CSS animé, GPU, sans dépendance.
   ════════════════════════════════════════════════════════════════ */
.wx-mq{position:relative;width:100%;overflow:hidden;display:flex;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);}
.wx-mq-track{display:flex;align-items:center;flex-wrap:nowrap;width:max-content;
  animation:wx-mq-x linear infinite;will-change:transform}
.wx-mq--tech .wx-mq-track{animation-direction:reverse}
.wx-mq:hover .wx-mq-track{animation-play-state:paused}
@keyframes wx-mq-x{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.wx-mq-seq{display:flex;align-items:center;flex:0 0 auto}
.wx-mq-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  padding:0 clamp(26px,4.4vw,66px)}
.wx-mq-item img{width:auto!important;max-width:none!important;
  object-fit:contain;display:block;
  transition:transform .45s var(--wx-ease),opacity .45s ease,filter .45s ease;will-change:transform}
/* CLIENTS : bloc jaune - logos en silhouette noire, plus grands */
.wx-mq--clients .wx-mq-item img{height:clamp(42px,4.8vw,62px)!important;opacity:.8;filter:brightness(0)}
.wx-mq--clients .wx-mq-item:hover img{opacity:1;filter:brightness(0);transform:scale(1.1)}
/* TECH : logos plus grands, couleur, désaturés au repos puis ravivés */
.wx-mq--tech .wx-mq-item img{height:clamp(36px,4.2vw,54px)!important;opacity:.62;filter:grayscale(.9)}
.wx-mq--tech .wx-mq-item:hover img{opacity:1;filter:none;transform:scale(1.1)}

/* ── BLOC CLIENTS UNIFIÉ : fond jaune (titre + logos ensemble) ── */
.wx-clients-yellow{background:#F0B200!important}
.wx-clients-yellow .elementor-widget-cmsmasters-advanced-title__text{color:#141414!important}
/* neutraliser l'ancienne bande noire + resserrer */
.wx-clients-band{background:transparent!important;
  padding-top:clamp(20px,3vw,40px)!important;padding-bottom:clamp(30px,4vw,52px)!important}
/* statique si reduced-motion */
.wx-mq-track.wx-mq-static{animation:none!important;flex-wrap:wrap;justify-content:center;width:100%}
@media(prefers-reduced-motion:reduce){
  .wx-mq{-webkit-mask-image:none;mask-image:none}
}

/* ===== Uniformisation du template d'article (single-post) ===== */
/* 1) Masquer le bloc auteur partout : un seul template d'article */
body.single-post .elementor-widget-cmsmasters-author-box,
body.single-post .cmsmasters-author-box,
body.single-post .cmsmasters-post-author,
body.single-post .elementor-widget-author-box,
body.single-post .cmsmasters-theme-box-author{ display:none !important; }

/* 2) CTA article — carte sombre : texte lisible (l'inline color:#fff était écrasé par le thème) */
body.single-post .entry-content div[style*="0a0a0a"] h3{ color:#fff !important; }
body.single-post .entry-content div[style*="0a0a0a"] p{ color:#ccc !important; }
/* carte jaune : titre foncé lisible sur fond jaune */
body.single-post .entry-content div[style*="F0B200"] h3{ color:#141414 !important; }

/* 3) Pied d'article cadré (navigation + articles similaires : pas pleine largeur) */
body.single-post .elementor-widget-cmsmasters-post-navigation,
body.single-post .e-con:has(.elementor-widget-cmsmasters-blog-slider),
body.single-post .e-con:has(.cmsmasters-thumb-more-posts){
  max-width:1160px !important;
  margin-left:auto !important; margin-right:auto !important;
}

/* ===== Bloc contact flottant (sur les articles) ===== */
#wx-float-contact{position:fixed;left:20px;bottom:20px;z-index:9998;font-family:'DM Sans',sans-serif}
#wx-float-contact .wxfc-toggle{display:inline-flex;align-items:center;gap:8px;background:#F0B200;color:#0a0a0a;border:none;border-radius:100px;padding:13px 22px;font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 8px 26px rgba(0,0,0,.22);transition:transform .25s,box-shadow .25s}
#wx-float-contact .wxfc-toggle:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(240,178,0,.45)}
#wx-float-contact .wxfc-panel{position:absolute;left:0;bottom:58px;width:330px;max-width:calc(100vw - 40px);background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,.22);padding:20px;animation:wxfcIn .3s ease}
@keyframes wxfcIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
#wx-float-contact .wxfc-panel[hidden]{display:none}
#wx-float-contact .wxfc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
#wx-float-contact .wxfc-head strong{font-family:'Bricolage Grotesque',sans-serif;font-size:17px;color:#0a0a0a}
#wx-float-contact .wxfc-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:#999;padding:0 4px}
#wx-float-contact .wxfc-form{display:flex;flex-direction:column;gap:10px}
#wx-float-contact .wxfc-form input,#wx-float-contact .wxfc-form textarea{width:100%;border:1px solid rgba(0,0,0,.15);border-radius:10px;padding:11px 13px;font-family:'DM Sans',sans-serif;font-size:14px;color:#0a0a0a;outline:none;transition:border-color .2s;background:#fafafa;box-sizing:border-box}
#wx-float-contact .wxfc-form input:focus,#wx-float-contact .wxfc-form textarea:focus{border-color:#F0B200}
#wx-float-contact .wxfc-form textarea{resize:vertical;min-height:74px}
#wx-float-contact .wxfc-send{background:#0a0a0a;color:#fff;border:none;border-radius:100px;padding:12px;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s}
#wx-float-contact .wxfc-send:hover{background:#222}
#wx-float-contact .wxfc-send:disabled{opacity:.6;cursor:default}
#wx-float-contact .wxfc-status{font-size:13px;text-align:center;min-height:18px}
#wx-float-contact .wxfc-status.ok{color:#16a34a}
#wx-float-contact .wxfc-status.err{color:#dc2626}
@media(max-width:600px){#wx-float-contact{left:12px;bottom:12px}#wx-float-contact .wxfc-toggle{padding:11px 18px;font-size:13px}}

/* ===== Sécurité responsive : pas de défilement horizontal (bandes full-bleed 100vw) ===== */
html{overflow-x:clip}
